Import xml and JSon with MDriven
(Created page with "I have discussed the ''selfVM.JsonToObjects'' a bit in this article. Now another very similar function is introduced – the ''selfVM.XmlToObj...")
 
(Automatically adding template at the end of the page.)
 
(6 intermediate revisions by 2 users not shown)
Line 1: Line 1:
I have discussed the ''selfVM.JsonToObjects'' a bit in [[Rest Services In MDriven|this article]]. Now another very similar function is introduced – the ''selfVM.XmlToObjects''.
I have discussed the ''selfVM.JsonToObjects'' a bit in [[Rest Services In MDriven|this article]]. I now introduce another similar function – the ''selfVM.XmlToObjects''.


Suppose you have a use case where you receive xml data – and you want to turn this data objects in your model for further processing.
Suppose you have a use case where you receive XML data. You want to turn this data into objects in your model for further processing.


I will walk through this with a mock sample.
I will walk through this with a mock sample.


I have this xml:
I have this XML:
  <?xml version='1.0' standalone='no'?>
  <?xml version='1.0' standalone='no'?>
   <root>
   <root>
Line 16: Line 16:
   </person>
   </person>
   </root>  
   </root>  
I add a Text attribute to a class
I add a Text attribute to a class:


[[File:Import xml and JSon with MDrive 01.png|frameless|221x221px]]
[[File:Import xml and JSon with MDrive 01.png|frameless|221x221px]]


Now I expose this attribute in a ViewModel so that I can paste in the sample Xml and get it into play:
Now, I expose this attribute in a ViewModel so that I can paste in the sample XML and get it into play:


[[File:Import xml and JSon with MDriven 02.png|frameless|620x620px]]
[[File:Import xml and JSon with MDriven 02.png|frameless|620x620px]]


Running the model I create an object and  paste in xml in the XmlInput attribute.
Running the model, I create an object and paste it in XML in the XmlInput attribute.


[[File:Import xml and JSon with MDriven 10.png|frameless|544x544px]]
[[File:Import xml and JSon with MDriven 10.png|frameless|544x544px]]
Line 32: Line 32:
[[File:Import xml and JSon with MDriven 03.png|frameless|317x317px]]
[[File:Import xml and JSon with MDriven 03.png|frameless|317x317px]]


Notice that I have added an attribute ''RawJSon : String'' – this is totally optional but if the this exact attribute exists on the class used as a target in ''selfVM.XmlToObjects'' or ''selfVM.JsonToObjects''
Notice that I have added an attribute ''RawJSon : String'' – this is totally optional, but if this attribute exists on the class used as a target in ''selfVM.XmlToObjects'' or ''selfVM.JsonToObjects,'' then the handled JSon is assigned here (the imported Xml is first converted to JSon – then ''JsonToObjects'' handles the objects ) – this might be good for developing purposes.
 
then the handled JSon is assigned here (the imported Xml is first converted to JSon – then ''JsonToObjects'' handles the objects ) – and that might be good for developing purposes or whatever.


Now we can add an action to call the ''selfVM.XmlToObjects'' :
Now we can add an action to call the ''selfVM.XmlToObjects'' :
Line 40: Line 38:
[[File:Import xml and JSon with MDriven 04.png|frameless|601x601px]]
[[File:Import xml and JSon with MDriven 04.png|frameless|601x601px]]


The expression for the button action is:
The expression for the button action is '''vNewImportFile:=selfVM.XmlToObjects(  ImportFile , self.XmlInput)'''
 
'''vNewImportFile:=selfVM.XmlToObjects(  ImportFile , self.XmlInput)'''


This means:
This means:
* use this Xml data: '''''self.XmlInput'''''
* Use this Xml data: '''''self.XmlInput'''''
* Create an object of class '''''ImportFile''''' as root
* Create an object of class '''''ImportFile''''' as root
* Assign the resulting object of '''''ImportFile''''' class to the variable '''''vNewImportFile'''''
* Assign the resulting object of '''''ImportFile''''' class to the variable '''''vNewImportFile'''''
Running in the prototyper gives us:
Running it in the Prototyper gives us:


[[File:Import xml and JSon with MDriven 05.png|frameless|608x608px]]
[[File:Import xml and JSon with MDriven 05.png|frameless|608x608px]]
Line 76: Line 72:
[[File:Import xml and JSon with MDriven 06.png|frameless|438x438px]]
[[File:Import xml and JSon with MDriven 06.png|frameless|438x438px]]


The red “root” looks like single link, the green “person” is a multilink, the blue ones are attributes on the objects that end up in the person association.
The red “root” looks like a single link, the green “person” as a multilink, and the blue ones are attributes on the objects that end up in the person association.


This tells me that I can do this:
This tells me that I can do this:
Line 82: Line 78:
[[File:Import xml and JSon with MDriven 07.png|frameless|271x271px]]
[[File:Import xml and JSon with MDriven 07.png|frameless|271x271px]]


Note that if the logic finds things in the input that it cannot find in your classes it just silently continues. And if your classes has more attributes or associations than what you have in the JSon data – that is fine as well. Also note that your classes may have any name – it is the associations and attributes that are matched to understand data.
Note that if the logic finds things in the input that it cannot find in your classes, it just silently continues. If your classes have more attributes or associations than what you have in the JSon data – that is fine as well. Also, note that your classes may have any name – it is the associations and attributes that are matched to understand data.


We can add UI to see the imported things:
We can add UI to see the imported things:
Line 88: Line 84:
[[File:Import xml and JSon with MDriven 08.png|frameless|502x502px]]
[[File:Import xml and JSon with MDriven 08.png|frameless|502x502px]]


Running in the prototyper I can see my xml is imported as objects in my model:
Running in the Prototyper, I can see my XML is imported as objects in my model:


[[File:Import xml and JSon with MDriven 09.png|frameless|508x508px]]
[[File:Import xml and JSon with MDriven 09.png|frameless|508x508px]]


Mission accomplished.
Mission accomplished.
[[Category:View Model]]
[[Category:OCL ViewModel Operators]]
{{Edited|July|12|2024}}

Latest revision as of 15:35, 10 February 2024

I have discussed the selfVM.JsonToObjects a bit in this article. I now introduce another similar function – the selfVM.XmlToObjects.

Suppose you have a use case where you receive XML data. You want to turn this data into objects in your model for further processing.

I will walk through this with a mock sample.

I have this XML:

<?xml version='1.0' standalone='no'?>
 <root>
  <person id='1'>
    <name>Alan</name>
    <url>http://www.google.com</url>
  </person>  <person id='2'>
    <name>Louis</name>
    <url>http://www.yahoo.com</url>
  </person>
 </root> 

I add a Text attribute to a class:

Import xml and JSon with MDrive 01.png

Now, I expose this attribute in a ViewModel so that I can paste in the sample XML and get it into play:

Import xml and JSon with MDriven 02.png

Running the model, I create an object and paste it in XML in the XmlInput attribute.

Import xml and JSon with MDriven 10.png

Where should the information end up? I add a new class for this:

Import xml and JSon with MDriven 03.png

Notice that I have added an attribute RawJSon : String – this is totally optional, but if this attribute exists on the class used as a target in selfVM.XmlToObjects or selfVM.JsonToObjects, then the handled JSon is assigned here (the imported Xml is first converted to JSon – then JsonToObjects handles the objects ) – this might be good for developing purposes.

Now we can add an action to call the selfVM.XmlToObjects :

Import xml and JSon with MDriven 04.png

The expression for the button action is vNewImportFile:=selfVM.XmlToObjects(  ImportFile , self.XmlInput)

This means:

  • Use this Xml data: self.XmlInput
  • Create an object of class ImportFile as root
  • Assign the resulting object of ImportFile class to the variable vNewImportFile

Running it in the Prototyper gives us:

Import xml and JSon with MDriven 05.png

The Json looks like this:

{
  "?xml": {
    "@version": "1.0",    "@standalone": "no"
  },
  "root": {
    "person": [
      {
        "@id": "1",
        "name": "Alan",
        "url": "http://www.google.com"
      },
      {
        "@id": "2",
        "name": "Louis",
        "url": "http://www.yahoo.com"
      }
    ]
  }
 }

What we want to pay extra attention to in this JSon are things that can be used as associations and things that can be used as attributes. 

Import xml and JSon with MDriven 06.png

The red “root” looks like a single link, the green “person” as a multilink, and the blue ones are attributes on the objects that end up in the person association.

This tells me that I can do this:

Import xml and JSon with MDriven 07.png

Note that if the logic finds things in the input that it cannot find in your classes, it just silently continues. If your classes have more attributes or associations than what you have in the JSon data – that is fine as well. Also, note that your classes may have any name – it is the associations and attributes that are matched to understand data.

We can add UI to see the imported things:

Import xml and JSon with MDriven 08.png

Running in the Prototyper, I can see my XML is imported as objects in my model:

Import xml and JSon with MDriven 09.png

Mission accomplished.

This page was edited more than 11 months ago on 02/10/2024. What links here