node-google-dfp-wrapper
This project is a wrapper around node-google-dfp aimed at facilitating repeated interactions with the DFP API in a script.
Getting started
$ npm install node-google-dfp-wrapper
var Dfp = require('node-google-dfp-wrapper');
var config = require('../local/config')
var credentials = require('../local/application-creds');
var refreshToken = config.refreshToken;
var dfp = new Dfp(credentials, config, refreshToken);
How to use
For examples of how to use this library, please refer to https://github.com/spanishdict/example-dfp-line-item-generator
One-time setup
Configuration
These values are created by you, except for refreshToken
. If you do not have one, follow the directions below.
{
"networkCode": "<network code>",
"appName": "<Name of your app>",
"version": "<version number>",
"refreshToken": "<refresh token>"
}
To obtain your network code from DFP. It can be found in your url after you log in to DFP. For example in https://www.google.com/dfp/1027916#delivery
, the network code is 1027916.
Obtain refresh token
- Run:
$ cd node_modules/node-google-dfp-wrapper/
$ node generate-authentication-url.js
Go to the url and give authorization. Copy the auth code.
- Run the script in "auth code" mode:
$ node generate-refresh-token.js --authCode <auth code>
This will output a refresh token.
DFP project authorization
- Log into Google.
- Go to https://console.developers.google.com/project.
- Make a project for your app.
- Go to <https://console.developers.google.com/apis/credentials?project=.
- Click on
New Credentials
and then on OAuth client ID
- Click on
Configure consent screen
and give your project a name. - Under
Application type
select Other
and give your client a name. - You should now see a new entry under
OAuth 2.0 client IDs
and a download icon to the far right. Click that icon to download your cerdentials. Save the file as local/application-creds.json
. It should look like this, (though you may have to format it):
{
"installed": {
"client_id": "<client id>",
"project_id": "<project id>",
"auth_uri": "https://accounts.google.com/o/oauth2/auth",
"token_uri": "https://accounts.google.com/o/oauth2/token",
"auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs",
"client_secret": "<client secret>",
"redirect_uris": [
"urn:ietf:wg:oauth:2.0:oob",
"oob"
]
}
}