com.pulumi.keycloak.openid.UserRealmRoleProtocolMapper Maven / Gradle / Ivy
// *** WARNING: this file was generated by pulumi-java-gen. ***
// *** Do not edit by hand unless you're certain you know what you are doing! ***
package com.pulumi.keycloak.openid;
import com.pulumi.core.Output;
import com.pulumi.core.annotations.Export;
import com.pulumi.core.annotations.ResourceType;
import com.pulumi.core.internal.Codegen;
import com.pulumi.keycloak.Utilities;
import com.pulumi.keycloak.openid.UserRealmRoleProtocolMapperArgs;
import com.pulumi.keycloak.openid.inputs.UserRealmRoleProtocolMapperState;
import java.lang.Boolean;
import java.lang.String;
import java.util.Optional;
import javax.annotation.Nullable;
/**
* Allows for creating and managing user realm role protocol mappers within Keycloak.
*
* User realm role protocol mappers allow you to define a claim containing the list of the realm roles.
*
* Protocol mappers can be defined for a single client, or they can be defined for a client scope which can be shared between
* multiple different clients.
*
* ## Example Usage
*
* ### Client)
*
* <!--Start PulumiCodeChooser -->
*
* {@code
* package generated_program;
*
* import com.pulumi.Context;
* import com.pulumi.Pulumi;
* import com.pulumi.core.Output;
* import com.pulumi.keycloak.Realm;
* import com.pulumi.keycloak.RealmArgs;
* import com.pulumi.keycloak.openid.Client;
* import com.pulumi.keycloak.openid.ClientArgs;
* import com.pulumi.keycloak.openid.UserRealmRoleProtocolMapper;
* import com.pulumi.keycloak.openid.UserRealmRoleProtocolMapperArgs;
* 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) {
* var realm = new Realm("realm", RealmArgs.builder()
* .realm("my-realm")
* .enabled(true)
* .build());
*
* var openidClient = new Client("openidClient", ClientArgs.builder()
* .realmId(realm.id())
* .clientId("client")
* .name("client")
* .enabled(true)
* .accessType("CONFIDENTIAL")
* .validRedirectUris("http://localhost:8080/openid-callback")
* .build());
*
* var userRealmRoleMapper = new UserRealmRoleProtocolMapper("userRealmRoleMapper", UserRealmRoleProtocolMapperArgs.builder()
* .realmId(realm.id())
* .clientId(openidClient.id())
* .name("user-realm-role-mapper")
* .claimName("foo")
* .build());
*
* }
* }
* }
*
* <!--End PulumiCodeChooser -->
*
* ### Client Scope)
*
* <!--Start PulumiCodeChooser -->
*
* {@code
* package generated_program;
*
* import com.pulumi.Context;
* import com.pulumi.Pulumi;
* import com.pulumi.core.Output;
* import com.pulumi.keycloak.Realm;
* import com.pulumi.keycloak.RealmArgs;
* import com.pulumi.keycloak.openid.ClientScope;
* import com.pulumi.keycloak.openid.ClientScopeArgs;
* import com.pulumi.keycloak.openid.UserRealmRoleProtocolMapper;
* import com.pulumi.keycloak.openid.UserRealmRoleProtocolMapperArgs;
* 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) {
* var realm = new Realm("realm", RealmArgs.builder()
* .realm("my-realm")
* .enabled(true)
* .build());
*
* var clientScope = new ClientScope("clientScope", ClientScopeArgs.builder()
* .realmId(realm.id())
* .name("test-client-scope")
* .build());
*
* var userRealmRoleMapper = new UserRealmRoleProtocolMapper("userRealmRoleMapper", UserRealmRoleProtocolMapperArgs.builder()
* .realmId(realm.id())
* .clientScopeId(clientScope.id())
* .name("user-realm-role-mapper")
* .claimName("foo")
* .build());
*
* }
* }
* }
*
* <!--End PulumiCodeChooser -->
*
* ## Import
*
* Protocol mappers can be imported using one of the following formats:
*
* - Client: `{{realm_id}}/client/{{client_keycloak_id}}/{{protocol_mapper_id}}`
*
* - Client Scope: `{{realm_id}}/client-scope/{{client_scope_keycloak_id}}/{{protocol_mapper_id}}`
*
* Example:
*
* bash
*
* ```sh
* $ pulumi import keycloak:openid/userRealmRoleProtocolMapper:UserRealmRoleProtocolMapper user_realm_role_mapper my-realm/client/a7202154-8793-4656-b655-1dd18c181e14/71602afa-f7d1-4788-8c49-ef8fd00af0f4
* ```
*
* ```sh
* $ pulumi import keycloak:openid/userRealmRoleProtocolMapper:UserRealmRoleProtocolMapper user_realm_role_mapper my-realm/client-scope/b799ea7e-73ee-4a73-990a-1eafebe8e20a/71602afa-f7d1-4788-8c49-ef8fd00af0f4
* ```
*
*/
@ResourceType(type="keycloak:openid/userRealmRoleProtocolMapper:UserRealmRoleProtocolMapper")
public class UserRealmRoleProtocolMapper extends com.pulumi.resources.CustomResource {
/**
* Indicates if the property should be added as a claim to the access token. Defaults to `true`.
*
*/
@Export(name="addToAccessToken", refs={Boolean.class}, tree="[0]")
private Output* @Nullable */ Boolean> addToAccessToken;
/**
* @return Indicates if the property should be added as a claim to the access token. Defaults to `true`.
*
*/
public Output> addToAccessToken() {
return Codegen.optional(this.addToAccessToken);
}
/**
* Indicates if the property should be added as a claim to the id token. Defaults to `true`.
*
*/
@Export(name="addToIdToken", refs={Boolean.class}, tree="[0]")
private Output* @Nullable */ Boolean> addToIdToken;
/**
* @return Indicates if the property should be added as a claim to the id token. Defaults to `true`.
*
*/
public Output> addToIdToken() {
return Codegen.optional(this.addToIdToken);
}
/**
* Indicates if the property should be added as a claim to the UserInfo response body. Defaults to `true`.
*
*/
@Export(name="addToUserinfo", refs={Boolean.class}, tree="[0]")
private Output* @Nullable */ Boolean> addToUserinfo;
/**
* @return Indicates if the property should be added as a claim to the UserInfo response body. Defaults to `true`.
*
*/
public Output> addToUserinfo() {
return Codegen.optional(this.addToUserinfo);
}
/**
* The name of the claim to insert into a token.
*
*/
@Export(name="claimName", refs={String.class}, tree="[0]")
private Output claimName;
/**
* @return The name of the claim to insert into a token.
*
*/
public Output claimName() {
return this.claimName;
}
/**
* The claim type used when serializing JSON tokens. Can be one of `String`, `JSON`, `long`, `int`, or `boolean`. Defaults to `String`.
*
*/
@Export(name="claimValueType", refs={String.class}, tree="[0]")
private Output* @Nullable */ String> claimValueType;
/**
* @return The claim type used when serializing JSON tokens. Can be one of `String`, `JSON`, `long`, `int`, or `boolean`. Defaults to `String`.
*
*/
public Output> claimValueType() {
return Codegen.optional(this.claimValueType);
}
/**
* The client this protocol mapper should be attached to. Conflicts with `client_scope_id`. One of `client_id` or `client_scope_id` must be specified.
*
*/
@Export(name="clientId", refs={String.class}, tree="[0]")
private Output* @Nullable */ String> clientId;
/**
* @return The client this protocol mapper should be attached to. Conflicts with `client_scope_id`. One of `client_id` or `client_scope_id` must be specified.
*
*/
public Output> clientId() {
return Codegen.optional(this.clientId);
}
/**
* The client scope this protocol mapper should be attached to. Conflicts with `client_id`. One of `client_id` or `client_scope_id` must be specified.
*
*/
@Export(name="clientScopeId", refs={String.class}, tree="[0]")
private Output* @Nullable */ String> clientScopeId;
/**
* @return The client scope this protocol mapper should be attached to. Conflicts with `client_id`. One of `client_id` or `client_scope_id` must be specified.
*
*/
public Output> clientScopeId() {
return Codegen.optional(this.clientScopeId);
}
/**
* Indicates if attribute supports multiple values. If true, then the list of all values of this attribute will be set as claim. If false, then just first value will be set as claim. Defaults to `false`.
*
*/
@Export(name="multivalued", refs={Boolean.class}, tree="[0]")
private Output* @Nullable */ Boolean> multivalued;
/**
* @return Indicates if attribute supports multiple values. If true, then the list of all values of this attribute will be set as claim. If false, then just first value will be set as claim. Defaults to `false`.
*
*/
public Output> multivalued() {
return Codegen.optional(this.multivalued);
}
/**
* The display name of this protocol mapper in the GUI.
*
*/
@Export(name="name", refs={String.class}, tree="[0]")
private Output name;
/**
* @return The display name of this protocol mapper in the GUI.
*
*/
public Output name() {
return this.name;
}
/**
* The realm this protocol mapper exists within.
*
*/
@Export(name="realmId", refs={String.class}, tree="[0]")
private Output realmId;
/**
* @return The realm this protocol mapper exists within.
*
*/
public Output realmId() {
return this.realmId;
}
/**
* A prefix for each Realm Role.
*
*/
@Export(name="realmRolePrefix", refs={String.class}, tree="[0]")
private Output* @Nullable */ String> realmRolePrefix;
/**
* @return A prefix for each Realm Role.
*
*/
public Output> realmRolePrefix() {
return Codegen.optional(this.realmRolePrefix);
}
/**
*
* @param name The _unique_ name of the resulting resource.
*/
public UserRealmRoleProtocolMapper(java.lang.String name) {
this(name, UserRealmRoleProtocolMapperArgs.Empty);
}
/**
*
* @param name The _unique_ name of the resulting resource.
* @param args The arguments to use to populate this resource's properties.
*/
public UserRealmRoleProtocolMapper(java.lang.String name, UserRealmRoleProtocolMapperArgs args) {
this(name, args, null);
}
/**
*
* @param name The _unique_ name of the resulting resource.
* @param args The arguments to use to populate this resource's properties.
* @param options A bag of options that control this resource's behavior.
*/
public UserRealmRoleProtocolMapper(java.lang.String name, UserRealmRoleProtocolMapperArgs args, @Nullable com.pulumi.resources.CustomResourceOptions options) {
super("keycloak:openid/userRealmRoleProtocolMapper:UserRealmRoleProtocolMapper", name, makeArgs(args, options), makeResourceOptions(options, Codegen.empty()), false);
}
private UserRealmRoleProtocolMapper(java.lang.String name, Output id, @Nullable UserRealmRoleProtocolMapperState state, @Nullable com.pulumi.resources.CustomResourceOptions options) {
super("keycloak:openid/userRealmRoleProtocolMapper:UserRealmRoleProtocolMapper", name, state, makeResourceOptions(options, id), false);
}
private static UserRealmRoleProtocolMapperArgs makeArgs(UserRealmRoleProtocolMapperArgs args, @Nullable com.pulumi.resources.CustomResourceOptions options) {
if (options != null && options.getUrn().isPresent()) {
return null;
}
return args == null ? UserRealmRoleProtocolMapperArgs.Empty : args;
}
private static com.pulumi.resources.CustomResourceOptions makeResourceOptions(@Nullable com.pulumi.resources.CustomResourceOptions options, @Nullable Output id) {
var defaultOptions = com.pulumi.resources.CustomResourceOptions.builder()
.version(Utilities.getVersion())
.build();
return com.pulumi.resources.CustomResourceOptions.merge(defaultOptions, options, id);
}
/**
* Get an existing Host resource's state with the given name, ID, and optional extra
* properties used to qualify the lookup.
*
* @param name The _unique_ name of the resulting resource.
* @param id The _unique_ provider ID of the resource to lookup.
* @param state
* @param options Optional settings to control the behavior of the CustomResource.
*/
public static UserRealmRoleProtocolMapper get(java.lang.String name, Output id, @Nullable UserRealmRoleProtocolMapperState state, @Nullable com.pulumi.resources.CustomResourceOptions options) {
return new UserRealmRoleProtocolMapper(name, id, state, options);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy