Show last authors
1 (% class="wikigeneratedid" id="HTableofContents:" %)
2 **Table of Contents:**
3
4 {{toc/}}
5
6
7
8
9
10
11 = 1. The use of this guideline =
12
13
14 This configure instruction is for Dragino NB-IoT models with -NB or -NS suffix, for example DDS75-NB. These models use the same NB-IoT Module **[[BC660K-GL>>https://www.quectel.com/product/lpwa-bc660k-gl-nb2]]** and has the same software structure. The have the same configure instruction to different IoT servers. Use can follow the instruction here to see how to configure to connect to those servers.
15
16
17 = 2. Attach Network =
18
19 == 2.1 General Configure to attach network ==
20
21
22 To attache NB-IoT sensors to NB-IoT Network, You need to:
23
24 1. Get a NB-IoT SIM card from Service Provider. (Not the same as the SIM card we use in mobile phone)
25 1. Insert the SIM card to Sensor
26 1. [[Configure APN>>http://wiki.dragino.com/xwiki/bin/view/Main/How%20to%20configure%20APN%20in%20the%20node/]] in the sensor (AT+APN=<APN>)
27
28 [[image:image-20230808205045-1.png||height="293" width="438"]]
29
30 After doing above, the NB-IoT Sensors should be able to attach to NB-IoT network .
31
32 The -NB and -NS models support (% style="color:blue" %)**LTE Cat NB2**(%%), with below frequency band: multiple frequency bands of (% style="color:blue" %)**B1/B2/B3/B4/B5/B8/B12/B13/B14/B17/B18/B19/B20/B25/B28/B66/B70/B85**(%%) . Make sure you use a the NB-IoT SIM card.
33
34 (% border="1" cellspacing="4" style="background-color:#f2f2f2; width:878px" %)
35 |(% style="background-color:#4f81bd; color:white; width:117px" %)**SIM Provider**|(% style="background-color:#4f81bd; color:white; width:151px" %)**AT+APN=**|(% style="background-color:#4f81bd; color:white; width:474px" %)**NB-IoT Coverage**|(% style="background-color:#4f81bd; color:white; width:135px" %)**Comments**
36 |(% style="width:117px" %)**[[1NCE>>https://1nce.com]]**|(% style="width:151px" %)iot.1nce.net|(% style="width:474px" %)(((
37 **[[Coverage Reference Link>>https://1nce.com/en-ap/1nce-connect]]**
38
39 Austria, Belgium, Bulgaria, Croatia, Czech Republic, Denmark, Finland, Germany, Great Britain, Greece, Hungary, Ireland, Italy, Latvia, Malta, Netherlands, Norway, Puerto Rico, Russia, Slovak , Republic, Slovenia, Spain, Sweden, Switzerland, Taiwan, USA, US Virgin Islands
40 )))|(% style="width:135px" %)
41 |(% style="width:117px" %)China Mobile|(% style="width:151px" %)No need configure|(% style="width:474px" %)China Mainland, HongKong|(% style="width:135px" %)
42 |(% style="width:117px" %)China Telecom|(% style="width:151px" %)ctnb|(% style="width:474px" %)China Mainland|(% style="width:135px" %)
43
44 == 2.2 Speed Up Network Attach time ==
45
46
47 BC660K-GL supports multi bands (% style="color:blue" %)**B1/B2/B3/B4/B5/B8/B12/B13/B14/B17/B18/B19/B20/B25/B28/B66/B70/B85. **(%%) It will search one by one and try to attach, this will take a lot of time and even cause attach fail. User can lock the band to specify band for its operator to make this faster.
48
49 (% style="color:#037691" %)**AT+QBAND?       **(%%) ~/~/ Check what is the current used frequency band
50
51 (% style="color:#037691" %)**AT+QBAND=1,4    **(%%) ~/~/ Set to use 1 frequency band. Band4
52
53 (% style="color:#037691" %)**Europe General**(%%) **AT+QBAND=2,8,20 ** ~/~/ Set to use 2 frequency bands. Band 8 and Band 20
54
55 (% style="color:#037691" %)**Verizon**(%%)** ** AT+QBAND=1,13
56 (% style="color:#037691" %)**AT&T**(%%)           AT+QBAND=3,12,4,2
57 (% style="color:#037691" %)**Telstra**(%%)        AT+QBAND=1,28
58 (% style="color:#037691" %)**Softband**(%%)     AT+QBAND=2,3,8
59
60 After connection is successful, user can use (% style="color:#037691" %)**AT+QENG=0 **(%%) to check which band is actually in used.
61
62
63 See bands used for different provider:** [[NB-IoT Deployment , Bands, Operator list>>http://wiki.dragino.com/xwiki/bin/view/Main/NB-IoT%20Deployment%20%2C%20Bands%2C%20Operator%20list/]]**
64
65
66 = 3. Configure to connect to different servers =
67
68 == 3.1 General UDP Connection ==
69
70
71 The NB-IoT Sensor can send packet to server use UDP protocol.
72
73
74 === 3.1.1 Simulate UDP Connection by PC tool ===
75
76
77 We can use PC tool to simulate UDP connection to make sure server works ok.
78
79 [[image:image-20230802112413-1.png||height="468" width="1024"]]
80
81
82 === 3.1.2 Configure NB-IoT Sensor ===
83
84 ==== 3.1.2.1 AT Commands ====
85
86
87 (% style="color:blue" %)**AT Commands:**
88
89 * (% style="color:#037691" %)**AT+PRO=2,0**  (%%) ~/~/  Set to use UDP protocol to uplink ,Payload Type select Hex payload
90
91 * (% style="color:#037691" %)**AT+SERVADDR=120.24.4.116,5601**  (%%) ~/~/  Set UDP server address and port
92
93 * (% style="color:#037691" %)**AT+CFM=1**    (%%) ~/~/  If the server does not respond, this command is unnecessary
94
95 [[image:image-20230802112413-2.png]]
96
97
98 ==== 3.1.2.2 Uplink Example ====
99
100
101 [[image:image-20230802112413-3.png]]
102
103
104 == 3.2 General MQTT Connection ==
105
106
107 The NB-IoT Sensor can send packet to server use MQTT protocol.
108
109 Below are the commands.
110
111 (% style="color:blue" %)**AT Commands:**
112
113 * (% style="color:#037691" %)**AT+PRO=3,0**   (%%) ~/~/  Set to use MQTT protocol to uplink, Payload Type select Hex payload.
114
115 * (% style="color:#037691" %)**AT+SERVADDR=120.24.4.116,1883**  (%%) ~/~/  Set MQTT server address and port
116
117 * (% style="color:#037691" %)**AT+CLIENT=CLIENT**     (%%) ~/~/  Set up the CLIENT of MQTT
118
119 * (% style="color:#037691" %)**AT+UNAME=UNAME**        (%%) ~/~/  Set the username of MQTT
120
121 * (% style="color:#037691" %)**AT+PWD=PWD**             (%%) ~/~/  Set the password of MQTT
122
123 * (% style="color:#037691" %)**AT+PUBTOPIC=NSE01_PUB**  (%%) ~/~/  Set the sending topic of MQTT
124
125 * (% style="color:#037691" %)**AT+SUBTOPIC=NSE01_SUB**  (%%) ~/~/  Set the subscription topic of MQTT
126
127 [[image:image-20230802112413-4.png]]
128
129 [[image:image-20230802112413-5.png||height="530" width="987"]]
130
131 (% style="color:red" %)**Notice: MQTT protocol has a much higher power consumption compare with UDP/CoAP protocol. Please check the power analyze document and adjust the uplink  period to a suitable interval.**
132
133
134 == 3.3 [[ThingSpeak>>url:https://thingspeak.com/]] (via MQTT) ==
135
136 === 3.3.1 Get MQTT Credentials ===
137
138
139 [[ThingSpeak>>url:https://thingspeak.com/]] connection uses MQTT Connection. So we need to get MQTT Credentials first. You need to point MQTT Devices to ThingSpeak Channel as well.
140
141 [[image:image-20230802112413-6.png||height="336" width="925"]]
142
143 [[image:image-20230802112413-7.png]]
144
145
146 === 3.3.2 Simulate with MQTT.fx ===
147
148 ==== 3.3.2.1 Establish MQTT Connection ====
149
150
151 After we got MQTT Credentials, we can first simulate with PC tool MQTT.fx tool to see if the Credentials and settings are fine.
152
153 [[image:image-20230802112413-8.png]]
154
155 * (% style="color:#037691" %)**Broker Address:**(%%) mqtt3.thingspeak.com
156
157 * (% style="color:#037691" %)**Broker Port:**(%%) 1883
158
159 * (% style="color:#037691" %)**Client ID:**(%%) <Your ThingSpeak MQTT ClientID>
160
161 * (% style="color:#037691" %)**User Name:**(%%) <Your ThingSpeak MQTT User Name>
162
163 * (% style="color:#037691" %)**Password:**(%%) <Your ThingSpeak MQTT Password>
164
165 ==== 3.3.2.2 Publish Data to ThingSpeak Channel ====
166
167
168 [[image:image-20230802112413-9.png]]
169
170 [[image:image-20230802112413-10.png]]
171
172
173 (% style="color:blue" %)**In MQTT.fx, we can publish below info:**
174
175 * (% style="color:#037691" %)**Topic:**(%%) channels/YOUR_CHANNEL_ID/publish
176
177 * (% style="color:#037691" %)**Payload:**(%%) field1=63&field2=67&status=MQTTPUBLISH
178
179 Where 63 and 67 are the value to be published to field1 & field2.
180
181
182 (% style="color:blue" %)**Result: **
183
184 [[image:image-20230802112413-11.png||height="539" width="901"]]
185
186
187 === 3.3.3 Configure NB-IoT Sensor for connection ===
188
189 ==== 3.3.3.1 AT Commands: ====
190
191
192 In the NB-IoT, we can run below commands so to publish the channels like MQTT.fx
193
194 * (% style="color:blue" %)**AT+PRO=3,1** (%%) ~/~/ Set to use ThingSpeak Server and Related Payload
195
196 * (% style="color:blue" %)**AT+CLIENT=<Your ThingSpeak MQTT ClientID>**
197
198 * (% style="color:blue" %)**AT+UNAME=<Your ThingSpeak MQTT User Name>**
199
200 * (% style="color:blue" %)**AT+PWD=<Your ThingSpeak MQTT Password>**
201
202 * (% style="color:blue" %)**AT+PUBTOPIC=<YOUR_CHANNEL_ID>**
203
204 * (% style="color:blue" %)**AT+SUBTOPIC=<YOUR_CHANNEL_ID>**
205
206 ==== 3.3.3.2 Uplink Examples ====
207
208
209 [[image:image-20230816201942-1.png]]
210
211 For SE01-NB
212
213 For DDS20-NB
214
215 For DDS45-NB
216
217 For DDS75-NB
218
219 For NMDS120-NB
220
221 For SPH01-NB
222
223 For NLM01-NB
224
225 For NMDS200-NB
226
227 For CPN01-NB
228
229 For DS03A-NB
230
231 For SN50V3-NB
232
233
234 ==== 3.3.3.3 Map fields to sensor value ====
235
236
237 When NB-IoT sensor upload to ThingSpeak. The payload already specify which fileds related to which sensor value. Use need to create fileds in Channels Settings. with name so to see the value correctly.
238
239
240 [[image:image-20230802112413-12.png||height="504" width="1011"]]
241
242 [[image:image-20230802112413-13.png||height="331" width="978"]]
243
244
245 Below is the NB-IoT Product Table show the mapping.
246
247 (% border="1" cellspacing="4" style="background-color:#f2f2f2; width:1424px" %)
248 |(% style="background-color:#4f81bd; width:143px" %) |(% style="background-color:#4f81bd; color:white; width:103px" %)Field1|(% style="background-color:#4f81bd; color:white; width:102px" %)Field2|(% style="background-color:#4f81bd; color:white; width:157px" %)Field3|(% style="background-color:#4f81bd; color:white; width:154px" %)Field4|(% style="background-color:#4f81bd; color:white; width:153px" %)Field5|(% style="background-color:#4f81bd; color:white; width:151px" %)Field6|(% style="background-color:#4f81bd; color:white; width:160px" %)Field7|(% style="background-color:#4f81bd; color:white; width:152px" %)Field8|(% style="background-color:#4f81bd; color:white; width:67px" %)Field9|(% style="background-color:#4f81bd; color:white; width:69px" %)Field10
249 |(% style="background-color:#4f81bd; color:white; width:143px" %)S31x-NB|(% style="width:103px" %)Temperature |(% style="width:102px" %)Humidity|(% style="width:157px" %)Battery|(% style="width:154px" %)RSSI|(% style="width:153px" %) |(% style="width:151px" %) |(% style="width:160px" %) |(% style="width:152px" %) |(% style="width:67px" %) |(% style="width:69px" %)
250 |(% style="background-color:#4f81bd; color:white; width:143px" %)SE01-NB|(% style="width:103px" %)Temperature |(% style="width:102px" %)Humidity|(% style="width:157px" %)conduct|(% style="width:154px" %)dielectric_constant|(% style="width:153px" %)Battery|(% style="width:151px" %)RSSI|(% style="width:160px" %) |(% style="width:152px" %) |(% style="width:67px" %) |(% style="width:69px" %)
251 |(% style="background-color:#4f81bd; color:white; width:143px" %)DDS20-NB|(% style="width:103px" %)distance|(% style="width:102px" %)Battery|(% style="width:157px" %)RSSI|(% style="width:154px" %) |(% style="width:153px" %) |(% style="width:151px" %) |(% style="width:160px" %) |(% style="width:152px" %) |(% style="width:67px" %) |(% style="width:69px" %)
252 |(% style="background-color:#4f81bd; color:white; width:143px" %)DDS45-NB|(% style="width:103px" %)distance|(% style="width:102px" %)Battery|(% style="width:157px" %)RSSI|(% style="width:154px" %) |(% style="width:153px" %) |(% style="width:151px" %) |(% style="width:160px" %) |(% style="width:152px" %) |(% style="width:67px" %) |(% style="width:69px" %)
253 |(% style="background-color:#4f81bd; color:white; width:143px" %)DDS75-NB|(% style="width:103px" %)distance|(% style="width:102px" %)Battery|(% style="width:157px" %)RSSI|(% style="width:154px" %) |(% style="width:153px" %) |(% style="width:151px" %) |(% style="width:160px" %) |(% style="width:152px" %) |(% style="width:67px" %) |(% style="width:69px" %)
254 |(% style="background-color:#4f81bd; color:white; width:143px" %)NMDS120-NB|(% style="width:103px" %)distance|(% style="width:102px" %)Battery|(% style="width:157px" %)RSSI|(% style="width:154px" %) |(% style="width:153px" %) |(% style="width:151px" %) |(% style="width:160px" %) |(% style="width:152px" %) |(% style="width:67px" %) |(% style="width:69px" %)
255 |(% rowspan="1" style="background-color:#4f81bd; color:white; width:143px" %)SPH01-NB|(% style="width:103px" %)ph|(% style="width:102px" %)Temperature|(% style="width:157px" %)Battery|(% style="width:154px" %)RSSI|(% style="width:153px" %) |(% style="width:151px" %) |(% style="width:160px" %) |(% style="width:152px" %) |(% style="width:67px" %) |(% colspan="1" rowspan="1" style="width:69px" %)
256 |(% style="background-color:#4f81bd; color:white; width:143px" %)NLM01-NB|(% style="width:103px" %)Humidity|(% style="width:102px" %)Temperature|(% style="width:157px" %)Battery|(% style="width:154px" %)RSSI|(% style="width:153px" %) |(% style="width:151px" %) |(% style="width:160px" %) |(% style="width:152px" %) |(% style="width:67px" %) |(% style="width:69px" %)
257 |(% style="background-color:#4f81bd; color:white; width:143px" %)NMDS200-NB|(% style="width:103px" %)distance1|(% style="width:102px" %)distance2|(% style="width:157px" %)Battery|(% style="width:154px" %)RSSI|(% style="width:153px" %) |(% style="width:151px" %) |(% style="width:160px" %) |(% style="width:152px" %) |(% style="width:67px" %) |(% style="width:69px" %)
258 |(% style="background-color:#4f81bd; color:white; width:143px" %)CPN01-NB|(% style="width:103px" %)alarm|(% style="width:102px" %)count|(% style="width:157px" %)door open duration|(% style="width:154px" %)calc flag|(% style="width:153px" %)Battery|(% style="width:151px" %)RSSI|(% style="width:160px" %) |(% style="width:152px" %) |(% style="width:67px" %) |(% style="width:69px" %)
259 |(% colspan="1" rowspan="1" style="background-color:#4f81bd; color:white; width:143px" %)DS03A-NB|(% colspan="1" rowspan="1" style="width:103px" %)level|(% colspan="1" rowspan="1" style="width:102px" %)alarm|(% colspan="1" rowspan="1" style="width:157px" %)pb14door open num|(% colspan="1" rowspan="1" style="width:154px" %)pb14 last open time|(% colspan="1" rowspan="1" style="width:153px" %)pb15 level status|(% colspan="1" rowspan="1" style="width:151px" %)pb15 alarm status|(% colspan="1" rowspan="1" style="width:160px" %)pb15 door open num|(% colspan="1" rowspan="1" style="width:152px" %)pb15 last open time|(% colspan="1" rowspan="1" style="width:67px" %)Battery|(% colspan="1" rowspan="1" style="width:69px" %)RSSI
260 |(% colspan="1" rowspan="1" style="background-color:#4f81bd; color:white; width:143px" %)SN50V3-NB mod1|(% colspan="1" rowspan="1" style="width:103px" %)mod|(% colspan="1" rowspan="1" style="width:102px" %)Battery|(% colspan="1" rowspan="1" style="width:157px" %)RSSI|(% colspan="1" rowspan="1" style="width:154px" %)DS18B20 Temp|(% colspan="1" rowspan="1" style="width:153px" %)exit_state/input PA4|(% colspan="1" rowspan="1" style="width:151px" %)adc0|(% colspan="1" rowspan="1" style="width:160px" %)Temperature |(% colspan="1" rowspan="1" style="width:152px" %)Humidity|(% colspan="1" rowspan="1" style="width:67px" %) |(% colspan="1" rowspan="1" style="width:69px" %)
261 |(% colspan="1" style="background-color:#4f81bd; color:white; width:143px" %)SN50V3-NB mod2|(% colspan="1" style="width:103px" %)mod|(% colspan="1" style="width:102px" %)Battery|(% colspan="1" style="width:157px" %)RSSI|(% colspan="1" style="width:154px" %)DS18B20 Temp|(% colspan="1" style="width:153px" %)exit_state/input PA4|(% colspan="1" style="width:151px" %)adc0|(% colspan="1" style="width:160px" %)distance|(% colspan="1" style="width:152px" %) |(% colspan="1" style="width:67px" %) |(% colspan="1" style="width:69px" %)
262 |(% colspan="1" style="background-color:#4f81bd; color:white; width:143px" %)SN50V3-NB mod3|(% colspan="1" style="width:103px" %)mod|(% colspan="1" style="width:102px" %)Battery|(% colspan="1" style="width:157px" %)RSSI|(% colspan="1" style="width:154px" %)adc0|(% colspan="1" style="width:153px" %)exit_state/input PA4|(% colspan="1" style="width:151px" %)adc1|(% colspan="1" style="width:160px" %)Temperature|(% colspan="1" style="width:152px" %)Humidity|(% colspan="1" style="width:67px" %)adc4|(% colspan="1" style="width:69px" %)
263 |(% colspan="1" style="background-color:#4f81bd; color:white; width:143px" %)SN50V3-NB mod4|(% colspan="1" style="width:103px" %)mod|(% colspan="1" style="width:102px" %)Battery|(% colspan="1" style="width:157px" %)RSSI|(% colspan="1" style="width:154px" %)DS18B20 Temp|(% colspan="1" style="width:153px" %)adc0|(% colspan="1" style="width:151px" %)exit_state/input PA4|(% colspan="1" style="width:160px" %)DS18B20 Temp2|(% colspan="1" style="width:152px" %)DS18B20 Temp3|(% colspan="1" style="width:67px" %) |(% colspan="1" style="width:69px" %)
264 |(% colspan="1" style="background-color:#4f81bd; color:white; width:143px" %)SN50V3-NB mod5|(% colspan="1" style="width:103px" %)mod|(% colspan="1" style="width:102px" %)Battery|(% colspan="1" style="width:157px" %)RSSI|(% colspan="1" style="width:154px" %)DS18B20 Temp|(% colspan="1" style="width:153px" %)adc0|(% colspan="1" style="width:151px" %)exit_state/input PA4|(% colspan="1" style="width:160px" %)Weight|(% colspan="1" style="width:152px" %) |(% colspan="1" style="width:67px" %) |(% colspan="1" style="width:69px" %)
265 |(% colspan="1" style="background-color:#4f81bd; color:white; width:143px" %)SN50V3-NB mod6|(% colspan="1" style="width:103px" %)mod|(% colspan="1" style="width:102px" %)Battery|(% colspan="1" style="width:157px" %)RSSI|(% colspan="1" style="width:154px" %)count|(% colspan="1" style="width:153px" %) |(% colspan="1" style="width:151px" %) |(% colspan="1" style="width:160px" %) |(% colspan="1" style="width:152px" %) |(% colspan="1" style="width:67px" %) |(% colspan="1" style="width:69px" %)
266
267 == 3.4 [[Datacake>>https://datacake.co/]] ==
268
269
270 (% class="wikigeneratedid" %)
271 Dragino NB-IoT sensors has its template in **[[Datacake>>https://datacake.co/]]** Platform. There are two version for NB Sensor,
272
273
274 (% class="wikigeneratedid" %)
275 As example for S31B-NB. there are two versions: **S31B-NB-1D and S31B-NB-GE.**
276
277 * (% style="color:blue" %)**S31B-NB-1D**(%%): This version have pre-configure DataCake connection. User just need to Power on this device, it will auto connect send data to DataCake Server.
278
279 * (% style="color:blue" %)**S31B-NB-GE**(%%): This verson doesn't have pre-configure Datacake connection. User need to enter the AT Commands to connect to Datacake. See below for instruction.
280
281 === 3.4.1 For device Already has template ===
282
283 ==== 3.4.1.1 Create Device ====
284
285 (% style="color:blue" %)**Add Device**(%%) in DataCake.
286
287 [[image:image-20230808162301-1.png||height="453" width="952"]]
288
289
290 [[image:image-20230808162342-2.png||height="541" width="952"]]
291
292
293 (% style="color:blue" %)**Choose the correct model**(%%) from template.
294
295 [[image:image-20230808162421-3.png]]
296
297
298 (% style="color:blue" %)**Fill Device ID**(%%). The device ID needs to be filled in with IMEI, and a prefix of(% style="color:blue" %)** 'f' **(%%)needs to be added.
299
300 [[image:image-20230808163612-7.png||height="549" width="952"]]
301
302 [[image:image-20230808163035-5.png]]
303
304 [[image:image-20230808163049-6.png||height="544" width="926"]]
305
306
307 === 3.4.2 For Device already registered in DataCake before shipped ===
308
309 ==== 3.4.2.1 Scan QR Code to get the device info ====
310
311 Users can use their phones or computers to scan QR codes to obtain device data information.
312
313 [[image:image-20230808170051-8.png||height="255" width="259"]]
314
315 [[image:image-20230808170548-9.png]]
316
317
318 ==== 3.4.2.2 Claim Device to User Account ====
319
320 By Default, the device is registered in Dragino's DataCake Account. User can Claim it to his account.
321
322
323
324 === 3.4.3 Manual Add Decoder in DataCake ( don't use the template in DataCake) ===
325
326 **Step1:Add a device**
327
328 [[image:image-20240129170024-1.png||height="330" width="900"]]
329
330 **Step2:Choose your device type,please select dragino NB-IOT device**
331
332 [[image:image-20240129170216-2.png||height="534" width="643"]]
333
334 **Step3:Choose to create a new device**
335
336 [[image:image-20240129170539-3.png||height="459" width="646"]]
337
338 **Step4:Fill in the device ID of your NB device**
339
340 [[image:image-20240202111546-1.png||height="378" width="651"]]
341
342 **Step5:Please select your device plan according to your needs and complete the creation of the device**
343
344 [[image:image-20240129171236-6.png||height="450" width="648"]]
345
346 **Step6:Please add the decoder at the payload decoder of the device configuration.**
347
348 **Decoder location:**[[dragino-end-node-decoder/Datacake-Dragino_NB at main · dragino/dragino-end-node-decoder (github.com)>>url:https://github.com/dragino/dragino-end-node-decoder/tree/main/Datacake-Dragino_NB]]
349
350 [[image:image-20240129172056-7.png||height="457" width="816"]]
351
352 [[image:image-20240129173116-9.png||height="499" width="814"]]
353
354 **Step6:Add the output of the decoder as a field**
355
356 [[image:image-20240129173541-10.png||height="592" width="968"]]
357
358 **Step7:Customize the dashboard and use fields as parameters of the dashboard**
359
360 [[image:image-20240129174518-11.png||height="147" width="1042"]]
361
362 [[image:image-20240129174657-12.png||height="538" width="916"]]
363
364 [[image:image-20240129174840-13.png||height="536" width="750"]]
365
366
367 === 3.4.4 For device have not configured to connect to DataCake ===
368
369 (% class="lead" %)
370 Use AT command for connecting to DataCake
371
372 (% style="color:blue" %)**AT+PRO=2,0**
373
374 (% style="color:blue" %)**AT+SERVADDR=67.207.76.90,4445**
375
376
377 == 3.5 Node-Red (via MQTT) ==
378
379 === 3.5.1 Configure [[Node-Red>>http://wiki.dragino.com/xwiki/bin/view/Main/Node-RED/]] ===
380
381
382 Take S31-NB UDP protocol as an example.
383
384 Dragino provides input flow examples for the sensors.
385
386 User can download the required JSON file through Dragino Node-RED input flow template.
387
388 Download sample JSON file link: [[https:~~/~~/www.dropbox.com/sh/mduw85jcuwsua22/AAAvwPhg9z6dLjJhmZjqBf_ma?dl=0>>url:https://www.dropbox.com/sh/mduw85jcuwsua22/AAAvwPhg9z6dLjJhmZjqBf_ma?dl=0]]
389
390 We can directly import the template.
391
392 The templates for S31-NB and NB95S31B are the same.
393
394
395 [[image:image-20230809173127-4.png]]
396
397
398 Please select the NB95S31B template.
399
400 [[image:image-20230809173310-5.png||height="558" width="926"]]
401
402 [[image:image-20230809173438-6.png]]
403
404 [[image:image-20230809173800-7.png]]
405
406
407 Successfully imported template.
408
409 [[image:image-20230809173835-8.png||height="515" width="860"]]
410
411
412 Users can set UDP port.
413
414 [[image:image-20230809174053-9.png]]
415
416
417 === 3.5.2 Simulate Connection ===
418
419
420 We have completed the configuration of UDP. We can try sending packets to node red.
421
422 [[image:image-20230810083934-1.png]]
423
424 [[image:image-20230810084048-2.png||height="535" width="1052"]]
425
426
427 === 3.5.3 Configure NB-IoT Sensors ===
428
429
430 * (% style="color:#037691" %)**AT+PRO=3,0 or 3,5 ** (%%) **~/~/ hex format or json format**
431 * (% style="color:#037691" %)**AT+SUBTOPIC=<device name>or User Defined**
432 * (% style="color:#037691" %)**AT+PUBTOPIC=<device name>or User Defined**
433 * (% style="color:#037691" %)**AT+CLIENT=<device name> or User Defined**
434 * (% style="color:#037691" %)**AT+UNAME=<device name> or User Defined**
435 * (% style="color:#037691" %)**AT+PWD=“Your device token”**
436
437 == 3.6 ThingsBoard.Cloud (via MQTT) ==
438
439 === 3.6.1 Configure ThingsBoard ===
440
441 ==== 3.6.1.1 Create Device ====
442
443
444 Create a New Device in [[ThingsBoard>>url:https://thingsboard.cloud/]]. Record Device Name which is used for MQTT connection.
445
446 [[image:image-20230802112413-32.png||height="583" width="1066"]]
447
448
449 ==== 3.6.1.2 Create Uplink & Downlink Converter ====
450
451
452 (% style="color:blue" %)**Uplink Converter**
453
454 The purpose of the decoder function is to parse the incoming data and metadata to a format that ThingsBoard can consume. deviceName and deviceType are required, while attributes and telemetry are optional. Attributes and telemetry are flat key-value objects. Nested objects are not supported.
455
456 To create an uplink converter go to the (% style="color:blue" %)**Integrations center**(%%) -> (% style="color:blue" %)**Data converters**(%%) page and click (% style="color:blue" %)**“plus”** (%%)button. Name it (% style="color:blue" %)**“MQTT Uplink Converter”**(%%) and select type (% style="color:blue" %)"**Uplink"**(%%). Use debug mode for now.
457
458 [[image:image-20230802112413-33.png||height="597" width="1061"]]
459
460
461 (% style="color:blue" %)**Downlink Converter**
462
463 The Downlink converter transforming outgoing RPC message and then the Integration sends it to external MQTT broke
464
465 [[image:image-20230802112413-34.png||height="598" width="1063"]]
466
467 (% style="color:red" %)**Note: Our device payload is already human readable data. Therefore, users do not need to write decoders. Simply create by default.**
468
469
470 ==== 3.6.1.3 MQTT Integration Setup ====
471
472
473 Go to the (% style="color:blue" %)**Integrations center**(%%) **->** (% style="color:blue" %)**Integrations page**(%%) and click **“(% style="color:blue" %)plus(%%)”** icon to add a new integration. Name it (% style="color:blue" %)**“MQTT Integration”**(%%), select type (% style="color:blue" %)**MQTT**;
474
475 [[image:image-20230802112413-35.png||height="597" width="1062"]]
476
477
478 * The next steps is to add the recently created uplink and downlink converters;
479
480 [[image:image-20230802112413-36.png||height="598" width="1062"]]
481
482 [[image:image-20230802112413-37.png||height="598" width="1064"]]
483
484
485 (% style="color:blue" %)**Add a topic filter:**
486
487 Consistent with the theme of the node setting.
488
489 You can also select an MQTT QoS level. We use MQTT QoS level 0 (At most once) by default;
490
491 [[image:image-20230802112413-38.png||height="598" width="1064"]]
492
493
494 === 3.6.2 Simulate with MQTT.fx ===
495
496
497 [[image:image-20230802112413-39.png]]
498
499 [[image:image-20230802112413-40.png||height="525" width="980"]]
500
501
502 === 3.6.3 Configure NB-IoT Sensor ===
503
504
505 (% style="color:blue" %)**AT Commands**
506
507 * (% style="color:#037691" %)**AT+PRO=3,3  **(%%)** **~/~/ Use MQTT to connect to ThingsBoard. Payload Type set to 3.
508
509 * (% style="color:#037691" %)**AT+SUBTOPIC=<device name>**
510
511 * (% style="color:#037691" %)**AT+PUBTOPIC=<device name>**
512
513 * (% style="color:#037691" %)**AT+CLIENT=<device name> or User Defined**
514
515 * (% style="color:#037691" %)**AT+UNAME=<device name> or User Defined**
516
517 * (% style="color:#037691" %)**AT+PWD=<device name> or User Defined**
518
519 Test Uplink by click the button for 1 second
520
521 [[image:image-20230802112413-41.png||height="496" width="828"]]
522
523 [[image:image-20230802112413-42.png]]
524
525 [[image:image-20230802112413-43.png||height="407" width="825"]]
526
527
528 == 3.7 [[Tago.io>>url:https://admin.tago.io/]] (via MQTT) ==
529
530 === 3.7.1 Create device & Get Credentials ===
531
532
533 We use MQTT Connection to send data to [[Tago.io>>url:https://admin.tago.io/]]. We need to Create Device and Get MQTT Credentials first.
534
535 [[image:image-20230802112413-44.png]]
536
537 [[image:image-20230802112413-45.png]]
538
539
540 Go to the Device section and create a device. Then, go to the section tokens and copy your device-token.
541
542 [[image:image-20230802112413-46.png]]
543
544
545 The device needs to enable the TLS mode and set the (% style="color:blue" %)**AT+TLSMOD=1,0**(%%) command.
546
547 (% style="color:blue" %)**On the Connection Profile window, set the following information:**
548
549 * (% style="color:#037691" %)**Profile Name: “Any name”**
550
551 * (% style="color:#037691" %)**Broker Address: mqtt.tago.io**
552
553 * (% style="color:#037691" %)**Broker Port: 8883**
554
555 * (% style="color:#037691" %)**Client ID: “Any value”**
556
557 (% style="color:blue" %)**On the section User credentials, set the following information:**
558
559 * (% style="color:#037691" %)**User Name: “Any value”** (%%) **~/~/ Tago validates your user by the token only**
560
561 * (% style="color:#037691" %)**Password: “Your device token”**
562
563 * (% style="color:#037691" %)**PUBTOPIC: “Any value”**
564
565 * (% style="color:#037691" %)**SUBTOPIC: “Any value”**
566
567 (% style="color:blue" %)**AT command:**
568
569 * (% style="color:#037691" %)**AT+PRO=3,0 or 3,5 ** (%%) **~/~/ hex format or json format**
570
571 * (% style="color:#037691" %)**AT+SUBTOPIC=<device name>or User Defined**
572
573 * (% style="color:#037691" %)**AT+PUBTOPIC=<device name>or User Defined**
574
575 * (% style="color:#037691" %)**AT+CLIENT=<device name> or User Defined**
576
577 * (% style="color:#037691" %)**AT+UNAME=<device name> or User Defined**
578
579 * (% style="color:#037691" %)**AT+PWD=“Your device token”**
580
581 === 3.7.2 Simulate with MQTT.fx ===
582
583
584 [[image:image-20230802112413-52.png]]
585
586
587 [[image:image-20230808105300-2.png||height="553" width="1026"]]
588
589
590 Users can run the (% style="color:blue" %)**AT+PRO=3,5**(%%) command, and the payload will be converted to **JSON format**.
591
592 [[image:image-20230808105217-1.png||height="556" width="1031"]]
593
594 [[image:image-20230808105329-3.png]]
595
596
597 === 3.7.3 tago data ===
598
599
600 [[image:image-20230802112413-50.png||height="242" width="1037"]]
601
602 [[image:image-20230802112413-51.png||height="184" width="696"]]
603
604
605 == 3.8 TCP Connection ==
606
607
608 (% style="color:blue" %)**AT command:**
609
610 * (% style="color:#037691" %)**AT+PRO=4,0   ** (%%) ~/~/ Set to use TCP protocol to uplink(HEX format)
611
612 * (% style="color:#037691" %)**AT+PRO=4,1   ** (%%) ~/~/ Set to use TCP protocol to uplink(JSON format)
613
614 * (% style="color:#037691" %)**AT+SERVADDR=120.24.4.116,5600 ** (%%) ~/~/ to set TCP server address and port
615
616 (% style="color:blue" %)**Sensor Console Output when Uplink:**
617
618 [[image:image-20230807233631-1.png]]
619
620
621 (% style="color:blue" %)**See result in TCP Server:**
622
623 [[image:image-20230807233631-2.png]]
Copyright ©2010-2024 Dragino Technology Co., LTD. All rights reserved
Dragino Wiki v2.0