Changes for page Changing the default message format
                  Last modified by Danniar Firdausy on 2024/09/18 13:34
              
      
      From version  1.2 
    
    
              edited by Bouke Reitsma
        
on 2023/02/27 15:30
     on 2023/02/27 15:30
      Change comment:
              There is no comment for this version
          
         
      To version  10.1 
    
    
              edited by Bouke Reitsma
        
on 2023/03/03 13:17
     on 2023/03/03 13:17
      Change comment:
              There is no comment for this version
          
         Summary
- 
          Page properties (2 modified, 0 added, 0 removed)
Details
- Page properties
- 
      - Title
-   ... ... @@ -1,1 +1,1 @@ 1 -inte rmediate-apimanagement-restxml1 +Changing the default messaging format to XML 
- Content
-   ... ... @@ -1,6 +1,6 @@ 1 1 {{container}}{{container layoutStyle="columns"}}((( 2 2 3 -In our crash course on the API Gateway pattern, we have learned about setting up the API Gateway. However, we did notyetdelve intothespecificsof howtoupdateyourexistingAPI Gatewaysolution. In thismicrolearning,wewill focus on updating theDesignphase ofyourAPI Gateway(andthesubsequentsteps)andwewillfocus onupdating theCreatephaseofyourAPI Gateway(andthesubsequent steps). This tolearnthe impactof updates andtolearnhowwe canachievethis.3 +In our crash course on the API Gateway pattern, we have learned about setting up the API Gateway. By default, the messaging format chosen for your gateway is JSON. However, in some instances, other message formats are more appropriate as default. In this microlearning, we focus on changing the default message format and show the impact this has on flows in Create. 4 4 5 5 Should you have any questions, please contact [[academy@emagiz.com>>mailto:academy@emagiz.com]]. 6 6 ... ... @@ -10,84 +10,42 @@ 10 10 11 11 == 2. Key concepts == 12 12 13 -Th is microlearningcentersaroundupdatingyourAPI Gateway.13 +There are no specific concepts to consider for now that require additional explanation. 14 14 15 - Byupdating,we mean:Changingexisting softwareto reflectnew insightsor ideas that have come up duringdevelopmentand/ortesting15 +== 3. Changing the default messaging format == 16 16 17 -* Updating can happen from Design 18 -* Updating can happen from Create 19 -* Both situations have a different impact 17 +In our crash course on the API Gateway pattern, we have learned about setting up the API Gateway. By default, the messaging format selected for your gateway is JSON. However, the default messaging format can be changed in your project to for example, XML. This change can be made in Design -> Settings -> API Management. On the right side of this overview are the gateway settings. The last entry of this overview is the Default Format. By clicking on the Edit settings button, you enter the following overview 20 20 21 - == 3.UpdatingyourAPI Gateway Operations==19 +[[image:Main.Images.Microlearning.WebHome@intermediate-api-management-changing-default-messaging-format--edit-settings.png]] 22 22 23 - In our crashcourseon the API Gatewaypattern,we havelearned aboutsettingupthe API Gateway. However,we did notyetdelveintothespecificsofhowto updateyour existing API Gateway solution.In thismicrolearning,we willfocus on updatingtheDesign phase of your API Gateway(andthesubsequentsteps)and we willfocusonupdatingtheCreatephaseofyourAPI Gateway(and theubsequentsteps).Thisto learntheimpactofupdatesandtolearnhowwecanachieve this.21 +The last option allows you to switch between JSON or XML as your default messaging format in the gateway. In order to apply your new default to your project, you must press "Apply settings" in Design -> Architecture to confirm your change~*. 24 24 25 -* Updating can happen from Design 26 -* Updating can happen from Create 27 -* Both situations have a different impact 23 +{{info}}~* Note Changing the default messaging format does not affect existing operations in Create. Migrating these flows requires a reset of the exit flow. Additionally, the default response in Catalog has to be changed to application/xml. 24 + {{/info}} 28 28 29 - Intheremainder ofthismicrolearning,we will discuss both scenarios. This to get clarity on what theimpact is of both scenarios.26 +== 4. Impact in Create == 30 30 31 - ===3.1Updating fromDesign===28 +The automatic flow creation in the Create phase is adapted to the new default setting. When changing the messaging format to XML, the components of newly generated flows are created with different names and settings. The image below shows an example of an API GET operation with XML as the default messaging format. Besides the changed naming of the transformation, no JSON factory support objects are required in your flow in comparison with a JSON messaging format. 32 32 33 - After you have already added anintegration to Create youmight want to changethe error handling, the structure of the request and/or responsemessage, the parameters, etc.In all these scenarios you need to change somethingin theDesign phaseofeMagiz. The actual changing ofthese parts of theAPI Gateway solutions is specified in earliermicrolearnings. However, what to do after you havemadehosechangesisnot yetdiscussed. In this microlearning, we will discussthat processwithin eMagiz. Note that this process **only** applies when the operation already exists in Create. Ifit does not yet exist in Create eMagiz will simplyaddthe configuration to theexisting flow without changing theemainderof the all-entry.30 +[[image:Main.Images.Microlearning.WebHome@intermediate-api-management-changing-default-messaging-format--get-operation.png]] 34 34 35 -As you might know from our offering on the messaging pattern and how to update in those scenarios you can imagine that (parts of) the API Gateway flows need to be updated to reflect your changes. Depending on the exact change the effect will be seen in the 'all entry' or in one of the exit gates that is specific to an operation. The division can be made as follows: 36 - 37 -* When you change something to the configuration of the API Gateway itself (i.e security, error handling, parameters) the change will **only** impact the all-entry 38 -* When you change something to the configuration of the backend operation (i.e. endpoint, parameter, system request/response) the change will **only** impact the specific exit gate 39 -* When you change the gateway request/response message (with transformation) the change will impact **both** the all-entry and the specific exit gate 40 - 41 -In all cases, you need a version bump of the flow to which you can relate the change. For exit gates, this process is identical to when you do a version bump of any messaging flow after updating for example a CDM message or message mapping. However, when you update something on the all-entry level this becomes less simple. Because eMagiz does not only pre-configure the resources for you in Create but the complete all-entry flow you **need** a reset of the all-entry to reflect these changes. To reset a flow simply access the context menu on flow level in Create (via a right-mouse click) and press Reset flow. 42 - 43 -[[image:Main.Images.Microlearning.WebHome@intermediate-api-management-updating-your-api-gateway-operations--reset-flow-context-menu.png]] 44 - 45 -After you press this option eMagiz will present you with a confirmation pop-up to ensure that you are 100% sure that this is the correct flow that you want to reset. This because resetting a flow means returning to the original state. 46 - 47 -[[image:Main.Images.Microlearning.WebHome@intermediate-api-management-updating-your-api-gateway-operations--reset-flow-warning.png]] 48 - 49 -After you reset your all-entry eMagiz will update the following: 50 - 51 -* Swagger UI that is shown to clients via the Swagger documentation page 52 -* Parameter references 53 -* Error Handling 54 -* Many more 55 - 56 -This all depends on which changes you **made** on the Design level. 57 - 58 -=== 3.2 Updating from Create === 59 - 60 -Apart from updating your API Gateway solution in Create, you can only update parts of the API Gateway solution in Create. Here we mainly talk about changing the gateway messages. Any other changes on the 'exit gate' level have no special impact compared to changing parts of other flows. We discern two parts of updating a (gateway) message that you can execute in the Create phase: 61 - 62 -* Changing the dataType (i.e. from dateTime to date) 63 -* Adding valid enum values 64 - 65 -In both cases, eMagiz will automatically update your Swagger definition and all-entry flow by recreating the swagger definition to reflect these changes and executing a version bump of the all-entry. 66 - 67 -As is the case with all new versions in Create the changes will only be effectuated when you deploy your solution via the Deploy phase of eMagiz. 68 - 69 69 == 4. Assignment == 70 70 71 - Thinkofthreechanges you want to applytoan API Gatewaysolution andsee if you can determinewhichflow in Createneeds an update.34 +Change the default messaging format to XML. 72 72 This assignment can be completed with the help of the (Academy) project that you have created/used in the previous assignment. 73 73 74 74 == 5. Key takeaways == 75 75 76 -* Updating can happen from Design 77 -* Updating can happen from Create 78 -* Both situations have a different impact 79 -* Adding a new operation to an existing solution does not involve a reset 80 -* Updating from Create does not involve a reset 81 -* Updating from Design involves a reset 39 +* The default messaging format can be changed to XML 40 +* Updating this only affects new flows 41 +* Migrating existing operations can be done by resetting the exit flow 82 82 83 - 84 - 85 85 == 6. Suggested Additional Readings == 86 86 87 -If you are interested in this topic and want more information on it please read the help text provided by eMagiz. 45 +If you are interested in this topic and want more information on it, please read the help text provided by eMagiz. 88 88 89 89 == 7. Silent demonstration video == 90 90 91 - As this is a moretheoretical microlearning wedid not providea video for this one.49 +To be recorded. 92 92 93 93 )))((({{toc/}}))){{/container}}{{/container}} 
 
