terraform-provider-google/website/docs/r/google_project_iam_custom_role.html.markdown
The Magician 219bd09496 Mark the deleted field computed in google_project_iam_custom_role (#2619)
<!-- This change is generated by MagicModules. -->
/cc @rileykarson
2018-12-20 17:22:22 -08:00

2.5 KiB

layout page_title sidebar_current description
google Google: google_project_iam_custom_role docs-google-project-iam-custom-role Allows management of a customized Cloud IAM project role.

google_project_iam_custom_role

Allows management of a customized Cloud IAM project role. For more information see the official documentation and API.

~> Warning: Note that custom roles in GCP have the concept of a soft-delete. There are two issues that may arise from this and how roles are propagated. 1) creating a role may involve undeleting and then updating a role with the same name, possibly causing confusing behavior between undelete and update. 2) A deleted role is permanently deleted after 7 days, but it can take up to 30 more days (i.e. between 7 and 37 days after deletion) before the role name is made available again. This means a deleted role that has been deleted for more than 7 days cannot be changed at all by Terraform, and new roles cannot share that name.

Example Usage

This snippet creates a customized IAM role.

resource "google_project_iam_custom_role" "my-custom-role" {
  role_id     = "myCustomRole"
  title       = "My Custom Role"
  description = "A description"
  permissions = ["iam.roles.list", "iam.roles.create", "iam.roles.delete"]
}

Argument Reference

The following arguments are supported:

  • role_id - (Required) The role id to use for this role.

  • title - (Required) A human-readable title for the role.

  • permissions (Required) The names of the permissions this role grants when bound in an IAM policy. At least one permission must be specified.

  • project - (Optional) The project that the service account will be created in. Defaults to the provider project configuration.

  • stage - (Optional) The current launch stage of the role. Defaults to GA. List of possible stages is here.

  • description - (Optional) A human-readable description for the role.

Attributes Reference

In addition to the arguments listed above, the following computed attributes are exported:

  • deleted - (Optional) The current deleted state of the role.

Import

Customized IAM project role can be imported using their URI, e.g.

$ terraform import google_project_iam_custom_role.my-custom-role projects/my-project/roles/myCustomRole