When the principal you are using doesn't have the permissions you need to accomplish your task, or you want to use a service account in a development environment, you can use service account impersonation.
When you use service account impersonation, you start with an authenticated principal (your user account or a service account) and request short-lived credentials for a service account that has the authorization that your use case requires. The authenticated principal must have the necessary permissions to impersonate the service account.
Service account impersonation is more secure than using a service account key because service account impersonation requires a prior authenticated identity, and the credentials that are created by using impersonation do not persist. In comparison, authenticating with a service account key requires no prior authentication, and the persistent key is a high risk credential if exposed.
For more information about service account impersonation, see Service account impersonation.
Before you begin
Before you use service account impersonation, you need to enable the required APIs and ensure that you have the required roles.
Enable APIs
To impersonate a service account, you need to enable the Service Account Credentials API in your project.
Roles required to enable APIs
          To enable APIs, you need the Service Usage Admin IAM
          role (roles/serviceusage.serviceUsageAdmin), which
          contains the serviceusage.services.enable permission. Learn how to grant
          roles.
        
Required roles
    
      To get the permission that
      you need to impersonate a service account,
    
      ask your administrator to grant you the
    
  
  
    
      Service Account Token Creator  (roles/iam.serviceAccountTokenCreator)
     IAM role on the service account.
  
  
  
  
  For more information about granting roles, see Manage access to projects, folders, and organizations.
  
  
      
        This predefined role contains the
         iam.serviceAccounts.getAccessToken
        permission,
         which is required to
        impersonate a service account.
      
    
  
  
    
      
You might also be able to get this permission with custom roles or other predefined roles.
You must grant these roles to your account, even when you are working in a project that you created.
For more information about roles required for impersonation, see Roles for service account authentication.
You can use service account impersonation using the following methods:
- Use the gcloud CLI
- Set up Application Default Credentials for using client libraries
- Generate and manage short-lived credentials
Use the gcloud CLI
The gcloud CLI provides a straightforward way to use service account impersonation. This method works well when you need to use a service account to access Google Cloud resources or services by using the gcloud CLI.
You can impersonate a service account for a specific gcloud CLI command or set up the gcloud CLI to use impersonation for every command automatically.
Use impersonation for a specific gcloud CLI command
To use impersonation for a specific gcloud CLI command, you use the
--impersonate-service-account flag. For example, the
following command lists storage buckets, using the identity and access provided
by the specified service account:
gcloud storage buckets list --impersonate-service-account=SERVICE_ACCT_EMAIL
When you use this flag, the gcloud CLI requests short-lived credentials for the specified service account and uses them to authenticate to the API and authorize the access. The principal that is logged in to the gcloud CLI (usually your user account) must have the required permission on the service account.
Use impersonation with the gcloud CLI by default
To set up the gcloud CLI to use the identity and access provided by a service account by default, you use the gcloud CLI config command:
gcloud config set auth/impersonate_service_account SERVICE_ACCT_EMAIL
With this config property set, the gcloud CLI requests short-lived credentials for the specified service account and uses them to authenticate to the API and authorize the access to the resource for every command. The principal that is logged in to the gcloud CLI must have the required permission on the service account.
Set up Application Default Credentials for using client libraries
You can use service account impersonation to set up a local Application Default Credentials (ADC) file. Client libraries that support impersonation can use those credentials automatically. Local ADC files created by using impersonation are supported in the following languages:
- C#
- Go
- Java
- Node.js
- Python
Use service account impersonation to create a local ADC file:
gcloud auth application-default login --impersonate-service-account SERVICE_ACCT_EMAIL
You can now use client libraries using the supported languages the same way you would after setting up a local ADC file with user credentials. Credentials are automatically found by the authentication libraries. For more information, see Authenticate for using client libraries.
Credentials from a local ADC file generated by using service account impersonation are not supported by all of the authentication libraries. For more information, see Error returned for local credentials from service account impersonation.
Generate and manage short-lived credentials
If neither of the previous methods address your use case, you need to generate and manage short-lived tokens. For example, if you need a different type of short-lived credential (something other than an access token), or if you need to use impersonation in a production environment, use this method.
For information about generating short-lived tokens, see Create short-lived credentials for a service account.
What's next
- Learn more about how ADC finds credentials.
- Explore authentication methods.