Changes for page JSON Related Transformations
                  Last modified by Erik Bakker on 2024/09/09 12:46
              
      
      From version  34.1 
    
    
              edited by Erik Bakker
        
on 2022/06/13 15:17
     on 2022/06/13 15:17
      Change comment:
              There is no comment for this version
          
         Summary
- 
          Page properties (4 modified, 0 added, 0 removed)
Details
- Page properties
- 
      - Title
-   ... ... @@ -1,1 +1,0 @@ 1 -migration-path-json-related-transformations 
- Parent
-   ... ... @@ -1,1 +1,0 @@ 1 -WebHome 
- Author
-   ... ... @@ -1,1 +1,1 @@ 1 -XWiki. ebakker1 +XWiki.marijn 
- Content
-   ... ... @@ -1,6 +1,13 @@ 1 -{{container}}{{container layoutStyle="columns"}}((( 2 -= JSON Related Transformations = 1 +{{html wiki="true"}} 2 +<div class="ez-academy"> 3 + <div class="ez-academy_body"> 3 3 5 +<div class="doc"> 6 + 7 + 8 + 9 += Migration Path * JSON Related Transformations = 10 + 4 4 Within eMagiz, you have the option to transform messages from JSON to XML, XML to JSON, and from JSON to JSON. In all these scenarios, you had to resort to using at least a custom XSLT, sometimes even in combination with standard components provided by eMagiz. With the new functionality, it has become possible to define what the input and output of a message transformation are and have the option to interpret the input against which can be validated. 5 5 6 6 Should you have any questions, please get in touch with academy@emagiz.com. ... ... @@ -17,13 +17,15 @@ 17 17 18 18 * The new approach allows you to use the transformation tooling in Design to create your mapping from JSON to XML 19 19 20 -== 3. SON Related Transformations == 21 21 28 + 29 +== 3. Migration Path * JSON Related Transformations == 30 + 22 22 === 3.1 Legacy approach === 23 23 24 24 In the Legacy situation, you need to have at least one custom XSLT to transform between JSON and XML (or JSON). A classic example of converting from JSON to XML looks as follows. 25 25 26 - [[image:Main.Images.Migrationpath.WebHome@migration-path-json-related-transformations--json-to-xml-transformation-legacy.png]]35 +<p align="center">[[image:migration-path-json-related-transformations--json-to-xml-transformation-legacy.png||]]</p> 27 27 28 28 Here you would use the standard component to transform from JSON to XML followed by a standardized XSLT available through the store. A similar setup was needed when converting XML to JSON. 29 29 ... ... @@ -31,7 +31,7 @@ 31 31 32 32 In the new situation, you can start your work in Design as you do when transforming XML to XML. The same can now be done with JSON to XML transformations. Note that the definition should have an additional root element (by default, eMagiz calls the element root) to make the validation and transformation work as it should be. After setting your system message and message mapping as you are just to, you can navigate to Create and build the flow. Then, within the flow, some minor changes are needed. See below for a representation of how this looks in Create. 33 33 34 - [[image:Main.Images.Migrationpath.WebHome@migration-path-json-related-transformations--json-to-xml-transformation-support-objects.png]]43 +<p align="center">[[image:migration-path-json-related-transformations--json-to-xml-transformation-support-objects.png||]]</p> 35 35 36 36 === 3.3 How to get to the new approach === 37 37 ... ... @@ -57,7 +57,7 @@ 57 57 o In an asynchronous offramp, no validations need to be changed because you validate the CDM, which is still based on XML. 58 58 o This logic applies the same for other asynchronous and synchronous flows. 59 59 13. If the answer is yes for the flow you are currently editing, you should add a JSON source factory support object and couple this to the validation. See below for how this looks 60 - [[image:Main.Images.Migrationpath.WebHome@migration-path-json-related-transformations--JSON-to-XML-transformation-add-support-objects.png]]69 +<p align="center">[[image:migration-path-json-related-transformations--JSON-to-XML-transformation-add-support-objects.png||]]</p> 61 61 14. Determine whether any transformation component in your flow has a JSON message. For example: 62 62 a) In an asynchronous onramp, this would be the standard transformation based on your message mapping made in Design 63 63 b) In an asynchronous offramp, no transformation will have JSON as input because here you transform message from CDM to system message and the CDM and that is still based on XML. ... ... @@ -67,16 +67,22 @@ 67 67 b) If the output is XML, you must add one support object. This support object is called the result to string transformer. See step 17 for more details 68 68 16. Couple the just created support objects to your transformation as shown below 69 69 70 - [[image:Main.Images.Migrationpath.WebHome@migration-path-json-related-transformations--json-to-xml-transformation-link-support-objects.png]]79 +<p align="center">[[image:migration-path-json-related-transformations--json-to-xml-transformation-link-support-objects.png||]]</p> 71 71 72 72 Congratulations, you have successfully migrated your current flow to transform JSON message 17. Couple the just created support object to your transformation as shown below 73 73 74 - [[image:Main.Images.Migrationpath.WebHome@migration-path-json-related-transformations--json-to-xml-transformation-link-support-objects-xml.png]]83 +<p align="center">[[image:migration-path-json-related-transformations--json-to-xml-transformation-link-support-objects-xml.png||]]</p> 75 75 76 76 Congratulations, you have successfully migrated your current flow to transform JSON message. 77 77 87 +===== Practice ===== 88 + 78 78 == 4. Key takeaways == 79 79 80 80 * The new approach allows you to use the transformation tooling in Design to create your mapping from JSON to XML 81 81 82 -)))((({{toc/}}))){{/container}}{{/container}} 93 +</div> 94 +</div> 95 +</div> 96 + 97 +{{/html}} 
 
