How to build a connector
Table of Contents
- Create Connection
- Create Datatype
- Create New Event
- Create Flow
- Creating a Status Callback
- Testing the SMS Message
- Creating a Webpage
Create Connection
Navigate to Gateway -> Connectors on the Velosimo menu.
data:image/s3,"s3://crabby-images/02b74/02b74a53d29a3040df624530045553e76da6d578" alt="connection-p1.png 1920"
Select Connections from the side menu, then click Add New at the top of the page.
data:image/s3,"s3://crabby-images/bb33a/bb33a52bfcb23004f24e580824b8c333191f5317" alt="connection-p2.png 1920"
Create a namespace. This will be the one you use for every element created for this integration. Then, enter a name and the Base URL for the API you are using.
data:image/s3,"s3://crabby-images/d9e2d/d9e2db7f55fb9422ba0a15ac61bedb5f5dfa001d" alt="connection-p3.png 694"
Authorization
To create Authorization for your connection, either click the Add a new Authorization button or navigate to Security -> Authorizations section with the navigation menu.
data:image/s3,"s3://crabby-images/b7b44/b7b44f602b60eb4e17076c0c90801f96c1dea5c7" alt="connection-p4.png 1920"
Select the authorization type used by the API you are configuring and click Next.
data:image/s3,"s3://crabby-images/8ecae/8ecaeb9357df7f2f1fdc48a6a5d3b4e71ee43430" alt="connection-p6.png 1905"
To learn more about the Authorization types, go here
Enter the namespace and create a name. Configure the credentials to your API's authorization data. Keep in mind that value entered into the Password input will be hidden after saving for security. Click Save at the bottom once completed.
data:image/s3,"s3://crabby-images/4ca02/4ca02a16b758b6a298275ea85550b51a26adccc0" alt="connection-p5.png 724"
Now back in the Connection configuration form, set Authorization to the Authorization that was just created. By setting this, your API will require the correct authorization headers to run correctly.
data:image/s3,"s3://crabby-images/0f959/0f959eb87672eeaece69e854f58d8541c93b97d4" alt="connection-p7.png 1905"
Click Save once completed.
Create Datatype
Navigate to Data -> Definitions on the Velosimo menu.
data:image/s3,"s3://crabby-images/f7347/f73474416cb8d7a64f572261558ada6bf11ebaa4" alt="datatype-p1.png 1920"
Select Data Types from the side menu.
data:image/s3,"s3://crabby-images/3f464/3f46487093d18e67a3ce17ec5c84795f290542bb" alt="datatype-p2.png 1920"
Select JSON Types from the list.
data:image/s3,"s3://crabby-images/52ce6/52ce6a97fa069109f91d6b551e8398f2e13811e8" alt="datatype-p3.png 340"
If you would like to know more about the other Data Types, go here
Click Add new at the top of the page.
data:image/s3,"s3://crabby-images/e42cf/e42cfeb76c6ae07308490ac455ddbed0466cfc64" alt="datatype-p4.png 1920"
First, enter a namespace and name for the new data type.
data:image/s3,"s3://crabby-images/b0772/b0772333021a3a8eb612fb9cbdb901e436c3902f" alt="datatype-p5.png 651"
Next, configure the JSON schema for the data type. Keep in mind that this is only to define the properties of the data type and the type of data each one should expect to receive. Click save once completed.
data:image/s3,"s3://crabby-images/4053a/4053a701a0b476731c25932411610f172e86947e" alt="datatype-p6.png 1516"
This schema defines that our new SMS Message data type will be an object with the properties: to(string), from(string), body(string)
Now that we have created a new data type, we can create a new entry. Select the Action menu on the data type and select Records.
data:image/s3,"s3://crabby-images/58f13/58f13eba308a02b4ff9cb752775192e43112eeba" alt="datatype-p9.png 1919"
Click Add New at the top of the page.
data:image/s3,"s3://crabby-images/1dfb2/1dfb2a6ea852032aeec9d575f8a26136b19e7a4a" alt="datatype-p10.png 1919"
Now enter values into the forms and click save.
data:image/s3,"s3://crabby-images/ddaf5/ddaf5d45d4eb396f0f35c67dbaf25c3347fcad05" alt="datatype-p12.png 1919"
If creation of the data entry was successful, a status message will be displayed and the entry will be in the list.
data:image/s3,"s3://crabby-images/77304/773046f4b8d86468e0b0ac40d0c6cca8174189d0" alt="datatype-p13.png 1919"
Create New Event
Navigate to Workflows -> Data Events on the Velosimo menu.
data:image/s3,"s3://crabby-images/a38bb/a38bb7b8314f765c5295e725fe2ae2a516539530" alt="datatype-p9.png 1920"
To learn more about Data Events. go here
Click Add New at the top of the page.
data:image/s3,"s3://crabby-images/b28fe/b28fefeb8ae48f15a81e9cdba47b7dadd6b6220f" alt="datatype-p10.png 1920"
Enter a namespace, name, and select the Data Type you want to link.
data:image/s3,"s3://crabby-images/42d66/42d66d33ccd264514d8eb683a2ca19ab3ee8a92f" alt="dataevent-p3.png 1905"
Click next.
data:image/s3,"s3://crabby-images/f028f/f028f052c1c4f094d5ccf102cb8008970b766ee5" alt="dataevent-p4.png 1905"
Next, define the Triggers. Think of this as the event listener that executes when the conditions are fulfilled. For this example we will be creating a Trigger that executes every time a new SMS Message data type record is created. Click Add to add trigger conditions. Click save once completed.
data:image/s3,"s3://crabby-images/e48ad/e48adaa42ea3ec7f55702c1584741da7416e6675" alt="dataevent-p5.png 1920"
By selecting the Trigger "Created At" and setting its value to "Is present", we now have an event listener that will execute every time a new record for the data type SMS Message is created.
Create Flow
Navigate to Workflows -> Flows on the Velosimo platform.
data:image/s3,"s3://crabby-images/eeee8/eeee81397c305d39b1bf2e7baff5d11a049e7800" alt="flow-p1.png 1920"
Click Add new at the top of the page.
data:image/s3,"s3://crabby-images/92155/92155d24a5c483846abff65a03cba7eea8c30db0" alt="flow-p2.png 1920"
Enter a namespace and name.
data:image/s3,"s3://crabby-images/ea10d/ea10df289eb6f229d6b6841a4ba99513c4f7f84c" alt="flow-p3.png 687"
Next, for Event select the Data Event you want to link.
data:image/s3,"s3://crabby-images/89975/899757b85fd5b3baefc6677fead4c17c9519ddda" alt="flow-p4.png 889"
Translator/Template
Translators facilitate the transfer of data inside the flow. Click Add a new Transformation to begin creating a new Translator.
data:image/s3,"s3://crabby-images/a92e1/a92e145ac309c76d2d7d55b3bb1bc5763eb16e3d" alt="flow-p5.png 820"
Select a Transformation type from the list. For this example a Ruby Template will be used. Once selected, click the button in the bottom right.
data:image/s3,"s3://crabby-images/bf7d3/bf7d347f4657c06e41fc0d6ddc2b25b3814c43e0" alt="flow-p6.png 623"
To learn more about Template transformers, go here
Then, enter a namespace and name, and select a data type for the Source Data Type. This allows you to directly reference the properties of the data type in the template code.
data:image/s3,"s3://crabby-images/83deb/83deb59ac9077e7640f08df48447d76a41b78c8d" alt="flow-p7.png 1905"
Next write the template code. If you defined the source data type, you can reference the property values from the data type using "source.____". Click "Save" once completed and then click Next to go to the next step of configuring the Flow.
data:image/s3,"s3://crabby-images/ee1ce/ee1ce6089a4aff97162db95c3e6bbe771649867f" alt="flow-p9.png 1905"
Set Source Scope to Event Source. Next, we must create a Resource for the Flow's Webhook.
data:image/s3,"s3://crabby-images/eaad9/eaad996ef8fc7eea33ef0474a7729dd6239f1b2b" alt="flow-p10.png 922"
Resource
Think of the Resource as the Flow's API. It can be configured to a local API on the Velosimo platform or it can be configured to an external API, such as the Twilio SMS Message API used in this tutorial.
Using the Velosimo menu, open Gateway -> Connectors in a new tab and keep the Flow tab open.
data:image/s3,"s3://crabby-images/048df/048df750cd8b2ee1c3a7b0219cbf27e668e58427" alt="flow-p11.png 1904"
Click Add New at the top of the page.
data:image/s3,"s3://crabby-images/ea553/ea5536e6d34ab95bc079e85a8552634ec0d54d2c" alt="flow-p12.png 1919"
Set the namespace and enter a name. Then enter the URL path for the API you are linking to the flow.
data:image/s3,"s3://crabby-images/1bc24/1bc243ddb99d3a391b6c47efebf06881b9b3f2a3" alt="flow-p13.png 930"
Click Add a New Operation, then select a REST method from the list. Once completed click save.
data:image/s3,"s3://crabby-images/885fb/885fbab95ed793311ff4ce5e2f3cbfa63202d9c0" alt="flow-p14.png 1904"
Now back to the Flow, select the Webhook menu and find the Resource you just created in the list.
data:image/s3,"s3://crabby-images/0a296/0a296bd555a997ef2e149f589533ecd2a4a82a13" alt="flow-p18.png 1904"
Parser
The next step is to create a Parser for the response data. Parsers, along with Templates as seen before, are Translators/Transformers. To learn more about Translators/Transformers, go here
Click Add a new Transformation.
data:image/s3,"s3://crabby-images/1dd6c/1dd6c12fa8f5f250a117d1323298ccd2721dd6d0" alt="flow-p14.png 957"
Click the drop-down and select a Parser transformer from the list then click the button in the bottom right to proceed.
data:image/s3,"s3://crabby-images/fd1df/fd1dfc9154b19f6a6d6b17bb3adb0b84e9a11eda" alt="flow-p15.png 1905"
To learn more about Parser transformers, go here
Enter a namespace and name, then configure how the parser works in the Code section. Click Save once completed.
data:image/s3,"s3://crabby-images/3fd47/3fd47856178c8ddd4f2b04742e39c4b5c0214c60" alt="flow-p16.png 1905"
Set the Response data type to the same data type that was linked to the Template transformer in the previous section. The final step to configuring the flow is to check the Active checkbox. This will allow the flow to be used. Once completed click save.
data:image/s3,"s3://crabby-images/32074/320747a11837e52cb422a2e6d678031cd1ebf8a2" alt="flow-p17.png 1905"
Creating a Status Callback
Another feature of the Twilio API are status callbacks. Status callbacks let you access data about your SMS message's status. In this section we will demonstrate how to build an app on Velosimo that will receive the callback data and update the SMS Message data type record's status property.
Twilio let's you define the callback URL inside the SMS message body parameters. The callback URL will be the URL you configure for the Velosimo app later on. For example, in our Postman request this is how you would send a callback URL through the message body.
data:image/s3,"s3://crabby-images/52d16/52d169f42b531ba8bf3ba1a24c61f526b1a56a62" alt="Screen Shot 2021-10-04 at 11.08.06 AM.png 860"
Creating the App
Navigate to Compute -> Applications on the Velosimo menu.
data:image/s3,"s3://crabby-images/b54ba/b54ba7349072fe35567e167ef3a6aed63f8c47ea" alt="ss1.png 1920"
Click Add New at the top of the page
data:image/s3,"s3://crabby-images/e2f85/e2f85022135f327449ddd23bfddd6744068cccb3" alt="ss2.png 1920"
Define the namespace, name, and slug.
data:image/s3,"s3://crabby-images/ef6e0/ef6e02fb829d89a277f9f77d3bc893ca9bd3726f" alt="ss3.png 1920"
Next, click Add a new Action. Since the Twilio API sends a POST request to your callback URL, set the Action method to POST. Then define the path for your action. This will be apart of the URL you provide to the callback.
Currently there is a bug on the Velosimo platform that does not allow you to add new Actions once the app has been created. Since we will be creating more Actions later on in this tutorial, create some placeholder actions aswell.
data:image/s3,"s3://crabby-images/52f38/52f3839551c3d93cfd2a35911be34a74337f5e7e" alt="ss4.png 1920"
Add a few placeholder actions and define the REST method to a GET then define the placeholder path. Since we won't be using these endpoints until they are fully configured later on, it does not matter what algorithm we define for the action since it will never be called. For now we will leave it blank until we create our algorithm.
data:image/s3,"s3://crabby-images/3727d/3727d6ddf70ab2e93691f1fb5b488aea1b3747bc" alt="ss4p2.png 1905"
The next step is to create the algorithm that actually handles the data, but first, we need to tweak our SMS Message data type and flow template to accommodate the new callback data. For now, click "Add a new Algorithm".
data:image/s3,"s3://crabby-images/b1b97/b1b97ec41326bca98def8b50376ce297a752fe2d" alt="ss8.png 1904"
Then enter a namespace and name and save it.
data:image/s3,"s3://crabby-images/c1aa3/c1aa32c91e69cce443c29fab1347b908fcc060d3" alt="ss8p2.png 1905"
Now set the newly created algorithm to the Action. Since the algorithm is a required parameter to create an action, we must also temporarily set the algorithm on the placeholder actions so we can save the app.
data:image/s3,"s3://crabby-images/3382c/3382cb07060646fb122a2d611d7747176927622b" alt="ss8p3.png 1905"
Save the app.
data:image/s3,"s3://crabby-images/dc334/dc334849d6dc3dd562480b808659170b21755364" alt="ss8p3.png 1904"
Now we must update the Authorization settings for the app. Select the action menu on the app and click Configure.
data:image/s3,"s3://crabby-images/2c65f/2c65f8d7f1fec4d17929e5fc2e71353c7cf524d8" alt="ss8p4.png 1920"
Set the authorization method from User Credentials to Application ID. If the application is set to User Credentials, it will require the Tenant Access Key and Token to be passed to the URL, which is information we do not want to be accessible for security reasons. By setting it to Application ID, the authentication will get the Tenant info for the app from passing the app slug to the URL. Click save once completed.
data:image/s3,"s3://crabby-images/eca74/eca74ee730495e85098c778da071806f22563315" alt="ss8p5.png 1905"
Before going any further, we must register the app. Registered Velosimo app's can be used externally from the platform, while unregistered apps can only be used locally on the platform. Select the Action menu on the your app and select Regist.
data:image/s3,"s3://crabby-images/529af/529afba3f459bc277c134971d7ce6157b2b10441" alt="ss9.png 1920"
Create the URL name for your app in the Slug input. Set the Oauth name to the same one and click Regist.
data:image/s3,"s3://crabby-images/ec251/ec251f2b380e59116875518e8904b396cc3f40fb" alt="ss10.png 1920"
Once the app is registered you have your callback URL. It should look something like this:
https://connect.velosimo.io/app/{{regist_name}}/{{action_path}}
Before we can create our actual algorithm, we must tweak our Flow to accommodate the new data that will be processed from the callback.
Updating the Data Type Schema
Since we are building an algorithm that will update the status of the SMS Message that is created when our flow executes, we must create a new property in our data type schema called Status. Navigate back to Data -> Definitions -> JSON Types with the Velosimo menu and update the data type.
data:image/s3,"s3://crabby-images/376fa/376fadcd1178ea840739463fa66b4bc28cd07528" alt="ss6p2.png 1920"
Select the action menu on the data type and click Edit.
data:image/s3,"s3://crabby-images/9fb4f/9fb4f9ea4c089263f208153b99f4aaedf9da59ae" alt="ss6.png 1920"
In JSON format, add the new status property and set it's type to string and click Save.
data:image/s3,"s3://crabby-images/2460e/2460e395bf581fcead2bb61fe77b797c3951039c" alt="ss7.png 1920"
Updating the Flow Template
Next we must update our flow template's body parameters to send the callback URL to Twilio's API.
Navigate to Transforms -> Templates and select your template to edit.
data:image/s3,"s3://crabby-images/abbf9/abbf9cf5b505efeb3d74ac3e3588d2ede30b8bc4" alt="ss11.png 1920"
First, add a new property to the postBody object called StatusCallback. The syntax is important because Twilio will only recognize the parameter if it is StatusCallback exactly.
postBody = {}
postBody["StatusCallback"] = "callbackURL"
Set the value of the new property to your callback URL. Remember, it's the Velosimo subdomain site that the app was created on, followed by the Regist name of your app, and the algorithm action path.
https://connect.velosimo.io/app/messagecallback/status
data:image/s3,"s3://crabby-images/09c0c/09c0c79d2529718cdb7871ff7d88151add61e723" alt="ss12.png 1920"
Since we want to update a specific record, we will need to pass its ID to the callback URL. Add a query at the end of the URL called id and set its value to #{source['id']}. This variable is how we can access the ID of the record created with the flow.
data:image/s3,"s3://crabby-images/011ba/011bac372619e3eded8324ea152592e2da9d7ef7" alt="ss14.png 955"
Now that we have updated the data type and flow template to handle our new data, we can create the algorithm which will receive the Status Callback data and use it to update our flow's SMS Message record.
Creating the Algorithm
Navigate to Compute -> Algorithms on the Velosimo menu.
data:image/s3,"s3://crabby-images/cce4b/cce4b989b1f7dc5a5c413e128e02ac85ba841d54" alt="ss15p2.png 1919"
Locate the empty algorithm created for the app earlier. Select the action menu and click Edit.
data:image/s3,"s3://crabby-images/504fc/504fc0ca10c79d6481c7277e0e8a3fec067630ef" alt="ss15.png 1920"
Click Add a new Algorithm parameter and add these three parameters: "control, params, id" in that exact order.
data:image/s3,"s3://crabby-images/8492c/8492c0cd5d19a683289f603180b6c4db84c8a0cd" alt="ss16.png 1920"
Next is to create the code that will update the record. Let's break this down line by line:
statusData = params["MessageStatus"]
recordId = params["id"]
twilio_np = Cenit.namespace('Twilio')
sms_dt = twilio_np.data_type('SMS Message')
record = sms_dt.where(id: recordId).first
record["status"] = statusData
record.save
-
Line 1 accesses the status data being passed in from the Status Callback body data.
-
Line 2 accesses the record ID being passed to the callback URL through params.
-
Line 4 retrieves the namespace we are working in and defines it to a variable.
-
Line 5 retrieves the data type with the name SMS Message associated to the Twilio namespace and defines it to a variable.
-
Line 7 uses the sms_dmt variable to find a SMS Message record with a matching ID to the one passed in from params
-
Line 8 accesses the "status" property of the record and defines its value to the statusData variable which contains the data for the status of the message.
-
Line 9 saves the changes and updates the record.
data:image/s3,"s3://crabby-images/834e9/834e958436e65cf83553b6577d00ac6d5e069f81" alt="ss17.png 839"
Once complete, click save and the algorithm will update. Since we have already set the algorithm in the app it will update there too.
data:image/s3,"s3://crabby-images/7a3ab/7a3ab17bb139f5086a2ec06c24ca8c40515fdfce" alt="ss18.png 1920"
Once the algorithm is complete, the Status Callback URL provided in the Flow template body will call this algorithm with the record's id and execute the code. Now let's test it out!
Testing the SMS Message
Since we setup our flow to execute whenever a new record of the SMS Message data type is created, the first step is to create a new record.
Navigate to Data -> Definitions -> JSON Types and select the Action menu on the data type and select Records.
data:image/s3,"s3://crabby-images/59bcf/59bcf813c2d2e0c224392604a9e61dc7d9327745" alt="ss19.png 1920"
Click Add New at the top of the page.
data:image/s3,"s3://crabby-images/5fda5/5fda590701cc5c4919926a0747e77b9bfc20e269" alt="ss20.png 1920"
Set the To parameter to the phone number registered with Twilio, and set From to the Twilio number for your account. The From phone number can be accessed in your User Console at https://www.twilio.com/
Set the body to what message you want to receive through SMS. Leave Status empty and click Save.
data:image/s3,"s3://crabby-images/89038/8903889be3dab5f9172554ae6ee2b5f0914db169" alt="ss21.png 1920"
Now a new SMS Message has been created and you should have received a text on your phone. The status will remain empty until the Status Callback is completed. To verify this, check the flow executions for your flow.
data:image/s3,"s3://crabby-images/7064f/7064fec6cc2b1086e4bc2d0e3b354864b12915df" alt="ss22.png 1920"
Click the second logo on the Nav-Bar at the top of the screen to see the flow executions.
data:image/s3,"s3://crabby-images/c6724/c6724b7a420519dd22761688acd8e460aeb4dbcd" alt="ss24.png 1920"
Here we see that our flow did execute and was successful. Now go back to your SMS Message records and refresh the page.
data:image/s3,"s3://crabby-images/c5868/c58682fa7357035d2982f4ae20c964bb3d6d8414" alt="ss25.png 1920"
Once the records refresh, we can see that the Status Callback was successful and our SMS message now has a status of "delivered". For a list of different status messages that can be received through the callback, go here
data:image/s3,"s3://crabby-images/bfe05/bfe05bab28cbcdb2a88af619d0c4485533478cda" alt="ss26.png 1920"
Creating a Webpage
In this section we will go over how to create a Webpage on the Velosimo platform that displays records from the Twilio SMS Message data type using our App.
First, we need to create an HTML template. Navigate to Transforms -> Templates on the Velosimo menu.
data:image/s3,"s3://crabby-images/84908/849089a801083a2615555f7ba78a7fc50c6e9315" alt="ss1.png 1920"
Click Add New at the top of the page.
data:image/s3,"s3://crabby-images/1f1bc/1f1bc7687e52a57547749e945ea070b6860ddf7d" alt="ss2.png 1920"
Select ERB Template from the drop-down menu and click next.
data:image/s3,"s3://crabby-images/f04bf/f04bf06bf4739c582c5b7dc49a25d2b976e8614b" alt="ss3.png 1905"
Enter a namespace and name, then set MIME type to text/html. Click next.
data:image/s3,"s3://crabby-images/db6ce/db6ce9781b18770a73998dfc27af6338aec9cdaf" alt="ss4.png 1905"
The next step is to create the template HTML code. Let's open this code in the code editor and take a closer look at what's happening.
data:image/s3,"s3://crabby-images/fa8a4/fa8a41181f289ca62fe040b9adc8bbf2f98640e9" alt="ss5.png 1905"
In our head tag, we have the dependencies for the latest version of Bootstrap and JQuery being brought in.
data:image/s3,"s3://crabby-images/fc32e/fc32ee3e9067ede6e3263553e48ab2ca1985546f" alt="Screen Shot 2021-10-08 at 12.41.51 PM.png 1576"
In the body tag we are using Bootstrap class elements to create a layout. Here we have created a main container that separates the page into three row sections. The first row and last row are being used for spacing purposes, while the second row is where we plan to display our data. We have given the div an ID to identify it later on.
Outside of the main container is a loading screen modal created with Bootstrap class elements and properties. Since we only want this to display when certain conditions are met we do not want it inside of the main container.
data:image/s3,"s3://crabby-images/11186/11186aefcc46712414b0490970dd15d22c5a7c4d" alt="Screen Shot 2021-10-08 at 12.44.06 PM.png 773"
Before we go into the script of the template, there are a few things we must do with our app to make the Webpage work. Save the template before continuing. Remember to copy and paste your code into the Velosimo template code section if you created it in a separate code editor.
Navigate back to your app in Compute -> Applications and select it to Edit.
data:image/s3,"s3://crabby-images/38c1c/38c1ce1abe8e1f9ff22bc5978c4a335a1974a3f2" alt="ss6.png 1920"
Select one of the placeholder actions and set the Method to get. Then set the path to just "/". This will be our action which handles the Webpage code.
data:image/s3,"s3://crabby-images/27d6a/27d6ae4dddcec2899525d6d1795693ea0aa86fa1" alt="ss7.png 1905"
Next, click Add a new Algorithm. We need to build an algorithm that will call and run our template code.
data:image/s3,"s3://crabby-images/74280/7428011fcfbabe05735dcea88a21dc3a337e258f" alt="ss8.png 1905"
Enter a namespace and name, then add the Algorithm parameter: controller.
data:image/s3,"s3://crabby-images/90544/90544cad61e9fb2ffe9fb52cffc7035b1cbf4d29" alt="ss9.png 1905"
In the code block we only need a few simple lines.
Line 1: Define a variable called appName and set it's value to the Regist name of your app.
Line 3-7: Use the controller parameter to call and render your template code. You must pass in the name of the template, a property called username which uses the controller parameter to get your Velosimo user info, and an appName property set to the appName variable created in Line 1. We will be accessing the appName value through the template later on.
data:image/s3,"s3://crabby-images/bdbba/bdbba6d99c4e16d1075263e22a2122c48f2a383c" alt="ss10.png 568"
Click Save once completed.
data:image/s3,"s3://crabby-images/b1336/b1336d8085da9920739658e084376c6de265a529" alt="ss11.png 1920"
Now set the action algorithm to the one that was just created.
data:image/s3,"s3://crabby-images/2be2e/2be2e5cff6a62156b8a7a64a81bf5c2d7180cbd1" alt="ss12.png 1920"
Now this will be the URL to view the Webpage:
https://connect.velosimo.io/app/messagecallback/
Now that we have a URL to our webpage, we need to populate it with data. We need to create another algorithm to retrieve all the records for our data type, then we will use the algorithm endpoint in our Webpage template to retrieve and display the data.
Select another placeholder action to edit. Keep the Method as a GET, and this time change the path to /smsmessages
data:image/s3,"s3://crabby-images/0ca24/0ca24f8ec0a55caa63097a31d4ba4626d3186a32" alt="ss13.png 1920"
Click Add a New Algorithm.
data:image/s3,"s3://crabby-images/aab61/aab61fa88a2aa653fdd5344405fbb9611ad6234b" alt="ss14.png 1920"
Enter a namespace and name, then add an algorithm parameter called: controller.
data:image/s3,"s3://crabby-images/85d4f/85d4f7120a2669db163a41852df3a11fad9af8b6" alt="ss15.png 1920"
Enter this into the code block. Let's break it down line by line.
Line 1: A bug on Velosimo requires this line to make the controller param work.
Line 2: Retrieves the data type called SMS Message associated with the Twilio namespace and defines it to a variable called smsMsgsDT
Line 3: Retrieves all entries/records of the data type using the smsMsgsDT variable, and defines it to a new variable called smsMsgs.
Line 5: Defines the smsLogs object.
Line 6: Creates a new property within smsLogs called status with a value of success.
Line 7: Creates a new property within smsLogs called messages with the value of the smsMsgs variable.
Line 9: Required controller code to change the content to JSON.
Line 10: Using the Ruby method to_json to convert the smsLogs object to JSON data. This data will be passed through the API when the algorithm endpoint is called.
data:image/s3,"s3://crabby-images/6db1e/6db1ebfb80cbd0013b0ec48f202c44c6ff5f8145" alt="ss16.png 665"
Click save once completed.
data:image/s3,"s3://crabby-images/4b761/4b7616c6a9adc1ad56a48dca7b0d42891f93a373" alt="ss17.png 1920"
Set the action algorithm to the newly created algorithm. Save the app once finished.
data:image/s3,"s3://crabby-images/94129/94129ec4204d96675de7e204554356869e457b6a" alt="ss18.png 1920"
Now that we have built an algorithm to call and render the Webpage and algorithm to retrieve the data to populate the Webpage with, we need to create two functions inside the Webpage template that retrieve and show the data.
Navigate back to Transforms -> Templates and find the Webpage template.
data:image/s3,"s3://crabby-images/83a4b/83a4bfce2377d462e16beaace3b5dae24f522d9e" alt="ss19.png 1920"
Select the action menu and click Edit. If you are editing the template code in a separate code editor open that too.
data:image/s3,"s3://crabby-images/67513/6751392e57a6a0d147880e5f0c4439ae3a5fa51f" alt="ss20.png 1920"
In the script tag, define a new function to which will retrieve the data type records.
The first line of this function uses JQuery to call the ID of the loading modal and show it.
Next, an Ajax call is being defined. The URL being passed is the endpoint to our algorithm which retrieves the record entries. You can use the <%=appName%> variable to retrieve the appName from the global variables passed into the template. If the Ajax call is successful it will execute the function showSMSRecords and pass the API data to it. If it fails, an error message will display.
data:image/s3,"s3://crabby-images/41f0a/41f0a1a653271a662ea883c63aaf3407003ff985" alt="Screen Shot 2021-10-08 at 1.36.52 PM.png 536"
Now that we can retrieve our data type entries we must build the function which displays it. The showSMSRecords function will be called when the Ajax call in the getSMSRecords is successful.
In this function we are using a combination of JQuery and Bootstrap. JQuery is being used to create a data table and Bootstrap is being used to style it. The function creates a first row in the table which displays the SMS Message property names. Then, the API data being passed into the function from getSMSRecords is looped over. For every data entry, a new row will be created with the data associated to that entry.
data:image/s3,"s3://crabby-images/a5ef0/a5ef07a052ccf97b9bd2917f25b7d9bdf96e2855" alt="Screen Shot 2021-10-08 at 1.58.39 PM.png 1920"
In the previous steps of this section, we created a div in the template html with an ID of recordLocation. Once the loop is finished the table and its rows are appended with JQuery to a div, which itself is then appended to our recordLocation div and will display the newly created data table. Since we are using JQuery to run our loading modal at the beginning of the API call, we must use JQuery to hide the loading modal once the table data has been created.
data:image/s3,"s3://crabby-images/da26a/da26a4bf1b8f1c7fc198e8d494c3f69be28eee10" alt="Screen Shot 2021-10-08 at 2.09.24 PM.png 695"
Add this line at the end of the script tag. This will execute the function which retrieves the data records as soon as the window loads.
data:image/s3,"s3://crabby-images/a56c8/a56c807f5009a9e5f55a77f1d7f2bfe71ebb0b9f" alt="Screen Shot 2021-10-08 at 2.16.51 PM.png 281"
Now save the template. Remember to copy and paste your code into the code block if you used a separate code editor.
data:image/s3,"s3://crabby-images/0470c/0470c3ecb3dbae77a1b1f9941bec14fe5f785b3c" alt="ss21.png 1920"
Using the Webpage
Now that our template is set up to retrieve the data records let's test it out.
Navigate to Data -> Definitions -> JSON Types on the Velosimo menu and find your data type.
data:image/s3,"s3://crabby-images/335ce/335ce9aa2ad52f67322a3c16fd374c4abe532e71" alt="ss22.png 1920"
Select the Action menu and click Records.
data:image/s3,"s3://crabby-images/26071/260719d59cd3f5c070a0adc580c4c395eef1fb30" alt="ss23.png 1920"
Click Add New at the top of the page.
data:image/s3,"s3://crabby-images/44156/44156267dd7819a3359d82daa228e32ce4e02879" alt="ss24.png 1920"
Create a new entry and save it.
data:image/s3,"s3://crabby-images/22a35/22a35e4d003abed022bfa1f2e3dfcbc5eb2015b3" alt="ss25.png 1920"
Now enter the URL to your app with the Webpage template action path into your browsers search bar.
data:image/s3,"s3://crabby-images/9294c/9294cd262642442f545ed11b198d948531d38b4b" alt="Screen Shot 2021-10-08 at 2.29.21 PM.png 384"
If there were no errors with the API, you will now be able to see your data type records on the Webpage.
data:image/s3,"s3://crabby-images/5b072/5b072db09c404eda23310dbbf1b7d053a01274be" alt="ss26.png 1900"
Creating a Collection
The Velosimo Platform makes the transfer of elements and data between Velosimo Tenants very simple. To do this we must create a Collection and export it from it's current tenant, then import it to the new Tenant.
Navigate to Integrations -> Collections on the Velosimo Menu.
data:image/s3,"s3://crabby-images/6d9c5/6d9c55bcb10b28e9a9c81682c73fd8c4b3374783" alt="coll-1.png 1900"
Click Add new at the top of the page.
data:image/s3,"s3://crabby-images/6a86c/6a86c7d6eb5a3923d50758698e1a50231be9e0d8" alt="coll-2.png 1900"
Enter a name and title for the collection. Optionally, you can attach an image file and create a readMe file.
data:image/s3,"s3://crabby-images/02f6e/02f6eca50915f74be50b8aa4242e161ab0d5e7c3" alt="coll-3.png 1900"
Next, under compute, add the Translators, Algorithms, and App you want to transfer to the new Tenant. To add elements, search the name in the search bar then select it and click the right arrow. Elements that are in the box to the right will be added to the Collection.
data:image/s3,"s3://crabby-images/c3c01/c3c01b1aec9a3fced6e3cc26c134b7474dcbf5a4" alt="coll-4.png 1900"
Do the same for all desired sections.
data:image/s3,"s3://crabby-images/bdc46/bdc46f9963c260ec872641ffec0801565b4bd657" alt="coll-5.png 1900"
In Workflows, add the Flow and Event.
data:image/s3,"s3://crabby-images/a31ad/a31adc262a9604bec795557af7e2f5b4a6079e80" alt="coll-6.png 1900"
In Connectors, add the Connection and Resource.
data:image/s3,"s3://crabby-images/e2a0d/e2a0dc44dcf633e48775d918a111016fc0895a7c" alt="coll-7.png 1900"
In Data, add the Data Type.
data:image/s3,"s3://crabby-images/95456/95456d954e3733e75ae026e9b4a6fbdd2292d856" alt="coll-8.png 1900"
Then, in Security add the Authorization.
data:image/s3,"s3://crabby-images/7df58/7df58c81f117b4adce37d478e5dc4c8637e55658" alt="coll-9.png 1900"
Click Save once complete.
data:image/s3,"s3://crabby-images/7f9f9/7f9f959f859a5656c51fec4466d1208282971820" alt="coll-10.png 1900"
A message will display saying the execution has processed. Click the Refresh button.
data:image/s3,"s3://crabby-images/c0630/c06308eb22ad8bc3bd0061f62dc411345be10b1b" alt="coll-11.png 1900"
Now you will see the Collection that was created. Select the Action menu and click Export.
data:image/s3,"s3://crabby-images/a71bf/a71bf6a4a0d3d262119519b546dc4542f207b04a" alt="coll-12.png 1900"
Select Basic | Share JSON from the list.
data:image/s3,"s3://crabby-images/bfbdc/bfbdc4ee14568f03a3ab9cfe2ae14dfbd705e81a" alt="coll-13.png 1885"
Click Export.
data:image/s3,"s3://crabby-images/8acb3/8acb3608a8fce158eacd44a9bfa7462d697c9e16" alt="coll-14.png 1885"
An execution will then fire, click the link for more details.
data:image/s3,"s3://crabby-images/dd5bf/dd5bf4f320ce2c74fa71778adff0e1bee70edcaa" alt="coll-15.png 1900"
At the bottom of the page under notifications, click and download the JSON attachment.
data:image/s3,"s3://crabby-images/1925c/1925c2dd5ced0f48602e38379d3dece19dde2af7" alt="coll-17.png 1900"
Next, we need to edit our JSON export. Since our Collection contains an app which has an identifier value and a secret value, we cannot import a collection with these values. Open the JSON in a code editor and search for the identifier and secret property and delete them.
data:image/s3,"s3://crabby-images/ce02c/ce02ce59fd1d632ea93ffa3c98df401213c02539" alt="Screen Shot 2021-10-13 at 9.54.29 AM.png 865"
data:image/s3,"s3://crabby-images/7a5f0/7a5f074d5c52acb6d6bb77470fc0c2de41486d29" alt="Screen Shot 2021-10-13 at 9.56.20 AM.png 639"
The next step is to switch over to the Tenant you want to import the Collection into. For this example, we will be importing to another Velosimo subdomain, dev.velosimo.io, and exporting from connect.velosimo.io. Keep in mind that Collections can be imported to other Tenants on the same subdomain as well.
To change the Tenant you are in, click the drop-down menu in the top right of the Nav-Bar. Keep in mind that not all Tenants will show in the list. If you are having trouble finding the Tenant you want, use the search bar.
data:image/s3,"s3://crabby-images/b95d1/b95d157f2ba852157d8ebadf836c9c16df3981e6" alt="coll-18.png 1900"
In the new Tenant, navigate to Integrations -> Collections on the Velosimo Menu again.
data:image/s3,"s3://crabby-images/9644d/9644d2dbd9a1261ad1736187993a55c94ff27318" alt="coll-19.png 1900"
Now Select the Action menu at the top of the screen and click Import.
data:image/s3,"s3://crabby-images/99361/993619a786055eb7bc8681d720b429ee53cfeaa8" alt="coll-20.png 1900"
Select Basic | JSON Importer for the translator. Then attach the JSON file exported from the old Tenant to the File section.
data:image/s3,"s3://crabby-images/1b2ac/1b2ac1f5a78c8bc83c373915ef27384fcfe5f424" alt="coll-21.png 1885"
Click Import.
data:image/s3,"s3://crabby-images/ca46e/ca46ee24f73f9f3a898facd658913bcddda3d8f3" alt="coll-22.png 1885"
Then an execution will fire. Click the link for more details.
data:image/s3,"s3://crabby-images/a8d93/a8d93587654143e2ae599865fc4799809b61d832" alt="coll-23.png 1920"
In the Notifications section we can see the status of the execution. If it was successful, go back to the Collections and refresh the page. The imported Collection should now appear.
data:image/s3,"s3://crabby-images/544a7/544a748cae8aeae8de13475fafcc7514ac2d2a36" alt="coll-24.png 1920"
data:image/s3,"s3://crabby-images/3a14f/3a14ff511fe40fade1280cd48912e912b7eae2b4" alt="coll-25.png 1920"
Updated over 3 years ago