ZCL बेहतर प्लैटफ़ॉर्म (ZAP)

ZCL Advanced Platform (ZAP), एक Node.js टेंप्लेट इंजन है. यह Matter क्लस्टर पर आधारित है.

ZAP, Matter ऐप्लिकेशन और एसडीके के लिए ये सुविधाएं उपलब्ध कराता है:

  • जीयूआई इंटरफ़ेस से, Matter एंडपॉइंट, क्लस्टर, एट्रिब्यूट, और डिवाइस की अन्य सुविधाओं को कॉन्फ़िगर करें.
  • ऐसे टेंप्लेट बनाएं जो डेटा मॉडल की परिभाषाएं, कॉलबैक, और अन्य Matter सोर्स कोड अपने-आप जनरेट करते हों.
  • अपने SDK टूल में शामिल करने के लिए, पहले से कॉन्फ़िगर की गई ZAP फ़ाइलें बनाएं और उनका इस्तेमाल करें.
ZAP टूल

इंस्टॉल करें

  1. ZAP रिलीज़ पेज पर जाएं.

  2. "नया" टैग वाली रिलीज़ देखें. ज़्यादातर रिलीज़ को "रिलीज़ से पहले" टैग किया जाएगा.

  3. इस रिलीज़ में, ऐसेट हेडिंग में जाकर, अपने ऑपरेटिंग सिस्टम के लिए तय किया गया पैकेज चुनें और उसे डाउनलोड करें.

  4. Debian या Ubuntu पर चलने वाली मशीन पर, ZAP इंस्टॉल करने के लिए:

    sudo dpkg -i path/to/zap_installation_package

Debian या Ubuntu Linux पर, zap बाइनरी /usr/bin/ में इंस्टॉल होती है. अन्य ऑपरेटिंग सिस्टम पर, बाइनरी को कहीं और इंस्टॉल किया जा सकता है. किसी भी मामले में, पक्का करें कि रन किए जा सकने वाले प्रोग्राम की जगह, आपके PATH एनवायरमेंट वैरिएबल में हो.

ZAP फ़ाइलें

ZAP, ZAP फ़ाइलों नाम की टेंप्लेट फ़ाइलों का इस्तेमाल करता है. ZAP फ़ाइल एक JSON फ़ाइल होती है, जिसमें एंडपॉइंट, निर्देश, एट्रिब्यूट, और डिवाइस की अन्य सुविधाओं के बारे में जानकारी होती है. ZAP फ़ाइलों के नाम .zap पर खत्म होते हैं. उदाहरण के लिए, connectedhomeip/examples/lighting-app/lighting-common में lighting-app.zap.

all-clusters-app.zap फ़ाइल, connectedhomeip/examples/all-clusters-app/all-clusters-common में मिलती है. इसे सामान्य Matter क्लस्टर और तीन एंडपॉइंट के साथ पहले से कॉन्फ़िगर किया जाता है. इनमें Matter सेकंडरी नेटवर्क को कमिशन करने वाले डिवाइस टाइप भी शामिल हैं. यह क्लस्टर के अलग-अलग कॉन्फ़िगरेशन को एक्सप्लोर करने का एक अच्छा उदाहरण है.

चलाएं

  1. Matter के उदाहरणों में से कोई एक ZAP फ़ाइल चुनें.
  2. Matter रिपॉज़िटरी (connectedhomeip) की रूट डायरेक्ट्री से, run_zaptool.sh रैपर स्क्रिप्ट को चलाएं. इसके लिए, .zap फ़ाइल का पाथ डालें.

उदाहरण के लिए:

./scripts/tools/zap/run_zaptool.sh ./examples/lighting-app/lighting-common/lighting-app.zap

सेट अप करें

सेटिंग में जाकर, ZAP के यूज़र इंटरफ़ेस को कॉन्फ़िगर किया जा सकता है. इसमें, हल्की या गहरे रंग वाली थीम चुनने के साथ-साथ, डेवलपर टूल चालू या बंद करने का विकल्प भी शामिल है.

विकल्प पर क्लिक करके, प्रॉडक्ट मैन्युफ़ैक्चरर और डिफ़ॉल्ट जवाब की नीति चुनी जा सकती है. साथ ही, कमांड डिस्कवरी को चालू या बंद किया जा सकता है.

ZAP के ग्लोबल विकल्प

Zigbee क्लस्टर कॉन्फ़िगरर में कस्टम ZCL क्लस्टर या निर्देश जोड़ने के लिए, एक्सटेंशन पर क्लिक करें.

इस्तेमाल करें

एंडपॉइंट

lighting-app.zap फ़ाइल को पहले से Matter रूट नोड (एंडपॉइंट - 0) और Matter कम रोशनी करने वाले लाइट डिवाइस (एंडपॉइंट - 1) के साथ कॉन्फ़िगर किया गया है.

एंडपॉइंट - 0 में ऐसे सामान्य क्लस्टर शामिल होते हैं जो पूरे नोड के लिए काम के होते हैं. जैसे, नेटवर्किंग, कमीशनिंग, डिस्क्रिप्टर, ऑपरेशनल क्रेडेंशियल, और ओटीए क्लस्टर.

ZAP एंडपॉइंट 0

अगले चरणों में, आपको उदाहरण lighting-app में दिए गए एंडपॉइंट - 1 Matter मंद की जा सकने वाली लाइट की समीक्षा करनी होगी और उसे कॉन्फ़िगर करना होगा.

  1. Matter repo connectedhomeip से, ZAP चलाएं.

    scripts/tools/zap/run_zaptool.sh \
    examples/lighting-app/lighting-common/lighting-app.zap
  2. एंडपॉइंट - 1 पर क्लिक करें. इसके बाद, बदलाव करें पर क्लिक करें.

  3. ज़रूरी नहीं: Matter कई तरह के डिवाइसों पर काम करता है. डिवाइस ड्रॉपडाउन में, अपना डिवाइस बदलने के लिए matter टाइप करना शुरू करें. इसके बाद, सेव करें पर क्लिक करें.

    ZAP Select Device

ज़्यादा जानने के लिए, MatterPrimer में डिवाइस और एंडपॉइंट देखें.

क्लस्टर

पहले से तय क्लस्टर, एट्रिब्यूट, और रिपोर्टिंग के विकल्प, डिफ़ॉल्ट रूप से एंडपॉइंट - 1 में चालू होते हैं.

सिर्फ़ चालू किए गए क्लस्टर देखने के लिए, एंडपॉइंट - 1 पर क्लिक करें. इसके बाद, दिखाएं मेन्यू से चालू किए गए क्लस्टर चुनें. क्लस्टर को नाम से भी खोजा जा सकता है. उदाहरण के लिए, on.

ZAP की सुविधा वाले क्लस्टर

किसी क्लस्टर को क्लाइंट, सर्वर या क्लाइंट और सर्वर के तौर पर चालू करने के लिए, चालू करें ड्रॉपडाउन का इस्तेमाल करें. आपके पास पहले से कॉन्फ़िगर किए गए ऐसे क्लस्टर को बंद करने का विकल्प भी है जो आपके डिवाइस टाइप पर लागू नहीं होता. इसके लिए, चालू नहीं है को चुनें.

ZAP Disable Cluster

ज़्यादा जानने के लिए, Matter प्राइमर में क्लस्टर देखें.

एट्रिब्यूट और निर्देश

एट्रिब्यूट और निर्देशों को कॉन्फ़िगर करने के लिए, यह तरीका अपनाएं:

  1. On/Off क्लस्टर ढूंढें.
  2. उसी लाइन में, कॉन्फ़िगर करें आइकॉन पर क्लिक करें .

    ZAP कॉन्फ़िगर करना

यहां एट्रिब्यूट चालू या बंद किए जा सकते हैं, एट्रिब्यूट के अलग-अलग विकल्प सेट किए जा सकते हैं, और नाम के हिसाब से एट्रिब्यूट खोजे जा सकते हैं.

ZAP एट्रिब्यूट

इस क्लस्टर के लिए कार्रवाइयां कॉन्फ़िगर करने के लिए, कमांड पर क्लिक करें. उदाहरण के लिए, किसी लाइट के लिए चालू/बंद क्लस्टर में, चालू, बंद, और टॉगल निर्देश शामिल होंगे. हो सकता है कि Temperature Measurement क्लस्टर जैसे कुछ क्लस्टर में कोई भी कमांड न हो.

ZAP निर्देश

ज़्यादा जानने के लिए, Matter प्राइमर में एट्रिब्यूट और कमांड देखें.

ZAP सोर्स फ़ाइलें जनरेट करना

Matter के उदाहरणों में, ZAP से जनरेट किए गए सोर्स कोड का इस्तेमाल किया गया है. यह कोड, connectedhomeip/zzz_generated डायरेक्ट्री में उपलब्ध है. कुछ फ़ाइलें ऐप्लिकेशन के हिसाब से होती हैं, जबकि अन्य सामान्य ZAP फ़ाइलों को app-common में ग्रुप किया जाता है.

#include <app-common/zap-generated/ids/Attributes.h>
#include <app-common/zap-generated/ids/Clusters.h>

एंडपॉइंट कॉन्फ़िगर होने के बाद, अपने प्रोजेक्ट में इंटिग्रेट करने के लिए सोर्स फ़ाइलें जनरेट की जा सकती हैं.

  1. जनरेट करें पर क्लिक करें.
  2. ZAP आउटपुट सेव करने के लिए कोई फ़ोल्डर चुनें. उदाहरण के लिए, lighting-app के लिए connectedhomeip/zzz_generated/lighting-app/zap-generated पर जाएं.
  3. Optional. फ़ाइलों को अपने पसंदीदा आईडीई में खोलें.

ZAP, आपके डिवाइस टाइप और ZAP कॉन्फ़िगरेशन के हिसाब से, तय करता है, फ़ंक्शन बनाता है, और अन्य सोर्स कोड जनरेट करता है.

ZAP से जनरेट की गई फ़ाइलें

उदाहरण के लिए, callback-stub.cpp में क्लस्टर कॉलबैक का एक तरीका शामिल है, जिसमें सिर्फ़ वे क्लस्टर शामिल होते हैं जिन्हें आपने चालू किया है:

void emberAfClusterInitCallback(EndpointId endpoint, ClusterId clusterId)
{
    switch (clusterId)
    {
     ...
     case ZCL_ON_OFF_CLUSTER_ID :
        emberAfOnOffClusterInitCallback(endpoint);
        break;
     ...
    }
}

ZAP सोर्स फ़ाइलों का इस्तेमाल करना

डिवाइस टाइप के एट्रिब्यूट पाने और सेट करने के लिए, सामान्य ZAP सोर्स फ़ाइलों का इस्तेमाल किया जा सकता है. उदाहरण के लिए, zzz_generated/app-common/app-common/zap-generated/ids/ में Attributes.h:

Attributes.h

namespace DeviceTemperatureConfiguration {
  namespace Attributes {

  namespace CurrentTemperature {
    static constexpr AttributeId Id = 0x00000000;
    } // namespace CurrentTemperature

  ...

  } // namespace Attributes
} // namespace DeviceTemperatureConfiguration

main.cpp

#include <app-common/zap-generated/att-storage.h>
#include <app-common/zap-generated/attribute-id.h>
#include <app-common/zap-generated/attribute-type.h>
#include <app-common/zap-generated/attributes/Accessors.h>
#include <app-common/zap-generated/callback.h>
#include <app-common/zap-generated/cluster-id.h>
#include <app-common/zap-generated/cluster-objects.h>
#include <app-common/zap-generated/command-id.h>

using namespace ::chip;
using namespace ::chip::app::Clusters;

static void InitServer(intptr_t context)
{
    ...

    // Sets temperature to 20C
    int16_t temperature = 2000;
    auto status         = DeviceTemperatureConfiguration::Attributes::CurrentTemperature::Set(1, temperature);
    if (status != EMBER_ZCL_STATUS_SUCCESS)
    {
        ChipLogError(Shell, "Temp measurement set failed");
    }
}

Matter सोर्स कोड में ZAP फ़ाइलों का इस्तेमाल करने का तरीका जानने के बाद, ZAP को इंटिग्रेट करने के कई तरीके हैं:

  • अपने डिवाइस टाइप के हिसाब से नए उदाहरण बनाने के लिए, मौजूदा zzz_generated फ़ाइलों का इस्तेमाल करें.
  • अपने प्रोजेक्ट के लिए कस्टम .zap फ़ाइलें बनाएं.

कस्टमाइज़ करें

ZAP फ़ाइलें, ZAP टेंप्लेट से जनरेट होती हैं. ZAP लॉन्च करने के लिए run_zaptool.sh का इस्तेमाल करने पर, यह स्क्रिप्ट इन टेंप्लेट में पास होती है:

node src-script/zap-start.js --logToStdout \
    --gen "$CHIP_ROOT/src/app/zap-templates/app-templates.json" \
    --zcl "$CHIP_ROOT/src/app/zap-templates/zcl/zcl.json" \
    "${ZAP_ARGS[@]}"

templates.json, Matter टेंप्लेट के नाम और Matter के उदाहरणों में इस्तेमाल की गई उस आउटपुट फ़ाइल के बारे में बताता है.

{
    "path": "templates/app/callback-stub-src.zapt",
    "name": "ZCL callback-stub source",
    "output": "callback-stub.cpp"
}

Matter के समाधानों को पसंद के मुताबिक बनाने के लिए, ZAP के साथ काम करते समय ये कार्रवाइयां की जा सकती हैं:

संसाधन

ZAP के बारे में ज़्यादा संसाधनों के लिए, GitHub पर ZAP repo (zap) देखें.