Node.js

Google, Ad Manager API के साथ इंटरैक्ट करने के लिए, Node.js क्लाइंट लाइब्रेरी उपलब्ध कराता है.

पूर्वापेक्षा

Node.js क्लाइंट लाइब्रेरी का इस्तेमाल करने के लिए, आपके पास Node.js इंस्टॉल होना चाहिए. ज़्यादा जानकारी के लिए, Node.js® डाउनलोड करें लेख पढ़ें.

क्लाइंट लाइब्रेरी इंस्टॉल करना

शुरू करने के लिए, अपनी पसंद के IDE में एक नया प्रोजेक्ट बनाएं या किसी मौजूदा प्रोजेक्ट में डिपेंडेंसी जोड़ें. Google, क्लाइंट लाइब्रेरी के आर्टफ़ैक्ट को npm पर @google-ads/admanager के तौर पर पब्लिश करता है.

package.json

"dependencies": {
  "@google-ads/admanager": "^0.4.0"
}

कमांड लाइन

npm install @google-ads/admanager

क्रेडेंशियल कॉन्फ़िगर करना

पुष्टि करने के लिए, Node.js क्लाइंट लाइब्रेरी, OAuth2 और ऐप्लिकेशन डिफ़ॉल्ट क्रेडेंशियल (एडीसी) का इस्तेमाल करती है. एडीसी क्रेडेंशियल बनाने और कॉन्फ़िगर करने के लिए, Authentication देखें.

पहला अनुरोध करना

हर सेवा में एक ServiceClient ऑब्जेक्ट होता है. इसमें हर REST तरीके के लिए मेथड होते हैं. हर तरीके के उदाहरण देखने के लिए, GitHub रिपॉज़िटरी googleapis/google-cloud-node देखें. यहां Network ऑब्जेक्ट को पढ़ने का उदाहरण दिया गया है:

// Resource name of the Network
const name = 'networks/NETWORK_CODE'

// Imports the Admanager library
const {NetworkServiceClient} = require('@google-ads/admanager').v1;

// Instantiates a client
const admanagerClient = new NetworkServiceClient();

async function callGetNetwork() {
  // Construct request
  const request = {
    name,
  };

  // Run request
  const response = await admanagerClient.getNetwork(request);
  console.log(response);
}

callGetNetwork();

एचटीटीपी अनुरोधों और जवाबों को लॉग करना

Node.js क्लाइंट लाइब्रेरी, एचटीटीपी अनुरोधों और जवाबों को लॉग करने की सुविधा देती है. डिफ़ॉल्ट रूप से, क्लाइंट लाइब्रेरी लॉगिंग की सुविधा बंद कर देती है.

स्टैंडर्ड आउटपुट में डिफ़ॉल्ट लॉगिंग चालू करने के लिए, एनवायरमेंट वैरिएबल GOOGLE_SDK_NODE_LOGGING को Google API पैकेज के नामों की कॉमा-सेपरेटेड लिस्ट पर सेट करें. सभी Google API के लिए लॉगिंग की सुविधा चालू की जा सकती है. इसके लिए, वैरिएबल की वैल्यू को all पर सेट करें. सभी उपलब्ध क्लाइंट लाइब्रेरी पैकेज के नामों के लिए, Google Cloud Node.js क्लाइंट लाइब्रेरी देखें

Node.js

// Enable logging for the Google Ad Manager API
process.env.GOOGLE_SDK_NODE_LOGGING = 'admanager';

// Enable logging for the Google Ad Manager and pubsub APIs.
process.env.GOOGLE_SDK_NODE_LOGGING = 'admanager,pubsub';

// Enable logging for all Google APIs
process.env.GOOGLE_SDK_NODE_LOGGING = 'all';

Linux या macOS

# Enable logging for the Google Ad Manager API.
export GOOGLE_SDK_NODE_LOGGING=admanager

# Enable logging for the Google Ad Manager and pubsub APIs.
export GOOGLE_SDK_NODE_LOGGING=admanager,pubsub

# Enable logging for all Google APIs
export GOOGLE_SDK_NODE_LOGGING=all

Windows

# Enable logging for the Google Ad Manager API.
set GOOGLE_SDK_NODE_LOGGING=admanager

# Enable logging for the Google Ad Manager and pubsub APIs.
set GOOGLE_SDK_NODE_LOGGING=admanager,pubsub

# Enable logging for all Google APIs
set GOOGLE_SDK_NODE_LOGGING=all

इसके अलावा, लॉगिंग बैकएंड बदला जा सकता है या लॉग इवेंट हुक किए जा सकते हैं. ज़्यादा जानकारी के लिए, Google के लॉगिंग टूल देखें.

गड़बड़ियां ठीक करना

Node.js क्लाइंट लाइब्रेरी में, Ad Manager API से जुड़ी सभी गड़बड़ियां, GaxiosError टाइप का अपवाद दिखाती हैं.

Ad Manager API से जुड़ी गड़बड़ियों में, गड़बड़ी का मैसेज और एक यूनीक requestId वैल्यू शामिल होती है. इसे एपीआई की सहायता टीम को दिया जा सकता है. समस्या हल करने से जुड़ी सहायता पाने के लिए, एपीआई की सहायता टीम से संपर्क करें लेख पढ़ें. यहां दिए गए उदाहरण में, requestId वैल्यू और गड़बड़ी का मैसेज निकाला गया है:

const admanagerClient = new NetworkServiceClient();
try {
  const network = admanagerClient.getNetwork(
    { name: 'networks/NETWORK_CODE' }
  );
  console.log(network);
} catch(e) {
  if (e instanceof GaxiosError) {
    // Load the error
    const apiError = JSON.parse(e.message).error;
    const requestInfoType = 'type.googleapis.com/google.rpc.RequestInfo';
    const requestInfo = apiError.details.find(detail => detail['@type'] === requestInfoType);
    console.error(apiError.status + ' - ' + apiError.message);
    console.error('RequestId: ' + requestInfo.requestId);
  } else {
    throw e;
  }
}