-
Notifications
You must be signed in to change notification settings - Fork 59
/
Copy pathiot-config-update.html
138 lines (121 loc) · 4.86 KB
/
iot-config-update.html
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
<!--
Copyright 2020 Google Inc.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
-->
<script type="text/html" data-template-name="google-cloud-iot config-update">
<!--Name-->
<div class="form-row">
<label for="node-input-name"><i class="fa fa-tag"></i> Name</label>
<input type="text" id="node-input-name">
</div>
<!--Credentials-->
<div class="form-row">
<label for="node-input-account"><i class="fa fa-user"></i> Credentials</label>
<input type="text" id="node-input-account">
</div>
<!--Key File-->
<div class="form-row">
<label for="node-input-keyFilename"><i class="fa fa-user"></i> Key File</label>
<input type="text" id="node-input-keyFilename">
</div>
<!--Project ID-->
<div class="form-row">
<label for="node-input-projectId"><i class="fa fa-cloud"></i> Project ID</label>
<input type="text" id="node-input-projectId">
</div>
<!--Region-->
<div class="form-row">
<label for="node-input-region"><i class="fa fa-globe"></i> Region</label>
<input type="text" id="node-input-region">
</div>
<!--Registry ID-->
<div class="form-row">
<label for="node-input-registryId"><i class="fa fa-book"></i> Registry ID</label>
<input type="text" id="node-input-registryId">
</div>
<!--Device ID-->
<div class="form-row">
<label for="node-input-deviceId"><i class="fa fa-microchip"></i> Device ID</label>
<input type="text" id="node-input-deviceId">
</div>
</script>
<script type="text/html" data-help-name="google-cloud-iot config-update">
<p>Update the config of an IoT device.</p>
<h3>Inputs</h3>
<dl class="message-properties">
<dt>msg.gcp.projectId
<span class="property-type">string</span>
</dt>
<dd>The project id hosting the registry of devices.</dd>
<dt>msg.gcp.region
<span class="property-type">string</span>
</dt>
<dd>The region in which the registry is defined..</dd>
<dt>msg.gcp.registryId
<span class="property-type">string</span>
</dt>
<dd>The identity of the registry.</dd>
<dt>msg.gcp.deviceId
<span class="property-type">string</span>
</dt>
<dd>The identity of the device.</dd>
</dl>
<h3>Details</h3>
<p>
The GCP IoT Core allows one to update the configuration of an IoT device The IoT - Config Update node encapsulates this function.
In order to update the config of an IoT device, we need to identify that device. The properties to identify it are the combination of:
<ul>
<li>project id - The project hosting the registry.</li>
<li>region - The region in which the registry is defined.</li>
<li>registry id - The identity of the registry.</li>
<li>device id - The identity of the device.</li>
</ul>
</p>
<p>
With those defined, we can then send a payload. To use this node, each of these must be supplied.
We can supply values statically through the node's specific configuration or dynamically in the incoming message.
For a dynamic invocation, we supply:
<ul>
<li>msg.gcp.projectId</li>
<li>msg.gcp.region</li>
<li>msg.gcp.registryId</li>
<li>msg.gcp.deviceId</li>
</ul>
</p>
<p>
For the projectId and region, if one or both of those are not found, then we test to see if Node-RED is itself running on GCP and use
the values retrieved from the compute engine metadata.
The content of the config update that is sent to the device will be retrieved from msg.payload.
</p>
</script>
<script type="text/javascript">
RED.nodes.registerType("google-cloud-iot config-update", {
category: "GCP",
defaults: {
account: { type: "google-cloud-credentials", required: false },
keyFilename: {value: "", required: false },
projectId: { required: false },
region: { required: false },
registryId: { required: false },
deviceId: { required: false },
name: { value: "", required: false }
},
inputs: 1,
outputs: 1,
icon: "iot.png",
align: "left",
color: "#3FADB5",
label: function () {
return this.name || this.topic || "iot config update";
},
paletteLabel: "iot config update"
});
</script>