Skip to content
This repository has been archived by the owner on Feb 17, 2023. It is now read-only.

Sample application illustrating use of the Google Prediction API within the Google App Engine environment

License

Notifications You must be signed in to change notification settings

GoogleCloudPlatform/prediction-try-java-python

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

36 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

prediction-try-java-python

Sample application illustrating use of the Google Prediction API within the Google App Engine environmentTry Prediction (v1.0)

This project provides a complete application illustrating use of the Google Prediction API within the Google App Engine environment. Sample code is provided for both the Java and Python App Engine runtimes, along with resources for CSS, Javascript, images and config data files, all of which are shared across the two runtime environments.

The application presents a simple interactive user experience: select a prediction model, enter a corresponding set of input text and submit your prediction request. For classification models, a graphical response is provided showing the confidence level for each category in the selected model. For regression models, a numerical result is presented.

The set of models supported and the corresponding input fields are entirely dynamic and controlled by a runtime text file (rc/models.json). You can freely add, change or remove models without changing any source code.

Web services in this domain typically provide access to a prediction model via a common set of shared security credentials. In this model, there is no need to force end users to perform the OAuth token granting sequence - authorization of end users is entirely up to the discretion of the application provider. This shared-server authorization model is one of the key elements being illustrated in this sample application.

You can try a live instance of this application at http://try-prediction.appspot.com.

Prerequisites

Before using this project, you should familiarize yourself with the Google Prediction API Developer's Guide and experiment with the "Hello Prediction!" sample exercise. You should have at least one trained model of your own to use with the Try Prediction app.

Dependencies for the Python version:

  • Python 2.5 or later
  • Google App Engine
  • Google Python API Client
  • Command line flags modules for Python
  • HTTP Client Library for Python
  • Google OAuth 2.0 Client Library for Python
  • URI Templates for Python

Dependencies for the Java version:

  • Java 5 (or higher) standard (SE) and enterprise (EE)
  • Google App Engine
  • Maven
  • Maven Plugin for App Engine

Getting Started

  1. Clone this repo into a new directory.

  2. Customize the following files:

- In shared/rc/client_secrets.json, replace the placeholder strings with your actual client id and 
  client secret from the Google APIs console.

- In shared/rc/models.json, enter information about the model(s) you would like to use, following 
  the format shown for the two sample models.

- Java only: edit the file gae-java/src/main/java/com/google/tryPredictionJava/web/IndexServlet.java 
  to specify your redirect URI, which should be your app's base URI + 
  /auth_return, e.g. http://your-app-name.appspot.com/auth_return.

- Add your redirect URI (defined in previous step) to the list of valid 
  redirect URIs in the "API Access" tab of the APIs Console. If you miss 
  this step, you'll get a 'redirect_uri_mismatch' error during initial 
  authorization of the shared server credentials.
  1. Build and deploy your app:
- For Python:
  - Modify the "application:" line in your app.yaml file to
     reflect your chosen app name and use the Google App Engine tools to
     deploy your app.
  - Install google-api-python-client library to your project vendor dir via pip:
     `pip install -t vendor -r requirements.txt`
     Note: this is only required for dev. On production this is done upon deployment

- For Java: modify the contents of the "application" XML element in 
  your gae-java/src/main/webapp/WEB-INF/appengine-web.xml file to 
  reflect your chosen app name and use the Maven plugin for Google 
  App Engine to deploy your app (you need to run "mvn gae:unpack" 
  once and then you can subsequently deploy your app repeatedly 
  with "mvn gae:deploy").
  1. The first time you access your app, it will step you through the login and OAuth 2.0 sequence, however, all access thereafter, by you or anyone else, will reuse your initially established security credentials. If you ever wish to change or re-establish the shared server credentials, simply visit your service's URI with the "/reset" suffix (note that the reset service can only be invoked by the application administrator).

Try Prediction is brought to you by the Google Developer Relations team.

About

Sample application illustrating use of the Google Prediction API within the Google App Engine environment

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •