Last modified by Erik Bakker on 2024/09/09 12:46

From version 43.1
edited by Erik Bakker
on 2024/09/09 12:46
Change comment: There is no comment for this version
To version 29.1
edited by eMagiz
on 2022/06/13 09:54
Change comment: There is no comment for this version

Summary

Details

Page properties
Title
... ... @@ -1,1 +1,0 @@
1 -JSON Related Transformations
Parent
... ... @@ -1,1 +1,0 @@
1 -WebHome
Author
... ... @@ -1,1 +1,1 @@
1 -XWiki.ebakker
1 +XWiki.marijn
Content
... ... @@ -1,8 +1,20 @@
1 -{{container}}{{container layoutStyle="columns"}}(((
1 +{{html wiki="true"}}
2 +<div class="ez-academy">
3 + <div class="ez-academy_body">
4 +
5 +<div class="doc">
6 +
7 +
8 +
9 += Migration Path * JSON Related Transformations =
10 +
2 2  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.
3 3  
4 4  Should you have any questions, please get in touch with academy@emagiz.com.
5 5  
15 +* Last update: March 1st, 2022
16 +* Required reading time: 6 minutes
17 +
6 6  == 1. Prerequisites ==
7 7  
8 8  * Basic knowledge of the eMagiz platform
... ... @@ -12,13 +12,15 @@
12 12  
13 13  * The new approach allows you to use the transformation tooling in Design to create your mapping from JSON to XML
14 14  
15 -== 3. SON Related Transformations ==
16 16  
28 +
29 +== 3. Migration Path * JSON Related Transformations ==
30 +
17 17  === 3.1 Legacy approach ===
18 18  
19 19  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.
20 20  
21 -[[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>
22 22  
23 23  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.
24 24  
... ... @@ -26,7 +26,7 @@
26 26  
27 27  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.
28 28  
29 -[[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>
30 30  
31 31  === 3.3 How to get to the new approach ===
32 32  
... ... @@ -52,9 +52,7 @@
52 52   o In an asynchronous offramp, no validations need to be changed because you validate the CDM, which is still based on XML.
53 53   o This logic applies the same for other asynchronous and synchronous flows.
54 54  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
55 -
56 -[[image:Main.Images.Migrationpath.WebHome@migration-path-json-related-transformations--JSON-to-XML-transformation-add-support-objects.png]]
57 -
69 +<p align="center">[[image:migration-path-json-related-transformations--JSON-to-XML-transformation-add-support-objects.png||]]</p>
58 58  14. Determine whether any transformation component in your flow has a JSON message. For example:
59 59   a) In an asynchronous onramp, this would be the standard transformation based on your message mapping made in Design
60 60   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.
... ... @@ -64,22 +64,22 @@
64 64   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
65 65  16. Couple the just created support objects to your transformation as shown below
66 66  
67 -[[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>
68 68  
69 69  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
70 70  
71 -[[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>
72 72  
73 73  Congratulations, you have successfully migrated your current flow to transform JSON message.
74 74  
87 +===== Practice =====
88 +
75 75  == 4. Key takeaways ==
76 76  
77 77  * The new approach allows you to use the transformation tooling in Design to create your mapping from JSON to XML
78 78  
79 -== 5. Suggested Additional Readings ==
93 +</div>
94 +</div>
95 +</div>
80 80  
81 -* [[Novice Level (Menu)>>doc:Main.eMagiz Academy.Microlearnings.Novice.WebHome||target="blank"]]
82 -** [[Create Your Transformations (Navigation)>>doc:Main.eMagiz Academy.Microlearnings.Novice.Create Your Transformations.WebHome||target="blank"]]
83 -* [[JSON (Search Result)>>url:https://docs.emagiz.com/bin/view/Main/Search?sort=score&sortOrder=desc&highlight=true&facet=true&r=1&f_space_facet=0%2FMain.&f_type=DOCUMENT&f_locale=en&f_locale=&f_locale=en&text=%22json%22||target="blank"]]
84 -
85 -)))((({{toc/}}))){{/container}}{{/container}}
97 +{{/html}}
migration-path-json-related-transformations--JSON-to-XML-transformation-add-support-objects.png
Author
... ... @@ -1,0 +1,1 @@
1 +XWiki.marijn
Size
... ... @@ -1,0 +1,1 @@
1 +19.2 KB
Content
migration-path-json-related-transformations--json-to-xml-transformation-legacy.png
Author
... ... @@ -1,0 +1,1 @@
1 +XWiki.marijn
Size
... ... @@ -1,0 +1,1 @@
1 +27.9 KB
Content
migration-path-json-related-transformations--json-to-xml-transformation-link-support-objects-xml.png
Author
... ... @@ -1,0 +1,1 @@
1 +XWiki.marijn
Size
... ... @@ -1,0 +1,1 @@
1 +23.4 KB
Content
migration-path-json-related-transformations--json-to-xml-transformation-link-support-objects.png
Author
... ... @@ -1,0 +1,1 @@
1 +XWiki.marijn
Size
... ... @@ -1,0 +1,1 @@
1 +19.5 KB
Content
migration-path-json-related-transformations--json-to-xml-transformation-support-objects.png
Author
... ... @@ -1,0 +1,1 @@
1 +XWiki.marijn
Size
... ... @@ -1,0 +1,1 @@
1 +25.2 KB
Content