Forum Discussion

chris01's avatar
chris01
New Contributor
3 years ago

OpenAPI: xml

Hello,

 

I would like to define for a put request a request body as described:

 

<startupConfig>
    <kroneMaterialNumbers>
        <KMAT number="204241000" nameProduktstrukturService="BX404-10">
            <WorkingSteps>
                <WorkingStep OrderNr="1">stepSetup</WorkingStep>
                <WorkingStep OrderNr="2">stepKSC</WorkingStep>
 
Because of Working Step is an array I can't find a solution to describe the attribute "OrderNr" in OpenAPI 3.0
 
I tried to use properties 
 
WorkingStep :
  type: array
  properties:
  1. properties:
  2.   number:
  3.     type: integer
  4.     xml:
  5.      attribute: true

  items:
   ...
 
but no attributes are display or generated.
 
Can anyone help?
  • chichepo's avatar
    chichepo
    Champion Level 1

    chris01 

    I tried this definition:

     

    components:
      schemas:
        KroneMaterialNumbers:
          type: object
          properties:
            kroneMaterialNumbers:
              $ref: '#/components/schemas/KMAT'
          xml:
            attribute: true
            name: kroneMaterialNumbers
        KMAT:
          type: object
          xml:
            name: KMAT
          properties:
            number:
              type: string
              example: 204241000
              xml:
                attribute: true
            nameProduktstrukturService:
              type: string
              example: BX404-10
              xml:
                attribute: true
            workingSteps:
              $ref: '#/components/schemas/WorkingSteps'
              
        WorkingSteps:
          type: array
          items:
            $ref: '#/components/schemas/WorkingStep'
          xml:
            wrapped : true
            name: WorkingSteps
    
        WorkingStep:
          type: object
          xml: 
            name: WorkingStep
          properties:
            OrderNr:
              type: string
              example: 1
              xml:
                attribute: true

     

     

    I get this:


    By the way, you can check this page

    Let me know

    • chris01's avatar
      chris01
      New Contributor

      Hello Chichepo,

       

      thanks for your answer. My problem is, by your solutions you get an array like this:

       

              <KMAT number="204241000" nameProduktstrukturService="BX404-10">
                  <WorkingSteps>
                      <WorkingStep OrderNr="1">stepSetup</WorkingStep>
                  </WorkingSteps>
                  <WorkingSteps>
                      <WorkingStep OrderNr="2">stepSetup</WorkingStep>
                  </WorkingSteps>
              </KMAT>

       

      but what I'm looking for is to process this kind of input:

       

              <KMAT number="204241000" nameProduktstrukturService="BX404-10">
                  <WorkingSteps>
                      <WorkingStep OrderNr="1">stepSetup</WorkingStep>
                      <WorkingStep OrderNr="2">stepKSC</WorkingStep>
                      <WorkingStep OrderNr="3">stepCleanHubDrive</WorkingStep>
                      <WorkingStep OrderNr="4">stepHeadersimulator</WorkingStep>
                      <WorkingStep OrderNr="5">stepParkBrake</WorkingStep>
                      <WorkingStep OrderNr="6">stepFieldSimulationHighPressureFor</WorkingStep>
                      <WorkingStep OrderNr="7">stepFieldSimulationHighPressureBack</WorkingStep>
                      <WorkingStep OrderNr="8">stepFieldSimulationIntake1</WorkingStep>
                      <WorkingStep OrderNr="9">stepFieldSimulationIntake2</WorkingStep>
                      <WorkingStep OrderNr="10">stepFieldSimulationHeader</WorkingStep>
                      <WorkingStep OrderNr="12">stepSpeedForwardRoad</WorkingStep>
                      <WorkingStep OrderNr="11">stepMRDT</WorkingStep>
                  </WorkingSteps>
              </KMAT>

       

      The function which I want to implement is to import a given set xmls and I can't change the format because of it is still be used.

       

      Regards