This project has been archived and is no longer actively maintained.
This is a project using the Ads Java client library in Google App Engine to create a web application that serves as a playground for DFP API developers. To use the playground, users need to authenticate using OAuth 2.0 and authorize the application to make calls to the DFP API on the user's behalf. For new API developers, if your Google account is not yet associated with any test networks, the playground will allow you to create one after authorization. In the application, you can load various DFP entities in the panels and filter on them using PQL filter statements if you wish.
This project can be used in two ways. You have the option to use Maven as your build and deploy mechanism or simply as jars coupled with the Google Plugin for Eclipse and/or appcfg tool.
This readme assumes you have already registered an AppEngine application. If you have not, please do so first at https://appengine.google.com.
You will also need to register a web OAuth2 application to get a valid client ID and secret. When registering the application, be sure to include the following callbacks:
http://localhost:8888/oauth2callback
https://localhost:8888/oauth2callback
http://test.<your-app-id>.appspot.com/oauth2callback
https://test.<your-app-id>.appspot.com/oauth2callback
http://<your-app-id>.appspot.com/oauth2callback
https://<your-app-id>.appspot.com/oauth2callback
The first callback is intended for local development, the second is for the test version of your app (the default in the web.xml), and the third is for your production application.
In the releases section download a file like dfp-playground-maven-project-v.v.v.tar.gz
and extract it.
The rest of the dependencies will be automatically pulled in using Maven, but you can examine and modify them through the project's pom.xml if you wish.
To build and run the project locally, follow these steps:
-
Modify
Fill in your client ID and client secret in src/main/webapp/WEB-INF/appengine-web.xml You can create the client ID and secret in the API console (https://console.developers.google.com) using the redirect URI below:
http://localhost:8888/oauth2callback https://localhost:8888/oauth2callback
-
Import
Open Eclipse, and import the project by going to File > Import, then General > Existing projects into workspace and selecting the extracted folder.
-
Run (using one of the following methods):
-
From Eclipse
Within the project, open the folder eclipse-launch-profiles. Right-click DevAppServer.launch, and then select Run As > DevAppServer.
The playground will be running at: http://localhost:8888/
-
From the command line
From the root of the project directory, run:
$ mvn appengine:devserver
The playground will be running at: http://localhost:8888/
-
(Optional) Debug
The DevAppServerWithDebugFlag.launch launch profile can be used to launch the server with debug flags so that you can connect a remote debugger.
To do so, open the folder eclipse-launch-profiles. Right-click DevAppServerWithDebugFlag.launch, and then select Run As > DevAppServerWithDebugFlag.
The server will load as usual, but stop with following output:
[INFO] Listening for transport dt_socket at address: 1044
At this point, right-click RemoteDebugDevAppServer.launch, and then select Debug As > RemoteDebugDevAppServer. The server will continue to run until it reaches your breakpoint.
If no source is found, you may have to attach the project manually in the source lookup dialog.
-
Create an App Engine application at https://appengine.google.com/.
-
Follow step 1 from above. Instead of localhost, you will need to add a redirect URI that corresponds to the application ID of your newly created App Engine application:
http://APP_ID.appspot.com/oauth2callback https://APP_ID.appspot.com/oauth2callback
-
Replace the application ID (dfp-playground) in src/main/webapp/WEB-INF/appengine-web.xml with your App Engine application ID
You may also want to update the version to something other than
test
(the default). -
Run the following (you will be prompted for your username and password):
$ mvn appengine:update
Alternatively, you can update the project from within Eclipse by using the UpdateApplication.launch profile. Open the eclipse-launch-profiles folder, right-click UpdateApplication.launch, and then select Run As > UpdateApplication.
In the releases section download a file like dfp-playground-jars-and-google-eclipse-plugin-project-v.v.v.tar.gz
and extract it.
If you are not familiar with the Google Plugin for Eclipse, please read through this getting started guide
-
Modify
Fill in your client ID and client secret in war/WEB-INF/appengine-web.xml You can create the client ID and secret in the API console (https://console.developers.google.com/project) using the redirect URI below:
http://localhost:8888/oauth2callback https://localhost:8888/oauth2callback
-
Import
Open Eclipse, and import the project by going to File > Import, then General > Existing projects into workspace and selecting the extracted folder.
IMPORTANT: The project will not compile at this stage. The next step will complete the process.
-
Setup
Next, add Google AppEngine functionality to the project. Right-click your project and select Google > App Engine Settings. Check the Use Google App Engine box and click OK.
The project should now compile and not have any build errors.
-
Run
Right-click your project and then select Run As > Web Application.
The playground will be running at: http://localhost:8888/
-
Create an App Engine application at https://appengine.google.com/.
-
Follow step 1 from above. Instead of localhost, you will need to add a redirect URI that corresponds to the application ID of your newly created App Engine application:
http://APP_ID.appspot.com/oauth2callback https://APP_ID.appspot.com/oauth2callback
-
Replace the application ID (dfp-playground) in war/WEB-INF/appengine-web.xml with your App Engine application ID
You may also want to update the version to something other than
test
(the default). -
Right-click your project and then select Google > Deploy to AppEngine.
For more information about deploying AppEngine projects, see the developer site.
All of these items can be submitted at https://github.com/googleads/googleads-dfp-java-dfp-playground/issues
Post a question to the forum for the community and API advisors: https://groups.google.com/forum/#!forum/google-doubleclick-for-publishers-api
Authors: Adam Rogal
Past contributors: Jeff Sham