You can make your original Software Tags like the following examples by the simple setting and programming with JavaScript on MESH SDK.
The Software Tag which accesses other Web Services with open Web API.
The Software Tag which controls functions of other WiFi controlled smart devices with open Web API.
The Software Tag which carries out complicated procedure, operation and flow control on Canvas.
The development flow of the Software Tag is as follows.
1. Making: Access the MESH SDK with your Web browser and making your original Software Tag.
2. Addition: Add your original Tag to the MESH App on your tablet.
3. Using & Debugging:Execute your original Tag and check if it works well.
In addition, we offer other functions to help development and sharing of your Tag in SDK.
What you should do mainly to make your Tag is following three points.
– Acquire the Developmemt account. And access to SDK.
– Describe outside specifications and the disposal of every function Tags on SDK.
– Preservation of the Tag which you made.
For more detail, please check the following steps.
Step 1. Access Top page of MESH SDK
Input “http://meshprj.com/sdk/” into the search window of the browser and search it. Or Click this link “SDK TOP page“.
Step 2. Access a sign in page
Step 3. Access an account registration page
Step 4. Input an account information
Step 5. Confirmation and registration of the account information
Step 6. Account application completion
You get the registration reception e-mail of to your e-mail address that input. It takes time from the registration reception to registration completion for limit the number of the accounts during closed β period.
Step 7. To activate your Account
You get a registration completion email to your e-mail address when ready for the account. An account is enabled when you access the URL on that email.
Step 8. Access to SDK
Step 1. Create a new Tag
Click “Create New Tag” of the upper page. A dialog to describe for the setting of the Tag stands up when you click it.
Step 2. Set the item concerned of outside specifications
Input the outside items about specifications such as an icon, the name of the Tag, description of the Tag, the function of the Tag, the name of the function, and more.
For more information about every item, please refer to “about a setting item“.
In addition, you can change indication / non-indication of the item by clicking “▶︎/ ▼”.
Step 3. Describes a code of every function on SDK by a JavaScript
Describe a code of JavaScript on a necessary part of “Initialize”, “Execute”, “Result” and “Receive”. A tab change is possible by clicking each label. Please refer to “About a Code” for the details about the description of the code.
What you should do to add a Tag on the MESH application of the tablet is following two points.
– Enter the sign in on application
Please watch below a detailed procedure.
Step 1. Open the menu by the list of recipes page
Step 2. Open the account management dialog from the menu
Step 3. Sign in
Step 1. Open list of Tags dialog which you developed
Add to a category “Custom” bottom on the list of the Canvas, when you sign in. And there is “+” button within a category, you tap it.
Step 2. Select the Tag to download
Step 3. Start to download
Step 4. Confirm that a Tag was added
It is following three points to do for using & debugging a Tag on the MESH application of the tablet.
– Reflection of re-edition and editing contents
Please watch below a detailed procedure.
Step 1. Use on Canvas by making drag & drop from a list
Step 1. Open log dialog
A dialog for log reading stands up, by tapping “Log” button in the Custom category of the list of Tags.
Step 2. Confirm a log
Be output the messages by error and the log command, in real time. Please refer to the log output for the details about the log command.
It is necessary to edit the Tag which you made on SDK again, when you found a bug and when you want to be changed of function. In addition, it is necessary to let editing contents update on the application when you edit it again.
Step 1. Re-edit the Tag on SDK
Re-edit a necessary point by turning on the “Edit” button and opening the dialog for the Tag editing.
Step 2. Open Tag detail dialog
Step 3. Check for Updates
Confirm whether there is the update that was edited on SDK by tapping “Check for Updates” button. When there is update, open the dialog for update.
Step 4. Update
We offer Export function and Import function as other functions to support development & sharing of the Tag other than the function mentioned above in MESH SDK.
By the Import function, you can make a Tag by reading the JSON data of the Tag output by the Export function mentioned above.
The procedure is as follows.
Step 1. Open Import dialog
Step 2. Paste JSON data
Step 3. Read data
Implement four methods {Initialize, Receive, Execute, Result} which has a function to define the movement of each function.
The summaries of four methods are as follows.
Method | Summary |
---|---|
Initialize | Use at the time of initialization of Function. Implement it when needed initialization processing for such as the setting of schedulers and the securing of internal variable. |
Receive | Use when you received a message from an input connector. There are multiple input connectors and implements it when you want to distinguish which you received it from. |
Execute | Use for Function run time. Usually, Describe procedures for this method. |
Result | Execute method is completed and Use when I send a message to next Tag from an output connector. There are multiple output connectors and Implements it when you want to choose which connector you output a message from. At default, Output them from all output connectors. |
In addition, as the common organization which is available by Software Tag development,
– Library
These are prepared.
Control whether you stop processing or continue (whether you use the next method) by the return value of each method. For example, in the case of the following source code, processing continues, and the next method is carried out.
return { resultType : "continue" }
I perform the control by a value of “resultType” of the return value. A value of “resultType” includes three following patterns.
resultType | Processing control |
---|---|
“continue” | Move to the next method. When “resultType” is not appointed explicitly, it is considered that “continue” was appointed as a default value. |
“stop” | Do not move to the next method. |
“pause” | Do not move to the next method. Use this when you wait for a specific condition being met, for example you wait for a response of async such as Web API to come back. |
When there are multiple input connectors of Function, you distinguish which connector it was input by and can change the processing. It is stored which input connector you received a message in, in the constant “index” which you can refer to in “Receive” method.
The sample source codes to refer to input connector ID are as follows.
if ( index == 0 ) { //input from the first connector log( "message from #0" ); }
When there are multiple output connectors of Function, usually a message is output after practice completion of Function by all output connectors, but you can choose connectors to output.
The setting appoints connector ID sequence as “indexes” in a return value in “Result” method.
The sample source codes to set output connector ID are as follows.
return { indexes : [0, 1], //Output from the first connector and the second one resultType : "continue" }
Task scheduler can carry out a timer in Function when you set a task scheduler. You perform the setting by appointing “taskConfig” object in the return value of the Initialize method.
In the case of follows, Function is carried out every 100 seconds.
return { resultType : "pause", taskConfig : { mode : "interval", seconds : 100 } }
The setting pattern of “taskConfig” is as follows.
Setting pattern | Example |
---|---|
Carry it out at regular intervals. |
taskConfig : { //Carry it out every ten seconds mode : "interval", seconds : 10 } |
Carry it out on the date and the time you appointed it |
taskConfig : { //It is carried out every day at 12:29. mode : "every_day", hours : 12, minutes : 29 } |
Carried out every day at the time I appointed it. |
taskConfig : { //It is carried out on 5:27pm, July 31, 2015 mode : "date", year : 2015, month : 7, day : 31, hours : 17, minutes : 27, seconds : 00 } |
The variable and the constant that you can access from a method of Function, are prepared for. The variable and the constant are the following kind.
When there are multiple input connectors of Function, it is a value to show what number connector you received it in.
The reference is as follows.
if ( index == 0 ) { //Input from the first connector log( "message from #0" ); }
It is the variable that you can share between methods in same Function. Assume the use as the state variable of Function mainly. You perform the initialization of the variable in “Initialize” method.
You appoint it as runtimeValues object in a return value as follows.
return { runtimeValues : { count : 0 } //Define the variable called "count" and Initialize it. }
Carry out the access to a variable by refer and update to runtimeValues object in each method.
But you appoint runtimeValues object as a return value of the methods by all means when you updated it.
Update is not reflected when you forget it.
runtimeValues.count++; if ( runtimeValues.count == properties.Limit ) { runtimeValues.count = 0; return { resultType : "continue", //Continue processing runtimeValues : runtimeValues //Return it as "runtimeValues" }; } else { return { resultType : "pause", //Stop processing runtimeValues : runtimeValues //Return it as "runtimeValues" } }
Refer and update to the data of message. That data is sent from the origin of connection to the connections on Canvas.
The access to a variable refer and update to messageValues object in each method.But please appoint messageValues object as a return value of the methods by all means when you update it.
Update is not reflected when you forget designation.
The example of source code on the message transmission side Tag as follows.
var msgVal = {}; msgVal.date = new Date(); //Add information (e.g. The practice date and time ) to a message return { messageValues : msgVal, //Return it as "message Values". resultType : "continue" }
The example of source code on the message reception side Tag is as follows.
var date = messageValues.date;
In SDK, we push forward the maintenance of the function that is available for the common use by Software Tag development. At present, we prepare for two following functions.
It is a sync HTTP communication facility. The main parameter that we can appoint is based on ajax method of jQuery basically as follows.
Parameter | Details |
---|---|
url | URL that you want to access |
data | Data object which wants to transmit to URL |
type | Kind of HTTP communication { GET / POST } |
contentType | Value of the content-type header to use when you send data to a server |
dataType | The data type that is given back by a server {xml / html / script / json / jsonp / text} |
timeout | Time before making time-out (millisecond) |
beforeSend | Event handler that is called back before the request transmission |
success | Event handler that is called back when communication succeeds |
error | Event handler that is called back when communication fails |
When you want to wait for a reply for, please appoint resultType:”pause” in the return value of the method. Because the Ajax is asynchronous communication.
The sample source codes of the weather check (please refer to “Weather forecast Tag” for the details) using weather forecast Web Service (OpenWeatherMap service) are as follows.
//The API which gets daily weather forecast var apiURL = "http://api.openweathermap.org/data/2.5/forecast/daily"; //The parameter of the API //Pass the value of the property var data = { "q" : properties.location, "cnt" : 1, "APPID" : '1111111111' //Please replace it with the App ID you get }; ajax ({ url : apiURL, data : data, type : "get", timeout : 5000, success : function ( contents ) { //Validate the contents if ( !contents.list || !contents.list[ 0 ] || !contents.list[ 0 ].weather || !contents.list[ 0 ].weather[ 0 ] || !contents.list[ 0 ].weather[ 0 ].id ) { log("Weather : Invalid data"); runtimeValues.outputIndex = -1; callbackSuccess( { resultType : "continue", runtimeValues : runtimeValues } ); } //Extract the ID part indicating the weather and convert it to the number value var idNum = contents.list[ 0 ].weather[ 0 ].id + 0; //Change the value of "outputIndex" depending on the weather if ( ( 200 <= idNum && idNum <= 531 ) || ( 600 <= idNum && idNum <= 622 ) ) { //Rainy runtimeValues.outputIndex = 2; } else if ( 701 <= idNum && idNum <= 781 ) { //Cloudy runtimeValues.outputIndex = 1; } else if ( 800 <= idNum && idNum <= 802 ) { //Sunny runtimeValues.outputIndex = 0; } else { runtimeValues.outputIndex = 1; } callbackSuccess( { resultType : "continue", runtimeValues : runtimeValues } ); }, error : function ( request, errorMessage ) { log("Weather : Network error"); runtimeValues.outputIndex = -1; callbackSuccess( { resultType : "continue", runtimeValues : runtimeValues } ); } }); return { resultType : "pause" };
As a debugging use at the time of the development, you can output practice log in a method. You can confirm the output log in a log dialog of the Canvas application.
The sample source code is as follow.
log("Characters that you want to output");
In the present conditions, you cannot carry out the log output in the "Initialize" method. Wait a minute, until limit cancellation.
Introduce following three kinds, as a sample of the Software Tag which you can make in SDK.
- Example of an other apparatuses cooperation : Camera Tag
- Example of an other services cooperation : Weather forecast Tag
- Example of a software logic: Random Tag
Please be careful to use it after having observed Terms of Use of each API on this occasion.
In addition, you confirm about the setting contents except the source code, by importing the JSON data (Camera Tag, Weather forecast Tag, Random Tag) of individual Tags.
Camera Tag is a Software Tag to control a supporting camera from MESH, using Sony Camera Remote API beta. In this example, Implement a Tag with "TakePicture" Function that takes a picture in simple. When you use this Tag, on network connection by iPad and camera supporting Camera Remote API beta, please use it.
In addition, you are necessary to appoint ActionListURL (e.g. http://192.168.122.1:10000/sony) as Property. Please use it after having checked ActionListURL of the supporting camera.
The source codes of "TakePicture" Function are as follows.
/*** No Initialize Codes ***/
/*** No Receive Codes ***/
//The endpoint URL of Remote API var endPointURL = properties.actionListURL + "/camera"; //The JSON data which puts the camera into "Shooting mode" var setShootModeJSONData = { method : "setShootMode", params : ["still"], id : 1, version : "1.0" }; //The JSON data which makes the camera take picture var takePictureJSONData = { method : "actTakePicture", params : [], id : 1, version : "1.0" }; //Puts the camera into "Shooting mode" ajax ({ url : endPointURL, type : "post", data : JSON.stringify( setShootModeJSONData ), contentType : "application/json", dataType : "json", timeout : 5000, success : function ( contents ) { //Makes the camera take picture ajax({ url : endPointURL, type : "post", data : JSON.stringify( takePictureJSONData ), contentType : "application/json", dataType : "json", timeout : 5000, success : function ( contents ) { callbackSuccess( { resultType : "continue" } ); }, error : function ( request, errorMessage ) { log("Camera : Network error"); callbackSuccess( { resultType : "continue" } ); } }); }, error : function ( request, errorMessage ) { log("Camera : Network error"); callbackSuccess( { resultType : "continue" } ); } }); return { resultType : "pause" };
/*** No Result Codes ***/
List below JSON data for Import.
The making of the Tag, a setting item, confirmation of the code, the editing are possible on SDK by Importing JSON data in reference to "Import function".
{"formatVersion":"1.0","tagData":{"name":"Camera","icon":"","description":"This is a sample Software Tag using \"Camera Remote API\".","functions":[{"id":"function_0","name":"TakePicture","connector":{"inputs":[{"label":""}],"outputs":[{"label":""}]},"properties":[{"name":"ActionListURL","referenceName":"actionListURL","type":"string","defaultValue":"http://192.168.0.100:10000/sony"}],"extension":{"initialize":"/*** No Initialize Codes ***/","receive":"/*** No Receive Codes ***/","execute":"//The endpoint URL of Remote API\nvar endPointURL = properties.actionListURL + \"/camera\";\n\n//The JSON data which puts the camera into \"Shooting mode\"\nvar setShootModeJSONData = {\n \tmethod : \"setShootMode\",\n\tparams : [\"still\"],\n\tid : 1,\n\tversion : \"1.0\"\n};\n\n//The JSON data which makes the camera take picture\nvar takePictureJSONData = {\n\tmethod : \"actTakePicture\",\n\tparams : [],\n\tid : 1,\n\tversion : \"1.0\"\n};\n\n//Puts the camera into \"Shooting mode\"\najax ({\n\turl : endPointURL,\n\ttype : \"post\",\n\tdata : JSON.stringify( setShootModeJSONData ),\n\tcontentType : \"application/json\",\n\tdataType : \"json\",\n\ttimeout : 5000,\n\tsuccess : function ( contents ) {\n\t\t//Makes the camera take picture\n\t\tajax({\n\t\t\turl : endPointURL,\n\t\t\ttype : \"post\",\n\t\t\tdata : JSON.stringify( takePictureJSONData ),\n\t\t\tcontentType : \"application/json\",\n\t\t\tdataType : \"json\",\n\t\t\ttimeout : 5000,\n\t\t\tsuccess : function ( contents ) {\n\t\t\t\tcallbackSuccess( {\n\t\t\t\t\tresultType : \"continue\"\n\t\t\t\t} );\n\t\t\t},\n\t\t\terror : function ( request, errorMessage ) {\n\t\t\t\tlog(\"Camera : Network error\");\n\t\t\t\tcallbackSuccess( {\n\t\t\t\t\tresultType : \"continue\"\n\t\t\t\t} );\n\t\t\t}\n\t\t});\n\t\t\n\t},\n\terror : function ( request, errorMessage ) {\n\t\tlog(\"Camera : Network error\");\n\t\tcallbackSuccess( {\n\t\t\tresultType : \"continue\"\n\t\t} );\n\t}\n});\n\nreturn {\n\tresultType : \"pause\"\n};","result":"/*** No Result Codes ***/"}}]}}
The source codes of "Check" Function are as follows. There is a line describing API Key in a part of the source code of "Execute". When you use this Tag, you make a account by OpenWeatherMap service, and you use it after having rearranged to API Key which you acquired.
//Initialize "outputIndex" return { runtimeValues : { outputIndex : 0 } };
/*** No Receive Codes ***/
//The API which gets daily weather forecast var apiURL = "http://api.openweathermap.org/data/2.5/forecast/daily"; //The parameter of the API //Pass the value of the property var data = { "q" : properties.location, "cnt" : 1, "APPID" : '1111111111' //Please replace it with the App ID you get }; ajax ({ url : apiURL, data : data, type : "get", timeout : 5000, success : function ( contents ) { //Validate the contents if ( !contents.list || !contents.list[ 0 ] || !contents.list[ 0 ].weather || !contents.list[ 0 ].weather[ 0 ] || !contents.list[ 0 ].weather[ 0 ].id ) { log("Weather : Invalid data"); runtimeValues.outputIndex = -1; callbackSuccess( { resultType : "continue", runtimeValues : runtimeValues } ); } //Extract the ID part indicating the weather and convert it to the number value var idNum = contents.list[ 0 ].weather[ 0 ].id + 0; //Change the value of "outputIndex" depending on the weather if ( ( 200 <= idNum && idNum <= 531 ) || ( 600 <= idNum && idNum <= 622 ) ) { //Rainy runtimeValues.outputIndex = 2; } else if ( 701 <= idNum && idNum <= 781 ) { //Cloudy runtimeValues.outputIndex = 1; } else if ( 800 <= idNum && idNum <= 802 ) { //Sunny runtimeValues.outputIndex = 0; } else { runtimeValues.outputIndex = 1; } callbackSuccess( { resultType : "continue", runtimeValues : runtimeValues } ); }, error : function ( request, errorMessage ) { log("Weather : Network error"); runtimeValues.outputIndex = -1; callbackSuccess( { resultType : "continue", runtimeValues : runtimeValues } ); } }); return { resultType : "pause" };
//Select an output connector depending on the "outputIndex" value updated in "Execute" return { indexes : [ runtimeValues.outputIndex ], resultType : "continue" };
List below JSON data for Import.
You are available for the making of the Tag, a setting item, confirmation, the editing of the code on SDK, by importing JSON data in reference to "Import function".
{"formatVersion":"1.0","tagData":{"name":"Weather","icon":"","description":"This is a sample Software Tag using \"Open Weather Map : Weather API\".","functions":[{"id":"function_0","name":"Check","connector":{"inputs":[{"label":""}],"outputs":[{"label":"Sunny"},{"label":"Cloudy"},{"label":"Rainy"}]},"properties":[{"name":"Location","referenceName":"location","type":"string","defaultValue":"Tokyo"}],"extension":{"initialize":"//Initialize \"outputIndex\"\nreturn {\n\truntimeValues : {\n\t\toutputIndex : 0\n\t},\n\tresultType : \"continue\"\n};","receive":"/*** No Receive Codes ***/","execute":"//The API which gets daily weather forecast\nvar apiURL = \"http://api.openweathermap.org/data/2.5/forecast/daily\";\n\n//The parameter of the API\n//Pass the value of the property\nvar data = {\n\t\"q\" : properties.location,\n\t\"cnt\" : 1,\n\t\"APPID\" : '1111111111' //Please replace it with the App ID you get\n};\n\najax ({\n\turl : apiURL,\n\tdata : data,\n\ttype : \"get\",\n\ttimeout : 5000,\n\tsuccess : function ( contents ) {\n\t\t//Validate the contents\n\t\tif ( !contents.list || !contents.list[ 0 ] || !contents.list[ 0 ].weather || !contents.list[ 0 ].weather[ 0 ] || !contents.list[ 0 ].weather[ 0 ].id ) {\n\t\t\tlog(\"Weather : Invalid data\");\n\t\t\truntimeValues.outputIndex = -1;\n\t\t\tcallbackSuccess( {\n\t\t\t\tresultType : \"continue\",\n\t\t\t\truntimeValues : runtimeValues\n\t\t\t} );\n\t\t}\n\n\t\t//Extract the ID part indicating the weather and convert it to the number value\n\t\tvar idNum = contents.list[ 0 ].weather[ 0 ].id + 0;\n\n\t\t//Change the value of \"outputIndex\" depending on the weather\n\t\tif ( ( 200 <= idNum && idNum <= 531 ) || ( 600 <= idNum && idNum <= 622 ) ) { //Rainy\n\t\t\truntimeValues.outputIndex = 2;\n\t\t} else if ( 701 <= idNum && idNum <= 781 ) { //Cloudy\n\t\t\truntimeValues.outputIndex = 1;\n\t\t} else if ( 800 <= idNum && idNum <= 802 ) { //Sunny\n\t\t\truntimeValues.outputIndex = 0;\n\t\t} else {\n\t\t\truntimeValues.outputIndex = 1;\n\t\t}\n\t\t\n\t\tcallbackSuccess( {\n\t\t\tresultType : \"continue\",\n\t\t\truntimeValues : runtimeValues\n\t\t} );\n\t},\n\terror : function ( request, errorMessage ) {\n\t\tlog(\"Weather : Network error\");\n\t\truntimeValues.outputIndex = -1;\n\t\tcallbackSuccess( {\n\t\t\tresultType : \"continue\",\n\t\t\truntimeValues : runtimeValues\n\t\t} );\n\t}\n});\n\nreturn {\n\tresultType : \"pause\"\n};","result":"//Select an output connector depending on the \"outputIndex\" value updated in \"Execute\"\nreturn {\n\tindexes : [ runtimeValues.outputIndex ],\n\tresultType : \"continue\"\n};"}}]}}
The Random Tag is the Software Tag which chooses one among plural output connectors at random and outputs a message, whenever a message is input into an input connector.
In this example, choose one from six output connectors at random and output a message.
The source code of "RandomOut" Function is as follows.
/*** No Initialize Codes ***/
/*** No Receive Codes ***/
/*** No Execute Codes ***/
//Select a output connector out of 6 connectors randomly var outputIndex = Math.floor( Math.random() * 6 ); return { indexes : [ outputIndex ], resultType : "continue" }
You are available for the making of the Tag, a setting item, confirmation, the editing of the code on SDK, by importing JSON data in reference to "Import function".
{"formatVersion":"1.0","tagData":{"name":"Random","icon":"","description":"This is a sample Software Tag.","functions":[{"id":"function_0","name":"RandomOut","connector":{"inputs":[{"label":""}],"outputs":[{"label":"out1"},{"label":"out2"},{"label":"out3"},{"label":"out4"},{"label":"out5"},{"label":"out6"}]},"properties":[],"extension":{"initialize":"/*** No Initialize Codes ***/","receive":"/*** No Receive Codes ***/","execute":"/*** No Execute Codes ***/","result":"//Select a output connector out of 6 connectors randomly\nvar outputIndex = Math.floor( Math.random() * 6 );\n\nreturn {\n\tindexes : [ outputIndex ],\n\tresultType : \"continue\"\n}\n"}}]}}