2016-11-08 07:27:32 +00:00
|
|
|
---
|
|
|
|
layout: "google"
|
|
|
|
page_title: "Google: google_service_account"
|
2018-03-05 23:33:16 +00:00
|
|
|
sidebar_current: "docs-google-service-account-x"
|
2016-11-08 07:27:32 +00:00
|
|
|
description: |-
|
2017-02-18 22:48:50 +00:00
|
|
|
Allows management of a Google Cloud Platform service account.
|
2016-11-08 07:27:32 +00:00
|
|
|
---
|
|
|
|
|
|
|
|
# google\_service\_account
|
|
|
|
|
2016-11-17 17:49:22 +00:00
|
|
|
Allows management of a [Google Cloud Platform service account](https://cloud.google.com/compute/docs/access/service-accounts)
|
2016-11-08 07:27:32 +00:00
|
|
|
|
2019-02-19 22:22:12 +00:00
|
|
|
-> Creation of service accounts is eventually consistent, and that can lead to
|
|
|
|
errors when you try to apply ACLs to service accounts immediately after
|
|
|
|
creation. If using these resources in the same config, you can add a
|
|
|
|
[`sleep` using `local-exec`](https://github.com/hashicorp/terraform/issues/17726#issuecomment-377357866).
|
|
|
|
|
2016-11-08 07:27:32 +00:00
|
|
|
## Example Usage
|
|
|
|
|
|
|
|
This snippet creates a service account, then gives it objectViewer
|
|
|
|
permission in a project.
|
|
|
|
|
2017-04-17 10:17:54 +00:00
|
|
|
```hcl
|
2016-11-08 07:27:32 +00:00
|
|
|
resource "google_service_account" "object_viewer" {
|
2017-02-18 22:48:50 +00:00
|
|
|
account_id = "object-viewer"
|
|
|
|
display_name = "Object viewer"
|
2016-11-08 07:27:32 +00:00
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
## Argument Reference
|
|
|
|
|
|
|
|
The following arguments are supported:
|
|
|
|
|
2018-12-14 00:00:26 +00:00
|
|
|
* `account_id` - (Required) The account id that is used to generate the service
|
|
|
|
account email address and a stable unique id. It is unique within a project,
|
|
|
|
must be 6-30 characters long, and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])`
|
|
|
|
to comply with RFC1035. Changing this forces a new service account to be created.
|
2016-11-08 07:27:32 +00:00
|
|
|
|
|
|
|
* `display_name` - (Optional) The display name for the service account.
|
|
|
|
Can be updated without creating a new resource.
|
|
|
|
|
2018-03-12 20:59:47 +00:00
|
|
|
* `project` - (Optional) The ID of the project that the service account will be created in.
|
2016-11-08 07:27:32 +00:00
|
|
|
Defaults to the provider project configuration.
|
|
|
|
|
|
|
|
## Attributes Reference
|
|
|
|
|
|
|
|
In addition to the arguments listed above, the following computed attributes are
|
|
|
|
exported:
|
|
|
|
|
|
|
|
* `email` - The e-mail address of the service account. This value
|
|
|
|
should be referenced from any `google_iam_policy` data sources
|
|
|
|
that would grant the service account privileges.
|
|
|
|
|
|
|
|
* `name` - The fully-qualified name of the service account.
|
|
|
|
|
|
|
|
* `unique_id` - The unique id of the service account.
|
2017-10-25 19:33:21 +00:00
|
|
|
|
|
|
|
## Import
|
|
|
|
|
|
|
|
Service accounts can be imported using their URI, e.g.
|
|
|
|
|
|
|
|
```
|
|
|
|
$ terraform import google_service_account.my_sa projects/my-project/serviceAccounts/my-sa@my-project.iam.gserviceaccount.com
|
|
|
|
```
|