C++ के साथ डाइनैमिक लिंक पाएं

अपने बनाए गए Firebase Dynamic Links को पाने के लिए, आपको अपने ऐप्लिकेशन में Dynamic Links SDK टूल शामिल करना होगा. साथ ही, firebase::dynamic_links::Listener ऑब्जेक्ट बनाना होगा, जो OnDynamicLinkReceived वर्चुअल फ़ंक्शन को लागू करता हो.

C++ SDK टूल, Android और iOS, दोनों पर काम करता है. हालांकि, इसके लिए हर प्लैटफ़ॉर्म के लिए कुछ अतिरिक्त सेटअप की ज़रूरत होती है.

शुरू करने से पहले

Firebase Dynamic Links का इस्तेमाल करने से पहले, आपको:

  • अपना C++ प्रोजेक्ट रजिस्टर करें और उसे Firebase का इस्तेमाल करने के लिए कॉन्फ़िगर करें.

    अगर आपका C++ प्रोजेक्ट पहले से ही Firebase का इस्तेमाल करता है, तो इसका मतलब है कि वह Firebase के लिए पहले से ही रजिस्टर और कॉन्फ़िगर किया गया है.

  • अपने C++ प्रोजेक्ट में Firebase C++ SDK टूल जोड़ें.

ध्यान दें कि अपने C++ प्रोजेक्ट में Firebase जोड़ने के लिए, Firebase कंसोल और अपने ओपन C++ प्रोजेक्ट, दोनों में टास्क शामिल होते हैं. उदाहरण के लिए, कंसोल से Firebase कॉन्फ़िगरेशन फ़ाइलें डाउनलोड करके, उन्हें अपने C++ प्रोजेक्ट में ले जाना.

कस्टम यूआरएल स्कीम जोड़ना (सिर्फ़ iOS के लिए)

Firebase Dynamic Links C++ क्लाइंट लाइब्रेरी, लिंक को प्रोसेस करने के लिए iOS पर कस्टम यूआरएल स्कीम का इस्तेमाल करती है. Dynamic Links पाने के लिए, आपको अपने ऐप्लिकेशन में कस्टम यूआरएल स्कीम जोड़नी होंगी.

  1. अपने प्रोजेक्ट का कॉन्फ़िगरेशन खोलने के लिए, बाएं ट्री व्यू में प्रोजेक्ट के नाम पर दो बार क्लिक करें.

  2. टारगेट सेक्शन से अपना ऐप्लिकेशन चुनें. इसके बाद, जानकारी टैब चुनें. इसके बाद, यूआरएल टाइप सेक्शन को बड़ा करें.

  3. + बटन पर क्लिक करें. इसके बाद, उलटे क्रम में लिखे गए क्लाइंट आईडी के लिए यूआरएल स्कीम जोड़ें. इस वैल्यू को ढूंढने के लिए:

    1. GoogleService-Info.plist कॉन्फ़िगरेशन फ़ाइल खोलें, फिर REVERSED_CLIENT_ID कुंजी खोजें.

    2. उस कुंजी की वैल्यू कॉपी करें. इसके बाद, उसे कॉन्फ़िगरेशन पेज पर मौजूद यूआरएल स्कीम बॉक्स में चिपकाएं.

    3. अन्य फ़ील्ड खाली छोड़ें.

  4. + बटन पर क्लिक करें. इसके बाद, दूसरा यूआरएल स्कीम जोड़ें. यह आपके ऐप्लिकेशन के बंडल आईडी के जैसा ही होता है.

    उदाहरण के लिए, अगर आपका बंडल आईडी com.example.ios है, तो उस वैल्यू को यूआरएल स्कीम बॉक्स में टाइप करें.

    अपने ऐप्लिकेशन का बंडल आईडी, प्रोजेक्ट कॉन्फ़िगरेशन (आइडेंटिटी > बंडल आइडेंटिफ़ायर) के सामान्य टैब में देखा जा सकता है.

Dynamic Link मिल रहा है

ऐप्लिकेशन बनाना और उसे शुरू करना

Dynamic Links मिलने की जांच करने से पहले, आपको एक firebase::App ऑब्जेक्ट बनाना और उसे शुरू करना होगा.

firebase::App के लिए हेडर फ़ाइल शामिल करें:

#include "firebase/app.h"

अगला हिस्सा आपके प्लैटफ़ॉर्म के हिसाब से अलग-अलग होता है:

Android

firebase::App बनाएं. इसके लिए, JNI एनवायरमेंट और Java गतिविधि का jobject रेफ़रंस, आर्ग्युमेंट के तौर पर पास करें:

app = ::firebase::App::Create(::firebase::AppOptions("APPLICATION NAME"), jni_env, activity);

iOS

firebase::App बनाएं:

app = ::firebase::App::Create(::firebase::AppOptions("APPLICATION NAME"));

Dynamic Links की जांच करने के लिए, Listener लागू करना

Dynamic Link मिला है या नहीं, यह देखने के लिए firebase::dynamic_links::Listener क्लास को लागू करें और उसका इस्तेमाल करें.

Dynamic Links पाने के लिए हेडर फ़ाइल शामिल करें:

#include "firebase/dynamic_links.h"

Dynamic Links लाइब्रेरी को शुरू करना:

::firebase::dynamic_links::Initialize(app, null);

ऐसा ऑब्जेक्ट बनाएं जो firebase::dynamic_links::Listener को लागू करता हो. साथ ही, इसे SetListener() के साथ Dynamic Links लाइब्रेरी में दें या इसे शुरू करें के दूसरे आर्ग्युमेंट के तौर पर पास करें.

Dynamic Links पाने के लिए, आपकी लिसनर क्लास को OnDynamicLinkReceived वर्चुअल फ़ंक्शन लागू करना होगा. अगर कोई डीप लिंक मिला है, तो उसे पाने के लिए, इस तरीके को बदला जा सकता है.

class Listener : public firebase::dynamic_links::Listener {
 public:
  // Called on the client when a dynamic link arrives.
  void OnDynamicLinkReceived(
      const firebase::dynamic_links::DynamicLink* dynamic_link) override {
    printf("Received link: %s", dynamic_link->url.c_str());
  }
};