Data services
Version 1.0 - March 2017
Changelog
- Fixed outdated api to retrieve service
Introduction
One of the core steps of building a mobile application is sourcing data from different external sources. In practice, there are different options
- REST endpoints (JSON over HTTP(S) )
- MQTT endpoints (Use of MQTT messaging technology)
- SOAP endpoints
- proprietary endpoints
We describe some of the options in the following chapter
REST endpoint consumption
Consuming a REST http(s) endpoint is one of the most common scenarios. In this chapter, using the REST Service consumption wizard, we will show how to
- Consume a REST HTTPS endpoint
- Automatically parse JSON and generate Swift classes from it
- Automatically generate client Swift code to call the endpoint
- Call the REST Service and handle any kind of exception
In this example, we use a sample REST service that returns a list of dummy banking accounts. You can use it too, it's a simple REST endpoint on AWS:
https://aq5dv0hhp7.execute-api.us-west-2.amazonaws.com/prod/accounts
Executing this with username=demo and password=demo returns a JSON document
{
"username": "flangel",
"password": "12345",
"timestamp": 8923487299,
"accounts": [
{
"name": "Euro Checking",
"id": 2389233812093238,
"lastTransaction": 1417453332,
"balance": 540,
"currency": "EUR"
},
{
"name": "Rent Saving",
"id": 9032443412107340,
"lastTransaction": 1420130032,
"balance": 800,
"currency": "USD"
},
{
"name": "Frank's Checking",
"id": 9032876412119872,
"lastTransaction": 1425571626,
"balance": 1200,
"currency": "USD"
}
]
}
So lets consume the same service in our mobile app:
Step 1 - Create the data service
One data service consists of many HTTP methods, i.e. different REST endpoints that you can call. We add one GET methods first:
- Select New | Service
data:image/s3,"s3://crabby-images/e163c/e163cf3bcec1ed05b5f84b75545398c11ce25e1a" alt=""
- Give it a name of banking. This is name for all banking related REST endpoints
- As Request URL, specify the first REST endpoint that you want to consume
- by convention, we combine the HTTP verb with the last part of the URL
- so here, the Swift method that is generated becomes getAccounts
data:image/s3,"s3://crabby-images/e4daa/e4daa017eec121b637c76e3fedfdae8275adde61" alt=""
- Now click on "Invoke Remote Request" to execute the request
data:image/s3,"s3://crabby-images/e298b/e298baf5ea3ee37ede6686ecd918a77d9b049f47" alt=""
- Now click on Invoke Remote Request to execute the request
The username/password is demo/demo.
data:image/s3,"s3://crabby-images/a1d9d/a1d9d06a3149994036ffed39a19ef5f4336f4ba8" alt=""
- Click on Next as we will not configure request parameter
data:image/s3,"s3://crabby-images/782e1/782e1d0b8492679a00c0748ab0771d5c4642fe17" alt=""
- Review the raw contents
data:image/s3,"s3://crabby-images/b17dc/b17dc7bfde5a917b45179f6642f5037df51cb420" alt=""
- Review the model that has been generated
- Use the type column to redefine types
- Sometimes, for instance, you want to use a String type
There is no need to do anything here, just click Finish
data:image/s3,"s3://crabby-images/77b3d/77b3d3451971d172b08f49ecde3319e57e41210b" alt=""
- Finally, press finish to create the structures
This will take 5-10 seconds. After that the Swift structures have been created that reflect this JSON structure we retrieved from the REST endpoint:
data:image/s3,"s3://crabby-images/95644/95644a8a722215edff2cf2ac958add776c117707" alt=""
Step 2 - Invoke the REST service
Now, all we need to do is to invoke the data service. Here a short snippet of code to invoke it.
import ScadeKit
class MainPageAdapter: SCDLatticePageAdapter {
// page adapter initialization
override func load(_ path: String) {
super.load(path)
// print name of all accounts
let accounts = getAccounts()
accounts.forEach {print($0.name)}
}
func getAccounts() -> [Accounts] {
// Get REST service reference
let bankingService: banking! = SCDRuntime.loadService("banking.service")
// Invoke service and get response
let result : AccountsResponse = bankingService.getAccounts()
// get accounts array
return result.accounts
}
}
When running it in the simulator, the accounts name are printed in the console
data:image/s3,"s3://crabby-images/999e1/999e1b3596c94841303c2f32a1fd482902629f8a" alt=""
Current limitations
- We don't support JSON arrays, i.e. JSON documents beginning with [ at the moment. As a workaround, parse the JSON document manually or change the JSON data structure you retrieve.
Updated almost 8 years ago