एजेंट मैनेज करें

सभी एजेंट, किसी ब्रैंड (कारोबार, संगठन या ग्रुप) से जुड़े होते हैं. कोई एजेंट बनाने से पहले, उससे जुड़ा ब्रैंड बनाना ज़रूरी है. ब्रैंड, सिर्फ़ संगठन के लिए होते हैं. इनकी मदद से, एक जैसे एजेंट को ग्रुप में रखा जा सकता है

इस पेज पर दिए गए कोड स्निपेट, Java और Node.js के सैंपल से लिए गए हैं.

एजेंट बनाना और उसकी परिभाषा

कोई एजेंट बनाएं

RBM एजेंट बनाने के लिए, आपको उसकी बुनियादी जानकारीतय करनी होगी.

ज़्यादा जानकारी के लिए, brands.agents.create देखें.

के बारे में पूरी जानकारी पाने के लिए, बिलिंग से जुड़े अक्सर पूछे जाने वाले सवाल देखें.

cURL

curl -v -X POST "https://businesscommunications.googleapis.com/v1/$BRAND_ID/agents" \
  -H "Content-Type: application/json" \
  -H "User-Agent: curl/business-messaging" \
  -H "`oauth2l header --json rbm-developer-service-account-credentials.json businesscommunications`" \
  -d "{
    'displayName': 'My test agent',
    'rcsBusinessMessagingAgent': {
      'description': 'My agent description',
      'logoUri': 'https://agent-logos.storage.googleapis.com/_/kt90w53vzw2QSxK6PG1uCeJf',
      'heroUri': 'https://agent-logos.storage.googleapis.com/_/kt90vzob74GQcfeHoEQbVRTP',
      'phoneNumbers': [
        {
            'phoneNumber': {
                'number': '+44800088088'
            },
            'label': 'My number'
        }
      ],
      'emails': [
        {
            'address': 'support@demo.test',
            'label': 'My email'
        }
      ],
      'websites': [
        {
            'uri': 'https://a.demo.test/',
            'label': 'My site'
        }
      ],
      'privacy': {
        'uri': 'https://a.demo.test/privacy',
        'label': 'My privacy policy'
      },
      'termsConditions': {
        'uri': 'https://a.demo.test/terms',
        'label': 'My terms'
      },
      'color': '#FFFFFF',
      'billingConfig': {
        'billingCategory': 'CONVERSATIONAL'
      },
      'agentUseCase': 'TRANSACTIONAL',
      'hostingRegion': 'EUROPE'
    }
  }"
यह कोड, हमारे RBM मैनेजमेंट एपीआई सैंपल का एक हिस्सा है.

Node.js

const businessCommunicationsApiHelper =
  require('@google/rbm-businesscommunications');

const privateKey =
  require('../../resources/businesscommunications-service-account-credentials.json');

businessCommunicationsApiHelper.initBusinessCommunucationsApi(privateKey);

const newAgentDetails = {
  displayName: 'My new agent',
  name: brandId + '/agents/',
  rcsBusinessMessagingAgent: {
    description: 'This is the agent description that will be displayed in the Agent info tab in Messages',
    logoUri: 'https://agent-logos.storage.googleapis.com/_/kt90w53vzw2QSxK6PG1uCeJf',
    heroUri: 'https://agent-logos.storage.googleapis.com/_/kt90vzob74GQcfeHoEQbVRTP',
    phoneNumbers: [
      {
        phoneNumber: {
          number: '+12223334444'
        },
        label: 'Call support'
      }
    ],
    // It's recommended to provide at least one contact method (phone or email) because
    // this is required for launch. For any phone, email, or website provided, a corresponding label
    // must also be included.
    privacy: {
      "uri": 'https://policies.google.com/privacy',
      "label": 'Our privacy policy'
    },
    termsConditions: {
      "uri": 'https://policies.google.com/terms',
      "label": 'Our Terms and Conditions'
    },
    color: '#0B78D0',
    billingConfig: { billingCategory: 'NON_CONVERSATIONAL' },
    agentUseCase: 'TRANSACTIONAL',
    hostingRegion: 'EUROPE'
  }
};

businessCommunicationsApiHelper.createAgent(brandId, newAgentDetails).then((response) => {

}).catch((err) => {
  console.log(err);
});

Java

Brand brand = api.getBrand(brandId);
logger.info("Brand to operate on: " + brand);
String displayName = flags.getOrDefault("agent_name", "Test RBM Agent: " + now.getSecond());
String suffix = flags.getOrDefault("agent_data_suffix", "API");
RcsBusinessMessagingAgent agentData = AgentFactory.createRbmAgent(suffix);
Agent agent = api.createRbmAgent(brand, displayName, agentData);
logger.info("RBM agent has been created: " + agent);

इस कोड से, नए एजेंट की जानकारी और उसे असाइन किया गया यूनीक आइडेंटिफ़ायर मिलता है:

{
  name: 'brands/40bd963f-ff92-425c-b273-8f0892d2d017/agents/my_new_agent_dxuewtvy_agent',
  displayName: 'My new agent',
  rcsBusinessMessagingAgent: {
    description: 'This is the agent description that will be displayed in the Agent info tab in Messages',
    logoUri: 'https://agent-logos.storage.googleapis.com/_/kt90w53vzw2QSxK6PG1uCeJf',
    heroUri: 'https://agent-logos.storage.googleapis.com/_/kt90vzob74GQcfeHoEQbVRTP',
    phoneNumbers: [ [Object] ],
    privacy: {
      uri: 'https://policies.google.com/privacy',
      label: 'Our privacy policy'
    },
    termsConditions: {
      uri: 'https://policies.google.com/terms',
      label: 'Our Terms and Conditions'
    },
    color: '#0B78D0',
    billingConfig: { billingCategory: 'NON_CONVERSATIONAL' },
    agentUseCase: 'MULTI_USE',
    hostingRegion: 'EUROPE'
  }
}

किसी एजेंट की परिभाषा देखना

किसी एजेंट का यूनीक आइडेंटिफ़ायर (name) तय करके, उसे वापस पाया जा सकता है. ज़्यादा जानकारी के लिए, brands.agents.list देखें.

Node.js

const businessCommunicationsApiHelper =
  require('@google/rbm-businesscommunications');

const privateKey =
  require('../../resources/businesscommunications-service-account-credentials.json');

businessCommunicationsApiHelper.initBusinessCommunucationsApi(privateKey);

// Retrieve details of the first agent (if one has already been created)
businessCommunicationsApiHelper.getAgent(agent.name).then((response) => {

}).catch((err) => {
  console.log(err);
});

Java

Agent agent = api.getAgent(flags.get("agent_id"));
logger.info("Agent: " + agent);

इस कोड से, एजेंट की जानकारी मिलती है:

{
  name: 'brands/40bd963f-ff92-425c-b273-8f0892d2d017/agents/my_new_agent_dxuewtvy_agent',
  displayName: 'My new agent',
  rcsBusinessMessagingAgent: {
    description: 'This is the agent description that will be displayed in the Agent info tab in Messages',
    logoUri: 'https://agent-logos.storage.googleapis.com/_/kt90w53vzw2QSxK6PG1uCeJf',
    heroUri: 'https://agent-logos.storage.googleapis.com/_/kt90vzob74GQcfeHoEQbVRTP',
    phoneNumbers: [ [Object] ],
    privacy: {
      uri: 'https://policies.google.com/privacy',
      label: 'Our privacy policy'
    },
    termsConditions: {
      uri: 'https://policies.google.com/terms',
      label: 'Our Terms and Conditions'
    },
    color: '#0B78D0',
    billingConfig: { billingCategory: 'NON_CONVERSATIONAL' },
    agentUseCase: 'MULTI_USE',
    hostingRegion: 'EUROPE'
  }
}

पुष्टि करना और लॉन्च करना

पुष्टि करने के लिए जानकारी सबमिट करना

एजेंट लॉन्च करने के लिए , ब्रैंड की पुष्टि करना ज़रूरी है. लॉन्च का अनुरोध करने से पहले, आपको पुष्टि करने के लिए जानकारी सबमिट करनी होगी. ध्यान दें कि लॉन्च का अनुरोध करने से पहले, आपको ब्रैंड की मंज़ूरी मिलने का इंतज़ार नहीं करना होगा. ब्रैंड की मंज़ूरी, लॉन्च की मंज़ूरी की प्रोसेस का हिस्सा होती है.

ज़्यादा जानकारी के लिए, brands.agents.requestVerification देखें.

Node.js

const businessCommunicationsApiHelper =
  require('@google/rbm-businesscommunications');

const privateKey =
  require('../../resources/businesscommunications-service-account-credentials.json');

businessCommunicationsApiHelper.initBusinessCommunucationsApi(privateKey);

let agentVerificationContact = {
  partnerName: 'Alice',
  partnerEmailAddress: 'alice@thepartner.com',
  brandContactName: 'Bob',
  brandContactEmailAddress: 'bob@thebrand.com',
  brandWebsiteUrl: 'https://thebrand.com/'
};

businessCommunicationsApiHelper.verifyAgent(agent.name, agentVerificationContact).then((response) => {

}).catch((err) => {
  console.log(err);
});

Java

AgentVerificationContact contact = AgentFactory.createRbmAgentVerification();
AgentVerification verification = api.requestAgentVerification(agent.getName(), contact);
logger.info("Verification requested: " + verification);

इस कोड से, पुष्टि करने के लिए दी गई जानकारी मिलती है:

{
  "name": "brands/40bd963f-ff92-425c-b273-8f0892d2d017/agents/my_new_agent_ciymyd2b_agent",
  "verificationState": "VERIFICATION_STATE_UNVERIFIED",
  "agentVerificationContact": {
    "partnerName": "Alice",
    "partnerEmailAddress": "alice@thepartner.com",
    "brandContactName": "Bob",
    "brandContactEmailAddress": "bob@thebrand.com",
    "brandWebsiteUrl": "https://thebrand.com/"
  }
}

किसी एजेंट की पुष्टि करने के लिए दी गई जानकारी देखना

किसी एजेंट के ब्रैंड की पुष्टि का स्टेटस वापस पाया जा सकता है. ज़्यादा जानकारी के लिए, देखें brands.agents.getVerification.

Node.js

const businessCommunicationsApiHelper =
  require('@google/rbm-businesscommunications');

const privateKey =
  require('../../resources/businesscommunications-service-account-credentials.json');

businessCommunicationsApiHelper.initBusinessCommunucationsApi(privateKey);

businessCommunicationsApiHelper.getAgentVerification(agent.name).then((response) => {

}).catch((err) => {
  console.log(err);
});

Java

AgentVerification verification = api.getAgentVerification(agent.getName());
logger.info("RBM agent verification: " + verification);

इस कोड से, पुष्टि का स्टेटस और पार्टनर की जानकारी मिलती है:

{
  "name": "brands/40bd963f-ff92-425c-b273-8f0892d2d017/agents/my_new_agent_ciymyd2b_agent/verification",
  "verificationState": "VERIFICATION_STATE_UNVERIFIED",
  "agentVerificationContact": {
    "partnerName": "John Doe",
    "partnerEmailAddress": "john.doe@gmail.com",
    "brandContactName": "Bob",
    "brandContactEmailAddress": "bob@brand.com",
    "brandWebsiteUrl": "https://www.brand.com"
  }
}

किसी एजेंट को लॉन्च करने के लिए सबमिट करना

किसी एजेंट को एक या उससे ज़्यादा मोबाइल और इंटरनेट सेवा देने वाली कंपनियों के नेटवर्क पर लॉन्च करने के लिए सबमिट किया जा सकता है. कुछ लॉन्च को Google मैनेज करता है, जबकि अन्य को सीधे तौर पर मोबाइल और इंटरनेट सेवा देने वाली कंपनियां मैनेज करती हैं. मोबाइल और इंटरनेट सेवा देने वाली कंपनियों के मैनेज किए जाने वाले लॉन्च के लिए, अतिरिक्त शर्तें लागू हो सकती हैं. ज़्यादा जानकारी के लिए, Google के मैनेज किए जाने वाले लॉन्च बनाम मोबाइल और इंटरनेट सेवा देने वाली कंपनियों के मैनेज किए जाने वाले लॉन्च देखें.

किसी एजेंट को पहली बार लॉन्च करने से पहले, आपको पुष्टि करने के लिए जानकारी सबमिट करनी होगी. इससे Google, मोबाइल और इंटरनेट सेवा देने वाली कंपनियों या दोनों को, आपके ब्रैंड के संपर्क व्यक्ति से यह पुष्टि करने में मदद मिलती है कि आपके पास उनकी ओर से एजेंट को मैनेज करने की अनुमति है. ज़्यादा जानकारी के लिए, ब्रैंड की पुष्टि करना देखें.

पुष्टि करने के लिए जानकारी सबमिट करने और लॉन्च की ज़रूरी शर्तें, पूरी करने के बाद, लॉन्च का अनुरोध सबमिट किया जा सकता है.

किसी एजेंट को एक या उससे ज़्यादा मोबाइल और इंटरनेट सेवा देने वाली कंपनियों के नेटवर्क पर लॉन्च करने के लिए सबमिट किया जा सकता है. लॉन्च के अनुरोध के साथ, लॉन्च से जुड़े सवालों की सूची सबमिट करना ज़रूरी है. ज़्यादा जानकारी के लिए, देखें brands.agents.requestLaunch.

cURL

curl -v -X POST "https://businesscommunications.googleapis.com/v1/$AGENT_ID:requestLaunch" \
  -H "Content-Type: application/json" \
  -H "User-Agent: curl/business-messaging" \
  -H "`oauth2l header --json rbm-developer-service-account-credentials.json businesscommunications`" \
  -d "{
    'agentLaunch': {
      'rcsBusinessMessaging': {
        'questionnaire': {
          'contacts': [
            {
              'name': 'John Doe',
              'title': 'Product Owner',
              'email': 'support@demo.test'
            }
          ],
          'optinDescription': 'Thanks for your request.',
          'triggerDescription': 'Promotional messages will be triggered in a timely manner.',
          'interactionsDescription': 'Promotional messages are one way.',
          'optoutDescription': 'Sorry to see you go.',
          'agentAccessInstructions': 'Thanks for your request.',
          'videoUris': [
            'https://d2q4iodazzzt8b.cloudfront.net/MicrosoftTeamsvideo2_1758533835.mp4'
          ],
          'screenshotUris': [
            'https://rm.virbm.com/Il9ChvVEhS1na5mr/ee9bc94b468a40688fb7fc71cb1c069c.png'
          ]
        },
        'launchDetails': {
          '/v1/regions/$CARRIER_ID': {}
        }
      }
    }
  }"
यह कोड, हमारे RBM मैनेजमेंट एपीआई सैंपल का एक हिस्सा है.

Node.js

const businessCommunicationsApiHelper =
  require('@google/rbm-businesscommunications');

const privateKey =
  require('../../resources/businesscommunications-service-account-credentials.json');

businessCommunicationsApiHelper.initBusinessCommunucationsApi(privateKey);
  
let agentLaunch = {
  questionnaire: {
    contacts: [
      {
        name: 'James Bond',
        title: 'Mr 0 0 7',
        email: 'someone@somewhere.com'
      }
    ],
    optinDescription: 'Users accepted our terms of service online.',
    triggerDescription: 'We are reaching preregistered users',
    interactionsDescription: 'This agent does not do much.',
    optoutDescription: 'Reply stop and we stop.',
    agentAccessInstructions: 'This is a a simple agent that reaches registered users.',
    videoUris: [
      'https://www.google.com/a/video'
    ],
    screenshotUris: [
      'https://www.google.com/a/screenshot'
    ]
  },
  launchDetails: {}
};

businessCommunicationsApiHelper.launchAgent(agent.name, agentLaunch).then((response) => {

}).catch((err) => {
  console.log(err);
});

Java

Optional<Questionnaire> q = Optional.of(AgentFactory.createRbmQuestionnaire());
AgentLaunch launch = api.requestRbmAgentLaunch(agent.getName(), regionIds, q);
logger.info("RBM agent updated launch: " + launch);

इस कोड से, एजेंट को लॉन्च करने की जानकारी मिलती है:

{
  "name": "brands/40bd963f-ff92-425c-b273-8f0892d2d017/agents/my_new_agent_7jo0trhw_agent/launch",
  "rcsBusinessMessaging": {
    "questionnaire": {
      "contacts": [
        {
          "name": "James Bond",
          "title": "Mr O O 7",
          "email": "someone@somewhere.com"
        }
      ],
      "optinDescription": "Users accepted our terms of service online.",
      "triggerDescription": "We are reaching preregistered users",
      "interactionsDescription": "This agent does not do much.",
      "optoutDescription": "Reply stop and we stop.",
      "agentAccessInstructions": "This is a a simple agent that reaches registered users.",
      "videoUris": [
        "https://www.google.com/a/video"
      ],
      "screenshotUris": [
        "https://www.google.com/a/screenshot"
      ]
    },
    "launchDetails": {
      "/v1/regions/some-carrier": {
        "launchState": "LAUNCH_STATE_PENDING",
        "updateTime": "2023-02-24T15:02:13.903554Z"
      }
    },
    "launchRegion": "NORTH_AMERICA"
  }
}

ध्यान दें कि launchRegion अब काम नहीं करता. इसे जल्द ही हटा दिया जाएगा.

किसी एजेंट को एक या उससे ज़्यादा क्षेत्रों में लॉन्च करना

किसी एजेंट को एक या उससे ज़्यादा क्षेत्रों में लॉन्च करने के लिए, requestLaunch तरीके को कॉल करें. यह तब किया जाता है, जब एजेंट को पहले लॉन्च नहीं किया गया हो . इसके लिए, एक ऐसा ऑब्जेक्ट इस्तेमाल करें जिसमें उन सभी क्षेत्रों के लिए सिर्फ़ कुंजियां शामिल हों जहां आपको एजेंट को लॉन्च करना है. खाली मैप का इस्तेमाल करने से, एपीआई कॉल के बीच इस्तेमाल किए जाने वाले ऑब्जेक्ट में, इंटरनल एपीआई की एक जैसी सेटिंग बनाए रखने में मदद मिलती है.

curl -X POST \
"https://businesscommunications.googleapis.com/v1/brands/BRAND_ID/agents/AGENT_ID:requestLaunch" \
-H "Content-Type: application/json" \
-H "$(oauth2l header --json PATH_TO_SERVICE_ACCOUNT_KEY businesscommunications)" \
-d "{
  'name': 'brands/BRAND_ID/agents/AGENT_ID/launch',
  'rcsBusinessMessaging': {
    'questionnaire': {
      'contacts': [
        {
          'name': 'Contact person 000',
          'title': 'Contact manager 000',
          'email': 'user@domain.com000'
        }
      ],
      'optinDescription': 'Opt-in description 0',
      'triggerDescription': 'Trigger description 0',
      'optoutDescription': 'Opt-out description 0',
      'agentAccessInstructions': 'Agent instructions 0',
      'videoUris': [
        'https://www.youtube.com/watch?v=NN75im_us4k'
      ],
      'screenshotUris': [
        'https://www.youtube.com/watch?v=NN75im_us4k'
      ]
    },
    'launchDetails': {
      '/v1/regions/fi-rcs': {}
    }
  }
}"

requestLaunch खाली मैप का इस्तेमाल करने से, एपीआई कॉल के बीच इस्तेमाल किए जाने वाले ऑब्जेक्ट में, इंटरनल एपीआई की एक जैसी सेटिंग बनाए रखने में मदद मिलती है.

curl -X POST \
"https://businesscommunications.googleapis.com/v1/brands/BRAND_ID/agents/AGENT_ID:requestLaunch" \
-H "Content-Type: application/json" \
-H "$(oauth2l header --json PATH_TO_SERVICE_ACCOUNT_KEY businesscommunications)" \
-d "{
  'name': 'brands/BRAND_ID/agents/AGENT_ID/launch',
  'rcsBusinessMessaging': {
    'launchDetails': {
      '/v1/regions/fi-rcs': {},
      '/v1/regions/vodafone-idea-india': {}
    }
  }
}"

अगर कोई एजेंट, requestLaunch तरीके को कॉल करता है, लेकिन उन सभी क्षेत्रों को कुंजियों के तौर पर शामिल नहीं करता जहां एजेंट को पहले से लॉन्च किया गया है, तो 400 - Bad Request गड़बड़ी दिखती है.

किसी एजेंट के लॉन्च का स्टेटस देखना

किसी एजेंट के लॉन्च का मौजूदा स्टेटस वापस पाया जा सकता है. ज़्यादा जानकारी के लिए, देखें brands.agents.getLaunch.

Node.js

const businessCommunicationsApiHelper =
  require('@google/rbm-businesscommunications');

const privateKey =
  require('../../resources/businesscommunications-service-account-credentials.json');

businessCommunicationsApiHelper.initBusinessCommunucationsApi(privateKey);

businessCommunicationsApiHelper.getAgentLaunch(agent.name).then((response) => {

}).catch((err) => {
  console.log(err);
});

Java

AgentLaunch launch = api.getAgentLaunch(agent.getName());
logger.info("RBM agent launch: " + launch);

अगर मोबाइल और इंटरनेट सेवा देने वाली कंपनी, लॉन्च को अस्वीकार कर देती है, तो पार्टनर उस कंपनी के नेटवर्क पर लॉन्च का अनुरोध फिर से कर सकता है. इस अनुरोध का स्टेटस UNSPECIFIED होता है और बैकएंड का स्टेटस REJECTED होता है.

इस कोड से, लॉन्च की जानकारी और हर टारगेट मोबाइल और इंटरनेट सेवा देने वाली कंपनी के लिए लॉन्च का स्टेटस मिलता है:

{
  "name": "brands/40bd963f-ff92-425c-b273-8f0892d2d017/agents/my_new_agent_7jo0trhw_agent/launch",
  "rcsBusinessMessaging": {
    "questionnaire": {
      "contacts": [
        {
          "name": "James Bond",
          "title": "Mr O O 7",
          "email": "someone@somewhere.com"
        }
      ],
      "optinDescription": "Users accepted our terms of service online.",
      "triggerDescription": "We are reaching preregistered users",
      "interactionsDescription": "This agent does not do much.",
      "optoutDescription": "Reply stop and we stop.",
      "agentAccessInstructions": "This is a a simple agent that reaches registered users.",
      "videoUris": [
        "https://www.google.com/a/video"
      ],
      "screenshotUris": [
        "https://www.google.com/a/screenshot"
      ]
    },
    "launchDetails": {
      "/v1/regions/some-carrier": {
        "launchState": "LAUNCH_STATE_PENDING",
        "updateTime": "2023-02-24T15:02:13.903554Z"
      }
    },
    "launchRegion": "NORTH_AMERICA"
  }
}

ध्यान दें कि launchRegion अब काम नहीं करता. इसे जल्द ही हटा दिया जाएगा.

किसी एजेंट के लॉन्च में, मोबाइल और इंटरनेट सेवा देने वाली अन्य कंपनियां जोड़ना

brands.agents.getLaunch एपीआई कॉल का इस्तेमाल करके, अपने एजेंट के लॉन्च की मौजूदा जानकारी पाने के बाद, टारगेट मोबाइल और इंटरनेट सेवा देने वाली अन्य कंपनियां जोड़ी जा सकती हैं. इससे, आपके एजेंट की पहुंच बढ़ाई जा सकती है. ज़्यादा जानकारी के लिए, brands.agents.updateLaunch देखें.

Node.js

const businessCommunicationsApiHelper =
  require('@google/rbm-businesscommunications');

const privateKey =
  require('../../resources/businesscommunications-service-account-credentials.json');

businessCommunicationsApiHelper.initBusinessCommunucationsApi(privateKey);');

// To launch an agent to further carriers, we need to first obtain the existing
// launch information and extend it with the new carrier(s).
businessCommunicationsApiHelper.getAgentLaunch(agent.name).then((response) => {
  let existingLaunch = response.data.rcsBusinessMessaging;

  // Now we add the new carrier to the existing launch
  existingLaunch.launchDetails[config.launchCarrier2] = null;

  // And we submit the launch again
  businessCommunicationsApiHelper.launchAgent(agent.name, existingLaunch).then((response) => {
    console.log('Launch details are:');
    console.log(JSON.stringify(response.data, null, 2));
  }).catch((err) => {
    console.log(err);
  });
}).catch((err) => {
  console.log(err);
});

इस कोड से, लॉन्च की अपडेट की गई जानकारी मिलती है:

{
  "name": "brands/40bd963f-ff92-425c-b273-8f0892d2d017/agents/my_new_agent_7jo0trhw_agent/launch",
  "rcsBusinessMessaging": {
    "questionnaire": {
      "contacts": [
        {
          "name": "James Bond",
          "title": "Mr O O 7",
          "email": "someone@somewhere.com"
        }
      ],
      "optinDescription": "Users accepted our terms of service online.",
      "triggerDescription": "We are reaching preregistered users",
      "interactionsDescription": "This agent does not do much.",
      "optoutDescription": "Reply stop and we stop.",
      "agentAccessInstructions": "This is a a simple agent that reaches registered users.",
      "videoUris": [
        "https://www.google.com/a/video"
      ],
      "screenshotUris": [
        "https://www.google.com/a/screenshot"
      ]
    },
    "launchDetails": {
      "/v1/regions/some-carrier": {
        "launchState": "LAUNCH_STATE_PENDING",
        "updateTime": "2023-02-24T15:02:13.903554Z"
      },
      "/v1/regions/another-carrier": {
        "launchState": "LAUNCH_STATE_PENDING",
        "updateTime": "2023-02-24T15:04:50.456552Z"
      }
    },
    "launchRegion": "NORTH_AMERICA"
  }
}

लॉन्च करने के बाद और रखरखाव

किसी ब्रैंड के लिए बनाए गए सभी एजेंट की सूची देखना

डेवलपर, किसी ब्रैंड के लिए बनाए गए सभी एजेंट की सूची वापस पा सकता है. ज़्यादा जानकारी के लिए, brands.agents.list देखें.

Node.js

const businessCommunicationsApiHelper =
  require('@google/rbm-businesscommunications');

const privateKey =
  require('../../resources/businesscommunications-service-account-credentials.json');

businessCommunicationsApiHelper.initBusinessCommunucationsApi(privateKey);

businessCommunicationsApiHelper.listAgents(brand.name).then((response) => {
  console.log('Current agents are:');
  console.log(response.data);
  datastore.saveJsonData('agents', response.data.agents);
}).catch((err) => {
  console.log(err);
});

Java

Brand brand = api.getBrand(brandId);
logger.info("Brand: " + brand);
ListAgentsResponse response = api.listAllAgents(brand);
List<Agent> agents = response.getAgents().stream()
  .sorted(Comparator.comparing(Agent::getName)).collect(Collectors.toList());
logger.info(String.format("Found %d agents", response.getAgents().size()));
for (Agent agent : agents) {
  logger.info(String.format("Agent [%s]: '%s'", agent.getName(), agent.getDisplayName()));
}

इस कोड से, ब्रैंड के मालिकाना हक वाले सभी एजेंट की सूची मिलती है:

{
  agents: [
    {
      name: 'brands/40bd963f-ff92-425c-b273-8f0892d2d017/agents/my_new_agent_4fpd1psz_agent',
      displayName: 'My new agent',
      rcsBusinessMessagingAgent: [Object]
    },
    {
      name: 'brands/40bd963f-ff92-425c-b273-8f0892d2d017/agents/my_new_agent_ciymyd2b_agent',
      displayName: 'My second agent',
      rcsBusinessMessagingAgent: [Object]
    },
    {
      name: 'brands/40bd963f-ff92-425c-b273-8f0892d2d017/agents/my_new_agent_helof85o_agent',
      displayName: 'My third agent',
      rcsBusinessMessagingAgent: [Object]
    }
  ]
}

संग्रहित किए गए एजेंट शामिल करना

डिफ़ॉल्ट रूप से, सभी एजेंट की सूची में वे एजेंट शामिल नहीं होते जिन्हें पार्टनर ने संग्रहित किया है. नतीजों में संग्रहित किए गए एजेंट शामिल करने के लिए, includeArchived पैरामीटर को true पर सेट करें.

Node.js

`listAgents` तरीके में, संग्रहित किए गए एजेंट शामिल करने के लिए, कॉन्फ़िगरेशन का कोई ऑब्जेक्ट जोड़ा जा सकता है. हालांकि, यह ज़रूरी नहीं है.
const businessCommunicationsApiHelper =
 require('@google/rbm-businesscommunications');

const privateKey =
 require('../../resources/businesscommunications-service-account-credentials.json');

businessCommunicationsApiHelper.initBusinessCommunicationsApi(privateKey);

// To list all agents including archived ones, set includeArchived to true
const listOptions = {
  includeArchived: true
};

businessCommunicationsApiHelper.listAgents(brand.name, listOptions).then((response) => {
 console.log('Current agents (including archived) are:');
 console.log(response.data);
 datastore.saveJsonData('agents', response.data.agents);
}).catch((err) => {
 console.log(err);
});

Java

`listAllAgents` तरीके में, विज़िबिलिटी कंट्रोल के लिए बूलियन पैरामीटर शामिल होता है.
// To list all agents including archived ones, pass 'true' for the includeArchived parameter
boolean includeArchived = true;
Brand brand = api.getBrand(brandId);
logger.info("Brand: " + brand);

// Call listAllAgents with the brand and the includeArchived flag
ListAgentsResponse response = api.listAllAgents(brand, includeArchived);

List agents = response.getAgents().stream()
 .sorted(Comparator.comparing(Agent::getName)).collect(Collectors.toList());

logger.info(String.format("Found %d agents (including archived)", response.getAgents().size()));
for (Agent agent : agents) {
 logger.info(String.format("Agent [%s]: '%s' (Archived: %s)",
    agent.getName(), agent.getDisplayName(), agent.getIsArchived()));
}

किसी एजेंट को लॉन्च से हटाना

किसी एजेंट को किसी खास क्षेत्र से लॉन्च से हटाने के लिए, updateLaunch तरीके को कॉल करें. इसके लिए, कॉल के मैप में टारगेट क्षेत्र तय करें और launchState को LAUNCH_STATE_UNLAUNCHED पर सेट करें.

curl -X PATCH \
"https://businesscommunications.googleapis.com/v1/brands/BRAND_ID/agents/AGENT_ID" \
-H "Content-Type: application/json" \
-H "$(oauth2l header --json PATH_TO_SERVICE_ACCOUNT_KEY businesscommunications)"\
-d "{
  'rcsBusinessMessaging': {
    'launchDetails': {
      '/v1/regions/fi-rcs': {
        'launchState': 'LAUNCH_STATE_UNLAUNCHED'
      },
      '/v1/regions/vodafone-idea-india': {
        'launchState': 'LAUNCH_STATE_UNLAUNCHED'
      }
    }
  }
}"

किसी एजेंट को मिटाना

सुरक्षा कारणों से, अब RBM एजेंट को मिटाया नहीं जा सकता. मदद के लिए, RCS for Business की सहायता टीम से संपर्क करें.

एजेंट को संग्रहित करना या संग्रह से निकालना

साफ़-सुथरा और व्यवस्थित वर्कस्पेस बनाए रखने के लिए, उन एजेंट को संग्रहित किया जा सकता है जिनका अब इस्तेमाल नहीं किया जा रहा है. किसी एजेंट को संग्रहित करने पर, वह डिफ़ॉल्ट एपीआई डिस्कवरी के नतीजों में नहीं दिखता.

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

यह पक्का करने के लिए कि चालू एजेंट गलती से न छिप जाएं, ये नियम लागू होते हैं:

  • ज़रूरी शर्तें: सिर्फ़ उन एजेंट को संग्रहित किया जा सकता है जो चालू नहीं हैं: UNLAUNCHED, SUSPENDED, या REJECTED.
  • पाबंदियां: किसी ऐसे एजेंट को संग्रहित नहीं किया जा सकता जो किसी भी मोबाइल और इंटरनेट सेवा देने वाली कंपनी के नेटवर्क पर LAUNCHED या PENDING है. अगर ऐसे किसी एजेंट को संग्रहित करने की कोशिश की जाती है, तो गड़बड़ी के साथ अनुरोध अस्वीकार कर दिया जाएगा.

संग्रह के स्टेटस को अपडेट करना

किसी एजेंट को संग्रहित करने या संग्रह से निकालने के लिए, पैच तरीके का इस्तेमाल करें. अपडेट किए जा रहे फ़ील्ड को तय करने के लिए, यूआरएल में updateMask=is_archived पैरामीटर शामिल करना ज़रूरी है. संग्रहित करने के लिए, isArchived बूलियन को true पर सेट करें. वहीं, संग्रह से निकालने के लिए, इसे false पर सेट करें.

तरीका: PATCH /v1/brands/{brandId}/agents/{agentId} अपडेट मास्क में is_archived जोड़ें.

{
  "isArchived": true
}

फ़िल्टर के साथ एजेंट की सूची देखना

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

तरीका: GET /v1/brands/{brandId}/agents?include_archived=true