About authorization protocols
Your application must use OAuth 2.0 to authorize requests. No other authorization protocols are supported.
Authorizing requests with OAuth 2.0
The details of the authorization process, or "flow," for OAuth 2.0 vary somewhat depending on what kind of application you're writing. The following general process applies to all application types:
- When you create your application, you register it using the Google Developers Console. Google then provides information you'll need later, such as a client ID and a client secret.
- Activate the Google Compute Engine API in the Google Developers Console. (If the API isn't listed in the Developers Console, then skip this step.)
- When your application needs access to user data, it asks Google for a particular scope of access.
- Google displays a consent screen to the user, asking them to authorize your application to request some of their data.
- If the user approves, then Google gives your application a short-lived access token.
- Your application requests user data, attaching the access token to the request.
- If Google determines that your request and the token are valid, it returns the requested data.
Some flows include additional steps, such as using refresh tokens to acquire new access tokens. For detailed information about flows for various types of applications, see Google's OAuth 2.0 documentation.
Here's the OAuth 2.0 scope information for the Google Compute Engine API:
|https://www.googleapis.com/auth/compute||Read-write access to Google Compute Engine methods.|
|https://www.googleapis.com/auth/compute.readonly||Read-only access to Google Compute Engine methods.|
To request access using OAuth 2.0, your application needs the scope information, as well as information that Google supplies when you register your application (such as the client ID and the client secret).
Tip: The Google APIs client libraries can handle some of the authorization process for you. They are available for a variety of programming languages; check the page with libraries and samples for more details.
If you need to create and add custom images, you also need to provide Google Compute Engine with the scopes to Google Cloud Storage. Google Compute Engine uses Google Cloud Storage to store and retrieve images and can only do so using the proper Google Cloud Storage scopes. The Google Cloud Storage scopes are as follows:
|https://www.googleapis.com/auth/devstorage.read_only||Read-only access to Google Cloud Storage.|
|https://www.googleapis.com/auth/devstorage.write_only||Write-only access to Google Cloud Storage.|
|https://www.googleapis.com/auth/devstorage.read_write||Read and write access to Google Cloud Storage.|
|https://www.googleapis.com/auth/devstorage.full_control||Full control access to Google Cloud Storage.|