Google Cloud v8.23.0 published on Monday, Mar 24, 2025 by Pulumi
gcp.projects.getIamCustomRoles
Explore with Pulumi AI
Get information about Google Cloud IAM Custom Roles from a project.
Note that you must have the roles/iam.roleViewer
.
See the official documentation
and API.
import * as pulumi from "@pulumi/pulumi";
import * as gcp from "@pulumi/gcp";
const example = gcp.projects.getIamCustomRoles({
project: "your-project-id",
showDeleted: true,
view: "FULL",
});
import pulumi
import pulumi_gcp as gcp
example = gcp.projects.get_iam_custom_roles(project="your-project-id",
show_deleted=True,
view="FULL")
package main
import (
"github.com/pulumi/pulumi-gcp/sdk/v8/go/gcp/projects"
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
pulumi.Run(func(ctx *pulumi.Context) error {
_, err := projects.GetIamCustomRoles(ctx, &projects.GetIamCustomRolesArgs{
Project: pulumi.StringRef("your-project-id"),
ShowDeleted: pulumi.BoolRef(true),
View: pulumi.StringRef("FULL"),
}, nil)
if err != nil {
return err
}
return nil
})
}
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using Gcp = Pulumi.Gcp;
return await Deployment.RunAsync(() =>
{
var example = Gcp.Projects.GetIamCustomRoles.Invoke(new()
{
Project = "your-project-id",
ShowDeleted = true,
View = "FULL",
});
});
package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.gcp.projects.ProjectsFunctions;
import com.pulumi.gcp.projects.inputs.GetIamCustomRolesArgs;
import java.util.List;
import java.util.ArrayList;
import java.util.Map;
import java.io.File;
import java.nio.file.Files;
import java.nio.file.Paths;
public class App {
public static void main(String[] args) {
Pulumi.run(App::stack);
}
public static void stack(Context ctx) {
final var example = ProjectsFunctions.getIamCustomRoles(GetIamCustomRolesArgs.builder()
.project("your-project-id")
.showDeleted(true)
.view("FULL")
.build());
}
}
variables:
example:
fn::invoke:
function: gcp:projects:getIamCustomRoles
arguments:
project: your-project-id
showDeleted: true
view: FULL
Using getIamCustomRoles
Two invocation forms are available. The direct form accepts plain arguments and either blocks until the result value is available, or returns a Promise-wrapped result. The output form accepts Input-wrapped arguments and returns an Output-wrapped result.
function getIamCustomRoles(args: GetIamCustomRolesArgs, opts?: InvokeOptions): Promise<GetIamCustomRolesResult>
function getIamCustomRolesOutput(args: GetIamCustomRolesOutputArgs, opts?: InvokeOptions): Output<GetIamCustomRolesResult>
def get_iam_custom_roles(project: Optional[str] = None,
show_deleted: Optional[bool] = None,
view: Optional[str] = None,
opts: Optional[InvokeOptions] = None) -> GetIamCustomRolesResult
def get_iam_custom_roles_output(project: Optional[pulumi.Input[str]] = None,
show_deleted: Optional[pulumi.Input[bool]] = None,
view: Optional[pulumi.Input[str]] = None,
opts: Optional[InvokeOptions] = None) -> Output[GetIamCustomRolesResult]
func GetIamCustomRoles(ctx *Context, args *GetIamCustomRolesArgs, opts ...InvokeOption) (*GetIamCustomRolesResult, error)
func GetIamCustomRolesOutput(ctx *Context, args *GetIamCustomRolesOutputArgs, opts ...InvokeOption) GetIamCustomRolesResultOutput
> Note: This function is named GetIamCustomRoles
in the Go SDK.
public static class GetIamCustomRoles
{
public static Task<GetIamCustomRolesResult> InvokeAsync(GetIamCustomRolesArgs args, InvokeOptions? opts = null)
public static Output<GetIamCustomRolesResult> Invoke(GetIamCustomRolesInvokeArgs args, InvokeOptions? opts = null)
}
public static CompletableFuture<GetIamCustomRolesResult> getIamCustomRoles(GetIamCustomRolesArgs args, InvokeOptions options)
public static Output<GetIamCustomRolesResult> getIamCustomRoles(GetIamCustomRolesArgs args, InvokeOptions options)
fn::invoke:
function: gcp:projects/getIamCustomRoles:getIamCustomRoles
arguments:
# arguments dictionary
The following arguments are supported:
- Project string
- The project were the custom role has been created in. Defaults to the provider project configuration.
- Show
Deleted bool - Include Roles that have been deleted. Defaults to
false
. - View string
- When
"FULL"
is specified, thepermissions
field is returned, which includes a list of all permissions in the role. The default value is"BASIC"
, which does not return thepermissions
.
- Project string
- The project were the custom role has been created in. Defaults to the provider project configuration.
- Show
Deleted bool - Include Roles that have been deleted. Defaults to
false
. - View string
- When
"FULL"
is specified, thepermissions
field is returned, which includes a list of all permissions in the role. The default value is"BASIC"
, which does not return thepermissions
.
- project String
- The project were the custom role has been created in. Defaults to the provider project configuration.
- show
Deleted Boolean - Include Roles that have been deleted. Defaults to
false
. - view String
- When
"FULL"
is specified, thepermissions
field is returned, which includes a list of all permissions in the role. The default value is"BASIC"
, which does not return thepermissions
.
- project string
- The project were the custom role has been created in. Defaults to the provider project configuration.
- show
Deleted boolean - Include Roles that have been deleted. Defaults to
false
. - view string
- When
"FULL"
is specified, thepermissions
field is returned, which includes a list of all permissions in the role. The default value is"BASIC"
, which does not return thepermissions
.
- project str
- The project were the custom role has been created in. Defaults to the provider project configuration.
- show_
deleted bool - Include Roles that have been deleted. Defaults to
false
. - view str
- When
"FULL"
is specified, thepermissions
field is returned, which includes a list of all permissions in the role. The default value is"BASIC"
, which does not return thepermissions
.
- project String
- The project were the custom role has been created in. Defaults to the provider project configuration.
- show
Deleted Boolean - Include Roles that have been deleted. Defaults to
false
. - view String
- When
"FULL"
is specified, thepermissions
field is returned, which includes a list of all permissions in the role. The default value is"BASIC"
, which does not return thepermissions
.
getIamCustomRoles Result
The following output properties are available:
- Id string
- The provider-assigned unique ID for this managed resource.
- Roles
List<Get
Iam Custom Roles Role> - A list of all retrieved custom roles roles. Structure is defined below.
- Project string
- Show
Deleted bool - View string
- Id string
- The provider-assigned unique ID for this managed resource.
- Roles
[]Get
Iam Custom Roles Role - A list of all retrieved custom roles roles. Structure is defined below.
- Project string
- Show
Deleted bool - View string
- id String
- The provider-assigned unique ID for this managed resource.
- roles
List<Get
Iam Custom Roles Role> - A list of all retrieved custom roles roles. Structure is defined below.
- project String
- show
Deleted Boolean - view String
- id string
- The provider-assigned unique ID for this managed resource.
- roles
Get
Iam Custom Roles Role[] - A list of all retrieved custom roles roles. Structure is defined below.
- project string
- show
Deleted boolean - view string
- id str
- The provider-assigned unique ID for this managed resource.
- roles
Sequence[Get
Iam Custom Roles Role] - A list of all retrieved custom roles roles. Structure is defined below.
- project str
- show_
deleted bool - view str
- id String
- The provider-assigned unique ID for this managed resource.
- roles List<Property Map>
- A list of all retrieved custom roles roles. Structure is defined below.
- project String
- show
Deleted Boolean - view String
Supporting Types
GetIamCustomRolesRole
- Deleted bool
- The current deleted state of the role.
- Description string
- A human-readable description for the role.
- Id string
- an identifier for the resource with the format
projects/{{project}}/roles/{{role_id}}
. - Name string
- The name of the role in the format
projects/{{project}}/roles/{{role_id}}
. Likeid
, this field can be used as a reference in other resources such as IAM role bindings. - Permissions List<string>
- The names of the permissions this role grants when bound in an IAM policy.
- Role
Id string - The camel case role id used for this role.
- Stage string
- The current launch stage of the role. List of possible stages is here.
- Title string
- A human-readable title for the role.
- Deleted bool
- The current deleted state of the role.
- Description string
- A human-readable description for the role.
- Id string
- an identifier for the resource with the format
projects/{{project}}/roles/{{role_id}}
. - Name string
- The name of the role in the format
projects/{{project}}/roles/{{role_id}}
. Likeid
, this field can be used as a reference in other resources such as IAM role bindings. - Permissions []string
- The names of the permissions this role grants when bound in an IAM policy.
- Role
Id string - The camel case role id used for this role.
- Stage string
- The current launch stage of the role. List of possible stages is here.
- Title string
- A human-readable title for the role.
- deleted Boolean
- The current deleted state of the role.
- description String
- A human-readable description for the role.
- id String
- an identifier for the resource with the format
projects/{{project}}/roles/{{role_id}}
. - name String
- The name of the role in the format
projects/{{project}}/roles/{{role_id}}
. Likeid
, this field can be used as a reference in other resources such as IAM role bindings. - permissions List<String>
- The names of the permissions this role grants when bound in an IAM policy.
- role
Id String - The camel case role id used for this role.
- stage String
- The current launch stage of the role. List of possible stages is here.
- title String
- A human-readable title for the role.
- deleted boolean
- The current deleted state of the role.
- description string
- A human-readable description for the role.
- id string
- an identifier for the resource with the format
projects/{{project}}/roles/{{role_id}}
. - name string
- The name of the role in the format
projects/{{project}}/roles/{{role_id}}
. Likeid
, this field can be used as a reference in other resources such as IAM role bindings. - permissions string[]
- The names of the permissions this role grants when bound in an IAM policy.
- role
Id string - The camel case role id used for this role.
- stage string
- The current launch stage of the role. List of possible stages is here.
- title string
- A human-readable title for the role.
- deleted bool
- The current deleted state of the role.
- description str
- A human-readable description for the role.
- id str
- an identifier for the resource with the format
projects/{{project}}/roles/{{role_id}}
. - name str
- The name of the role in the format
projects/{{project}}/roles/{{role_id}}
. Likeid
, this field can be used as a reference in other resources such as IAM role bindings. - permissions Sequence[str]
- The names of the permissions this role grants when bound in an IAM policy.
- role_
id str - The camel case role id used for this role.
- stage str
- The current launch stage of the role. List of possible stages is here.
- title str
- A human-readable title for the role.
- deleted Boolean
- The current deleted state of the role.
- description String
- A human-readable description for the role.
- id String
- an identifier for the resource with the format
projects/{{project}}/roles/{{role_id}}
. - name String
- The name of the role in the format
projects/{{project}}/roles/{{role_id}}
. Likeid
, this field can be used as a reference in other resources such as IAM role bindings. - permissions List<String>
- The names of the permissions this role grants when bound in an IAM policy.
- role
Id String - The camel case role id used for this role.
- stage String
- The current launch stage of the role. List of possible stages is here.
- title String
- A human-readable title for the role.
Package Details
- Repository
- Google Cloud (GCP) Classic pulumi/pulumi-gcp
- License
- Apache-2.0
- Notes
- This Pulumi package is based on the
google-beta
Terraform Provider.