UNPKG

dfp-lib

Version:

This project hosts the Node.JS client library for the SOAP-based DFP API at Google.

54 lines (53 loc) 2.64 kB
"use strict"; var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; const sprintf_js_1 = require("sprintf-js"); const src_1 = require("../../../src"); const config_1 = require("../auth/config"); (function () { return __awaiter(this, void 0, void 0, function* () { const user = new src_1.dfp.DfpUser(config_1.default); user.logAll(); const pqlService = new src_1.dfp.PublisherQueryLanguageService(user); const lineItemStatementBuilder = new src_1.dfp.StatementBuilder() .select('Id, Name, Status') .from('Line_Item') .orderBy('Id ASC') .limit(src_1.dfp.StatementBuilder.SUGGESTED_PAGE_LIMIT); const adUnitStatementBuilder = new src_1.dfp.StatementBuilder() .select('Id, Name') .from('Ad_Unit') .orderBy('Id ASC') .limit(src_1.dfp.StatementBuilder.SUGGESTED_PAGE_LIMIT); yield fetchAndPrintMatchTable("Line Items", lineItemStatementBuilder, pqlService); yield fetchAndPrintMatchTable("Ad Units", adUnitStatementBuilder, pqlService); console.log("DONE"); }); })().catch((err) => console.error(err)); function fetchAndPrintMatchTable(tableName, statementBuilder, pqlService) { return __awaiter(this, void 0, void 0, function* () { while (true) { const resultSet = yield pqlService.select(statementBuilder.toStatement()); let offset = statementBuilder.getOffset() || 0; if (!offset) { console.log(tableName); console.log(src_1.dfp.Pql.getColumnLabels(resultSet)); console.log("------------"); } const rows = resultSet.rows; if (!rows || rows.length < 1) { break; } for (let i = 0, n = rows.length; i < n; ++i) { console.log(sprintf_js_1.sprintf("%d) %s", ++offset, src_1.dfp.Pql.getRowStringValues(rows[i]))); } statementBuilder.increaseOffsetBy(src_1.dfp.StatementBuilder.SUGGESTED_PAGE_LIMIT); } }); }