Line 6: | Line 6: | ||
MDriven supports a couple of EAL operators to manage REST services. All operators reside on the [[selfVM]] variable – available only in the ViewModel context. | MDriven supports a couple of EAL operators to manage REST services. All operators reside on the [[selfVM]] variable – available only in the ViewModel context. | ||
''selfVM.RestGet(targeturl,user,pwd,optionalnestingwithheaders)'' | ''selfVM.RestGet(targeturl,user,pwd,optionalnestingwithheaders)'' | ||
Read: [[OCLOperators RestGet]] | |||
''selfVM.RestPost(targeturl,user,pwd,optionalnestingwithheadersAndUploadValues)'' | |||
Read: [[OCLOperators RestPost]] | |||
''selfVM.RestDownload(targeturl,user,pwd,optionalnestingwithheaders)'' | |||
Read: [[OCLOperators RestDownload]] | |||
'''Note!''' ''optionalnestingwithheaders'' is the '''name''' of the blue view model class in the example below (as a OCL String). | |||
==== Example ==== | ==== Example ==== | ||
[[File:2018-05-29 10h31 45.png|none|thumb|689x689px]] | [[File:2018-05-29 10h31 45.png|none|thumb|689x689px]] | ||
The action '''GetExporttest''' retrieves data by converting another viewmodel to xml - it stores it in the variable vText | |||
Next action invokes RestPost to send that data to an url-address, it also says that it should look at the nesting named 'Xml' - in this nesting we have the STRINGCONTENT (see also [[OCLOperators RestPost]]) | Next action invokes RestPost to send that data to an url-address, it also says that it should look at the nesting named 'Xml' - in this nesting we have the STRINGCONTENT (see also [[OCLOperators RestPost]]) which get's it's content from the vText variable - we also add the header Authorization with a bearer token in order to get access from the receiving service. | ||
=== Exposing ourselves as a REST service === | === Exposing ourselves as a REST service === |
Revision as of 12:59, 17 July 2019
REST services are services that are executed by connecting to an URL that defines operation and parameters then it returns an answer – not seldom as JSon objects.
You must set the tagged value RestAllowed on ViewModels you want to allow Rest access to.
Calling existing REST services
MDriven supports a couple of EAL operators to manage REST services. All operators reside on the selfVM variable – available only in the ViewModel context.
selfVM.RestGet(targeturl,user,pwd,optionalnestingwithheaders)
Read: OCLOperators RestGet
selfVM.RestPost(targeturl,user,pwd,optionalnestingwithheadersAndUploadValues)
Read: OCLOperators RestPost
selfVM.RestDownload(targeturl,user,pwd,optionalnestingwithheaders)
Read: OCLOperators RestDownload
Note! optionalnestingwithheaders is the name of the blue view model class in the example below (as a OCL String).
Example
The action GetExporttest retrieves data by converting another viewmodel to xml - it stores it in the variable vText
Next action invokes RestPost to send that data to an url-address, it also says that it should look at the nesting named 'Xml' - in this nesting we have the STRINGCONTENT (see also OCLOperators RestPost) which get's it's content from the vText variable - we also add the header Authorization with a bearer token in order to get access from the receiving service.
Exposing ourselves as a REST service
And when it comes to exposing ourselves to others – Turnkey has two MVC verbs, Get and Post, like this;
TurnkeyRest/Get?command=vmname&id=rootobjref TurnkeyRest/Post?command=vmname&id=rootobjref
The ViewModel name is supplied as the command parameter.
When found the tagged value RestAllowed has to be set on the viewmodel.
The id parameter is an object reference in one of several available formats. Read more here about how to create these.
When the viewmodel and it's root has been found and the accessgroups are checked to see if access is allowed.
Then additional parameters are set (these can be either URL Encoded or multi-part form encoded. See HTTP POST for details).
- For Get, the parameter name is looked up against ViewModel variables and given the sent value.
- For Post, the parameter name is looked up against ViewModel variables and attributes and given the sent value.
Finally any actions present at the root level of the ViewModel are executed.
- For Get, use the actions to look up additional information.
- For Post, the actions are usually used to process sent JSON data into objects (see below)
Post saves any changed values to the database.
Both Get and Post returns the viewmodel content as json in the HTTP response.
If there is an error – a string “error: <message>” is returned.
Processing JSON into objects
The selfVM.JSonToObjects creates objects of class Type and matches attributes and association from the json data – and it can create object trees (unclosed graphs) by following names on associations. These few additions enables us to consume Rest services that others expose.
Use Tajson or the simpler JsonToObjects. Read more here on XML or JSON support: Import xml and JSon with MDriven
selfVM.JSonToObjects( «<Type>» , JSonDataInStringFormat)
Video
To make your experience more comfortable, we set the main tags mentioned in the video to the right bar menu of this mini player. Choose the interesting subtitle on the list and immediately get to the exact theme navigation-itemplace in the video. Now you can pick any topic to be instructed without watching the whole video.