You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
IoT-For-Beginners/translations/ne/2-farm/lessons/4-migrate-your-plant-to-the.../wio-terminal-connect-hub.md

306 lines
21 KiB

<!--
CO_OP_TRANSLATOR_METADATA:
{
"original_hash": "28320305a35ea3bc59c41fe146a2e6ed",
"translation_date": "2025-08-27T12:05:15+00:00",
"source_file": "2-farm/lessons/4-migrate-your-plant-to-the-cloud/wio-terminal-connect-hub.md",
"language_code": "ne"
}
-->
# आफ्नो IoT उपकरणलाई क्लाउडसँग जडान गर्नुहोस् - Wio Terminal
यस पाठको यस भागमा, तपाईं आफ्नो Wio Terminal लाई IoT Hub सँग जडान गर्नुहुनेछ, टेलिमेट्री पठाउन र आदेशहरू प्राप्त गर्न।
## आफ्नो उपकरणलाई IoT Hub सँग जडान गर्नुहोस्
अर्को चरण भनेको आफ्नो उपकरणलाई IoT Hub सँग जडान गर्नु हो।
### कार्य - IoT Hub सँग जडान गर्नुहोस्
1. VS Code मा `soil-moisture-sensor` प्रोजेक्ट खोल्नुहोस्।
1. `platformio.ini` फाइल खोल्नुहोस्। `knolleary/PubSubClient` लाइब्रेरी निर्भरता हटाउनुहोस्। यो सार्वजनिक MQTT ब्रोकरसँग जडान गर्न प्रयोग गरिएको थियो, र IoT Hub सँग जडान गर्न आवश्यक छैन।
1. तलका लाइब्रेरी निर्भरता थप्नुहोस्:
```ini
seeed-studio/Seeed Arduino RTC @ 2.0.0
arduino-libraries/AzureIoTHub @ 1.6.0
azure/AzureIoTUtility @ 1.6.1
azure/AzureIoTProtocol_MQTT @ 1.6.0
azure/AzureIoTProtocol_HTTP @ 1.6.0
azure/AzureIoTSocket_WiFi @ 1.0.2
```
`Seeed Arduino RTC` लाइब्रेरीले Wio Terminal मा वास्तविक समय घडीसँग अन्तरक्रिया गर्न कोड प्रदान गर्दछ, जुन समय ट्र्याक गर्न प्रयोग गरिन्छ। बाँकी लाइब्रेरीहरूले तपाईंको IoT उपकरणलाई IoT Hub सँग जडान गर्न अनुमति दिन्छ।
1. `platformio.ini` फाइलको तलमा निम्न थप्नुहोस्:
```ini
build_flags =
-DDONT_USE_UPLOADTOBLOB
```
यो कम्पाइलर फ्ल्याग सेट गर्दछ जुन Arduino IoT Hub कोड कम्पाइल गर्दा आवश्यक हुन्छ।
1. `config.h` हेडर फाइल खोल्नुहोस्। सबै MQTT सेटिङहरू हटाउनुहोस् र उपकरण कनेक्शन स्ट्रिङको लागि निम्न स्थिरांक थप्नुहोस्:
```cpp
// IoT Hub settings
const char *CONNECTION_STRING = "<connection string>";
```
`<connection string>` लाई तपाईंले पहिले प्रतिलिपि गरेको उपकरणको कनेक्शन स्ट्रिङले प्रतिस्थापन गर्नुहोस्।
1. IoT Hub सँगको जडान समय-आधारित टोकन प्रयोग गर्दछ। यसको मतलब IoT उपकरणले हालको समय थाहा पाउन आवश्यक छ। Windows, macOS वा Linux जस्ता अपरेटिङ सिस्टमहरू जस्तो, माइक्रोकन्ट्रोलरहरूले इन्टरनेटमार्फत स्वतः हालको समय समक्रमण गर्दैनन्। यसको मतलब तपाईंले [NTP](https://wikipedia.org/wiki/Network_Time_Protocol) सर्भरबाट हालको समय प्राप्त गर्न कोड थप्न आवश्यक छ। एकपटक समय प्राप्त भएपछि, यसलाई Wio Terminal मा वास्तविक समय घडीमा भण्डारण गर्न सकिन्छ, जसले उपकरणले पावर गुमाएको छैन भने सही समय पछि अनुरोध गर्न अनुमति दिन्छ। `ntp.h` नामक नयाँ फाइल निम्न कोडसँग थप्नुहोस्:
```cpp
#pragma once
#include "DateTime.h"
#include <time.h>
#include "samd/NTPClientAz.h"
#include <sys/time.h>
static void initTime()
{
WiFiUDP _udp;
time_t epochTime = (time_t)-1;
NTPClientAz ntpClient;
ntpClient.begin();
while (true)
{
epochTime = ntpClient.getEpochTime("0.pool.ntp.org");
if (epochTime == (time_t)-1)
{
Serial.println("Fetching NTP epoch time failed! Waiting 2 seconds to retry.");
delay(2000);
}
else
{
Serial.print("Fetched NTP epoch time is: ");
char buff[32];
sprintf(buff, "%.f", difftime(epochTime, (time_t)0));
Serial.println(buff);
break;
}
}
ntpClient.end();
struct timeval tv;
tv.tv_sec = epochTime;
tv.tv_usec = 0;
settimeofday(&tv, NULL);
}
```
यस कोडको विवरण यस पाठको दायराभन्दा बाहिर छ। यसले `initTime` नामक एक फंक्शन परिभाषित गर्दछ जसले NTP सर्भरबाट हालको समय प्राप्त गर्दछ र Wio Terminal मा घडी सेट गर्न प्रयोग गर्दछ।
1. `main.cpp` फाइल खोल्नुहोस् र सबै MQTT कोड हटाउनुहोस्, जसमा `PubSubClient.h` हेडर फाइल, `PubSubClient` भेरिएबलको घोषणा, `reconnectMQTTClient``createMQTTClient` मेथडहरू, र यी भेरिएबलहरू र मेथडहरूमा कुनै पनि कलहरू समावेश छन्। यो फाइलमा केवल WiFi सँग जडान गर्न, माटोको चिसोपन प्राप्त गर्न र यससँग JSON डकुमेन्ट सिर्जना गर्न कोड समावेश गर्नुपर्छ।
1. IoT Hub लाइब्रेरीहरू र समय सेट गर्न हेडर फाइलहरू समावेश गर्न `main.cpp` फाइलको माथि निम्न `#include` निर्देशनहरू थप्नुहोस्:
```cpp
#include <AzureIoTHub.h>
#include <AzureIoTProtocol_MQTT.h>
#include <iothubtransportmqtt.h>
#include "ntp.h"
```
1. हालको समय सेट गर्न `setup` फंक्शनको अन्त्यमा निम्न कल थप्नुहोस्:
```cpp
initTime();
```
1. फाइलको माथि, समावेश निर्देशनहरूको ठीक तल, निम्न भेरिएबल घोषणा थप्नुहोस्:
```cpp
IOTHUB_DEVICE_CLIENT_LL_HANDLE _device_ll_handle;
```
यसले `IOTHUB_DEVICE_CLIENT_LL_HANDLE` घोषणा गर्दछ, IoT Hub सँगको जडानको लागि ह्यान्डल।
1. यसको तल, निम्न कोड थप्नुहोस्:
```cpp
static void connectionStatusCallback(IOTHUB_CLIENT_CONNECTION_STATUS result, IOTHUB_CLIENT_CONNECTION_STATUS_REASON reason, void *user_context)
{
if (result == IOTHUB_CLIENT_CONNECTION_AUTHENTICATED)
{
Serial.println("The device client is connected to iothub");
}
else
{
Serial.println("The device client has been disconnected");
}
}
```
यसले एक क्यालब्याक फंक्शन घोषणा गर्दछ जुन IoT Hub सँगको जडानको स्थिति परिवर्तन हुँदा, जस्तै जडान वा डिस्कनेक्ट हुँदा, कल गरिन्छ। स्थिति सिरियल पोर्टमा पठाइन्छ।
1. यसको तल, IoT Hub सँग जडान गर्न फंक्शन थप्नुहोस्:
```cpp
void connectIoTHub()
{
IoTHub_Init();
_device_ll_handle = IoTHubDeviceClient_LL_CreateFromConnectionString(CONNECTION_STRING, MQTT_Protocol);
if (_device_ll_handle == NULL)
{
Serial.println("Failure creating Iothub device. Hint: Check your connection string.");
return;
}
IoTHubDeviceClient_LL_SetConnectionStatusCallback(_device_ll_handle, connectionStatusCallback, NULL);
}
```
यो कोडले IoT Hub लाइब्रेरी कोडलाई इनिसियलाइज गर्दछ, त्यसपछि `config.h` हेडर फाइलमा कनेक्शन स्ट्रिङ प्रयोग गरेर जडान सिर्जना गर्दछ। यो जडान MQTT मा आधारित छ। यदि जडान असफल हुन्छ भने, यो सिरियल पोर्टमा पठाइन्छ - यदि तपाईंले यो आउटपुटमा देख्नुभयो भने, कनेक्शन स्ट्रिङ जाँच गर्नुहोस्। अन्ततः कनेक्शन स्थिति क्यालब्याक सेटअप गरिन्छ।
1. `setup` फंक्शनमा `initTime` कलको तल यो फंक्शन कल गर्नुहोस्:
```cpp
connectIoTHub();
```
1. MQTT क्लाइन्टको जस्तै, यो कोड एकल थ्रेडमा चल्छ त्यसैले हबले पठाएको सन्देशहरू र हबमा पठाइएका सन्देशहरू प्रशोधन गर्न समय चाहिन्छ। `loop` फंक्शनको माथि निम्न थप्नुहोस्:
```cpp
IoTHubDeviceClient_LL_DoWork(_device_ll_handle);
```
1. यो कोड निर्माण र अपलोड गर्नुहोस्। तपाईं सिरियल मोनिटरमा जडान देख्नुहुनेछ:
```output
Connecting to WiFi..
Connected!
Fetched NTP epoch time is: 1619983687
Sending telemetry {"soil_moisture":391}
The device client is connected to iothub
```
आउटपुटमा तपाईंले NTP समय प्राप्त भइरहेको देख्न सक्नुहुन्छ, त्यसपछि उपकरण क्लाइन्ट जडान भइरहेको देख्न सक्नुहुन्छ। जडान गर्न केही सेकेन्ड लाग्न सक्छ, त्यसैले उपकरण जडान भइरहेको बेला तपाईंले आउटपुटमा माटोको चिसोपन देख्न सक्नुहुन्छ।
> 💁 तपाईं NTP को UNIX समयलाई [unixtimestamp.com](https://www.unixtimestamp.com) जस्ता वेबसाइट प्रयोग गरेर पढ्न मिल्ने संस्करणमा रूपान्तरण गर्न सक्नुहुन्छ।
## टेलिमेट्री पठाउनुहोस्
अब तपाईंको उपकरण जडान भएको छ, तपाईं MQTT ब्रोकरको सट्टा IoT Hub मा टेलिमेट्री पठाउन सक्नुहुन्छ।
### कार्य - टेलिमेट्री पठाउनुहोस्
1. `setup` फंक्शनको माथि निम्न फंक्शन थप्नुहोस्:
```cpp
void sendTelemetry(const char *telemetry)
{
IOTHUB_MESSAGE_HANDLE message_handle = IoTHubMessage_CreateFromString(telemetry);
IoTHubDeviceClient_LL_SendEventAsync(_device_ll_handle, message_handle, NULL, NULL);
IoTHubMessage_Destroy(message_handle);
}
```
यो कोडले पास गरिएको स्ट्रिङबाट IoT Hub सन्देश सिर्जना गर्दछ, यसलाई हबमा पठाउँछ, त्यसपछि सन्देश वस्तु सफा गर्दछ।
1. सिरियल पोर्टमा टेलिमेट्री पठाउने लाइनको ठीक पछि `loop` फंक्शनमा यो कोड कल गर्नुहोस्:
```cpp
sendTelemetry(telemetry.c_str());
```
## आदेशहरू ह्यान्डल गर्नुहोस्
तपाईंको उपकरणले रिले नियन्त्रण गर्न सर्वर कोडबाट आदेश ह्यान्डल गर्न आवश्यक छ। यो प्रत्यक्ष विधि अनुरोधको रूपमा पठाइन्छ।
## कार्य - प्रत्यक्ष विधि अनुरोध ह्यान्डल गर्नुहोस्
1. `connectIoTHub` फंक्शनको अघि निम्न कोड थप्नुहोस्:
```cpp
int directMethodCallback(const char *method_name, const unsigned char *payload, size_t size, unsigned char **response, size_t *response_size, void *userContextCallback)
{
Serial.printf("Direct method received %s\r\n", method_name);
if (strcmp(method_name, "relay_on") == 0)
{
digitalWrite(PIN_WIRE_SCL, HIGH);
}
else if (strcmp(method_name, "relay_off") == 0)
{
digitalWrite(PIN_WIRE_SCL, LOW);
}
}
```
यो कोडले क्यालब्याक मेथड परिभाषित गर्दछ जुन IoT Hub लाइब्रेरीले प्रत्यक्ष विधि अनुरोध प्राप्त गर्दा कल गर्न सक्छ। अनुरोध गरिएको विधि `method_name` प्यारामिटरमा पठाइन्छ। यो फंक्शनले सिरियल पोर्टमा कल गरिएको विधि प्रिन्ट गर्दछ, त्यसपछि विधि नामको आधारमा रिले अन वा अफ गर्दछ।
> 💁 यो एकल प्रत्यक्ष विधि अनुरोधमा पनि कार्यान्वयन गर्न सकिन्छ, रिलेको इच्छित अवस्था अनुरोधको साथ पास गर्न सकिने पेलोडमा पास गर्दै, जुन `payload` प्यारामिटरबाट उपलब्ध हुन्छ।
1. `directMethodCallback` फंक्शनको अन्त्यमा निम्न कोड थप्नुहोस्:
```cpp
char resultBuff[16];
sprintf(resultBuff, "{\"Result\":\"\"}");
*response_size = strlen(resultBuff);
*response = (unsigned char *)malloc(*response_size);
memcpy(*response, resultBuff, *response_size);
return IOTHUB_CLIENT_OK;
```
प्रत्यक्ष विधि अनुरोधहरूलाई प्रतिक्रिया आवश्यक छ, र प्रतिक्रिया दुई भागमा हुन्छ - पाठको रूपमा प्रतिक्रिया, र रिटर्न कोड। यो कोडले निम्न JSON डकुमेन्टको रूपमा परिणाम सिर्जना गर्दछ:
```JSON
{
"Result": ""
}
```
यो त्यसपछि `response` प्यारामिटरमा प्रतिलिपि गरिन्छ, र यो प्रतिक्रियाको आकार `response_size` प्यारामिटरमा सेट गरिन्छ। यो कोडले विधि सही रूपमा ह्यान्डल गरिएको देखाउन `IOTHUB_CLIENT_OK` फर्काउँछ।
1. क्यालब्याकलाई जडान गर्न `connectIoTHub` फंक्शनको अन्त्यमा निम्न थप्नुहोस्:
```cpp
IoTHubClient_LL_SetDeviceMethodCallback(_device_ll_handle, directMethodCallback, NULL);
```
1. `loop` फंक्शनले IoT Hub द्वारा पठाइएका घटनाहरू प्रशोधन गर्न `IoTHubDeviceClient_LL_DoWork` फंक्शन कल गर्नेछ। यो केवल `delay` को कारणले प्रत्येक 10 सेकेन्डमा कल गरिन्छ, जसको मतलब प्रत्यक्ष विधिहरू केवल प्रत्येक 10 सेकेन्डमा प्रशोधित हुन्छन्। यसलाई अझ कुशल बनाउन, 10 सेकेन्डको ढिलाइलाई धेरै छोटो ढिलाइको रूपमा कार्यान्वयन गर्न सकिन्छ, प्रत्येक पटक `IoTHubDeviceClient_LL_DoWork` कल गर्दै। यसलाई गर्न `loop` फंक्शनको माथि निम्न कोड थप्नुहोस्:
```cpp
void work_delay(int delay_time)
{
int current = 0;
do
{
IoTHubDeviceClient_LL_DoWork(_device_ll_handle);
delay(100);
current += 100;
} while (current < delay_time);
}
```
यो कोडले बारम्बार लूप गर्नेछ, `IoTHubDeviceClient_LL_DoWork` कल गर्नेछ प्रत्येक पटक 100ms को लागि ढिलाइ गर्नेछ। यो `delay_time` प्यारामिटरमा दिइएको समयको लागि ढिलाइ गर्न आवश्यक जति पटक यो गर्नेछ। यसको मतलब उपकरणले प्रत्यक्ष विधि अनुरोध प्रशोधन गर्न 100ms भन्दा बढी कुर्नु पर्दैन।
1. `loop` फंक्शनमा, `IoTHubDeviceClient_LL_DoWork` कल हटाउनुहोस्, `delay(10000)` कललाई निम्नसँग प्रतिस्थापन गर्नुहोस्:
```cpp
work_delay(10000);
```
> 💁 तपाईं यो कोड [code/wio-terminal](../../../../../2-farm/lessons/4-migrate-your-plant-to-the-cloud/code/wio-terminal) फोल्डरमा फेला पार्न सक्नुहुन्छ।
😀 तपाईंको माटोको चिसोपन सेन्सर प्रोग्राम IoT Hub सँग जडान भएको छ!
---
**अस्वीकरण**:
यो दस्तावेज़ AI अनुवाद सेवा [Co-op Translator](https://github.com/Azure/co-op-translator) प्रयोग गरेर अनुवाद गरिएको छ। हामी शुद्धताको लागि प्रयास गर्छौं, तर कृपया ध्यान दिनुहोस् कि स्वचालित अनुवादमा त्रुटिहरू वा अशुद्धताहरू हुन सक्छ। यसको मूल भाषा मा रहेको मूल दस्तावेज़लाई आधिकारिक स्रोत मानिनुपर्छ। महत्वपूर्ण जानकारीको लागि, व्यावसायिक मानव अनुवाद सिफारिस गरिन्छ। यस अनुवादको प्रयोगबाट उत्पन्न हुने कुनै पनि गलतफहमी वा गलत व्याख्याको लागि हामी जिम्मेवार हुने छैनौं।