-
Notifications
You must be signed in to change notification settings - Fork 5
Expand file tree
/
Copy pathDataSender.agent.nut
More file actions
138 lines (121 loc) · 5.33 KB
/
DataSender.agent.nut
File metadata and controls
138 lines (121 loc) · 5.33 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
// MIT License
//
// Copyright 2018 Electric Imp
//
// SPDX-License-Identifier: MIT
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be
// included in all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO
// EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES
// OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
// ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
// OTHER DEALINGS IN THE SOFTWARE.
#require "ThingWorx.agent.lib.nut:1.0.0"
// ThingWorx library example.
// Creates a ThingWorx Thing with two predefined Properties if it does not exist
// (thing name is specified as constructor argument) and periodically updates the properties values.
// Properties contain integer incremental value, converted to string and data measurement time
// in seconds since the epoch.
// Properties values are updated every 10 seconds.
const UPDATE_DATA_PERIOD = 10.0;
const THING_NAME = "test_thing";
const THING_PROPERTY_DATA_NAME = "data";
const THING_PROPERTY_DATA_TYPE = "STRING";
const THING_PROPERTY_MEASURE_TIME_NAME = "measure_time";
const THING_PROPERTY_MEASURE_TIME_TYPE = "INTEGER";
class DataSender {
_counter = 0;
_thingWorxClient = null;
_thingName = null;
constructor(endpoint, appKey, thingName) {
_thingWorxClient = ThingWorx(endpoint, appKey);
_thingName = thingName;
}
// Creates ThingWorx client, creates Thing if it doesn't exist and starts properties values update
function start() {
_thingWorxClient.existThing(_thingName, function (error, exist) {
if (error) {
server.error("ThingWorx existThing failed: " + error.details);
} else if (!exist) {
createThing(updatePropertiesValues);
} else {
updatePropertiesValues();
}
}.bindenv(this));
}
// Creates ThingWorx Thing
function createThing(callback) {
_thingWorxClient.createThing(_thingName, null, function (error) {
if (error) {
server.error("ThingWorx createThing failed: " + error.details);
} else {
createThingProperties(callback);
}
}.bindenv(this));
}
// Creates ThingWorx Thing Properties
function createThingProperties(callback) {
createThingProperty(THING_PROPERTY_DATA_NAME, THING_PROPERTY_DATA_TYPE, function () {
createThingProperty(THING_PROPERTY_MEASURE_TIME_NAME, THING_PROPERTY_MEASURE_TIME_TYPE, callback);
}.bindenv(this));
}
function createThingProperty(propertyName, propertyType, callback) {
_thingWorxClient.createThingProperty(_thingName, propertyName, propertyType, function (error) {
if (error) {
server.error("ThingWorx createThingProperty failed: " + error.details);
} else {
callback();
}
}.bindenv(this));
}
// Returns a data to be set for ThingWorx Properties
function getData() {
_counter++;
local result = {};
result[THING_PROPERTY_DATA_NAME] <- _counter.tostring();
result[THING_PROPERTY_MEASURE_TIME_NAME] <- time();
return result;
}
// Periodically updates Properties values
function updatePropertiesValues() {
local values = getData();
setPropertyValue(THING_PROPERTY_DATA_NAME, values[THING_PROPERTY_DATA_NAME], function() {
setPropertyValue(THING_PROPERTY_MEASURE_TIME_NAME, values[THING_PROPERTY_MEASURE_TIME_NAME], function() {
server.log("Property values updated successfully: " + http.jsonencode(values));
}.bindenv(this));
}.bindenv(this));
imp.wakeup(UPDATE_DATA_PERIOD, function () {
updatePropertiesValues();
}.bindenv(this));
}
// Updates value of the specified ThingWorx property
function setPropertyValue(propertyName, propertyValue, callback) {
_thingWorxClient.setPropertyValue(_thingName, propertyName, propertyValue, function (error) {
if (error) {
server.error("ThingWorx setPropertyValue failed: " + error.details);
} else {
callback();
}
}.bindenv(this));
}
}
// RUNTIME
// ---------------------------------------------------------------------------------
// ThingWorx constants
// ---------------------------------------------------------------------------------
const THING_WORX_ENDPOINT = "<YOUR_THING_WORX_ENDPOINT>";
const THING_WORX_APPLICATION_KEY = "<YOUR_THING_WORX_APPLICATION_KEY>";
// Start application
dataSender <- DataSender(THING_WORX_ENDPOINT, THING_WORX_APPLICATION_KEY, THING_NAME);
dataSender.start();