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 Client Libraries
पर जाएं
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;
}
}