ActiveRoleAssignmentArgs

data class ActiveRoleAssignmentArgs(val justification: Output<String>? = null, val principalId: Output<String>? = null, val roleDefinitionId: Output<String>? = null, val schedule: Output<ActiveRoleAssignmentScheduleArgs>? = null, val scope: Output<String>? = null, val ticket: Output<ActiveRoleAssignmentTicketArgs>? = null) : ConvertibleToJava<ActiveRoleAssignmentArgs>

Manages a PIM Active Role Assignment.

Example Usage

Subscription)

import * as pulumi from "@pulumi/pulumi";
import * as azure from "@pulumi/azure";
import * as time from "@pulumiverse/time";
const primary = azure.core.getSubscription({});
const example = azure.core.getClientConfig({});
const exampleGetRoleDefinition = azure.authorization.getRoleDefinition({
name: "Reader",
});
const exampleStatic = new time.Static("example", {});
const exampleActiveRoleAssignment = new azure.pim.ActiveRoleAssignment("example", {
scope: primary.then(primary => primary.id),
roleDefinitionId: Promise.all([primary, exampleGetRoleDefinition])&#46;then(([primary, exampleGetRoleDefinition]) => `${primary.id}${exampleGetRoleDefinition.id}`),
principalId: example.then(example => example.objectId),
schedule: {
startDateTime: exampleStatic.rfc3339,
expiration: {
durationHours: 8,
},
},
justification: "Expiration Duration Set",
ticket: {
number: "1",
system: "example ticket system",
},
});
import pulumi
import pulumi_azure as azure
import pulumiverse_time as time
primary = azure.core.get_subscription()
example = azure.core.get_client_config()
example_get_role_definition = azure.authorization.get_role_definition(name="Reader")
example_static = time.Static("example")
example_active_role_assignment = azure.pim.ActiveRoleAssignment("example",
scope=primary.id,
role_definition_id=f"{primary.id}{example_get_role_definition.id}",
principal_id=example.object_id,
schedule={
"start_date_time": example_static.rfc3339,
"expiration": {
"duration_hours": 8,
},
},
justification="Expiration Duration Set",
ticket={
"number": "1",
"system": "example ticket system",
})
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using Azure = Pulumi.Azure;
using Time = Pulumiverse.Time;
return await Deployment.RunAsync(() =>
{
var primary = Azure.Core.GetSubscription.Invoke();
var example = Azure.Core.GetClientConfig.Invoke();
var exampleGetRoleDefinition = Azure.Authorization.GetRoleDefinition.Invoke(new()
{
Name = "Reader",
});
var exampleStatic = new Time.Static("example");
var exampleActiveRoleAssignment = new Azure.Pim.ActiveRoleAssignment("example", new()
{
Scope = primary.Apply(getSubscriptionResult => getSubscriptionResult.Id),
RoleDefinitionId = Output.Tuple(primary, exampleGetRoleDefinition).Apply(values =>
{
var primary = values.Item1;
var exampleGetRoleDefinition = values.Item2;
return $"{primary.Apply(getSubscriptionResult => getSubscriptionResult.Id)}{exampleGetRoleDefinition.Apply(getRoleDefinitionResult => getRoleDefinitionResult.Id)}";
}),
PrincipalId = example.Apply(getClientConfigResult => getClientConfigResult.ObjectId),
Schedule = new Azure.Pim.Inputs.ActiveRoleAssignmentScheduleArgs
{
StartDateTime = exampleStatic.Rfc3339,
Expiration = new Azure.Pim.Inputs.ActiveRoleAssignmentScheduleExpirationArgs
{
DurationHours = 8,
},
},
Justification = "Expiration Duration Set",
Ticket = new Azure.Pim.Inputs.ActiveRoleAssignmentTicketArgs
{
Number = "1",
System = "example ticket system",
},
});
});
package main
import (
"fmt"
"github.com/pulumi/pulumi-azure/sdk/v6/go/azure/authorization"
"github.com/pulumi/pulumi-azure/sdk/v6/go/azure/core"
"github.com/pulumi/pulumi-azure/sdk/v6/go/azure/pim"
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
"github.com/pulumiverse/pulumi-time/sdk/go/time"
)
func main() {
pulumi.Run(func(ctx *pulumi.Context) error {
primary, err := core.LookupSubscription(ctx, &core.LookupSubscriptionArgs{}, nil)
if err != nil {
return err
}
example, err := core.GetClientConfig(ctx, map[string]interface{}{}, nil)
if err != nil {
return err
}
exampleGetRoleDefinition, err := authorization.LookupRoleDefinition(ctx, &authorization.LookupRoleDefinitionArgs{
Name: pulumi.StringRef("Reader"),
}, nil)
if err != nil {
return err
}
exampleStatic, err := time.NewStatic(ctx, "example", nil)
if err != nil {
return err
}
_, err = pim.NewActiveRoleAssignment(ctx, "example", &pim.ActiveRoleAssignmentArgs{
Scope: pulumi.String(primary.Id),
RoleDefinitionId: pulumi.Sprintf("%v%v", primary.Id, exampleGetRoleDefinition.Id),
PrincipalId: pulumi.String(example.ObjectId),
Schedule: &pim.ActiveRoleAssignmentScheduleArgs{
StartDateTime: exampleStatic.Rfc3339,
Expiration: &pim.ActiveRoleAssignmentScheduleExpirationArgs{
DurationHours: pulumi.Int(8),
},
},
Justification: pulumi.String("Expiration Duration Set"),
Ticket: &pim.ActiveRoleAssignmentTicketArgs{
Number: pulumi.String("1"),
System: pulumi.String("example ticket system"),
},
})
if err != nil {
return err
}
return nil
})
}
package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.azure.core.CoreFunctions;
import com.pulumi.azure.core.inputs.GetSubscriptionArgs;
import com.pulumi.azure.authorization.AuthorizationFunctions;
import com.pulumi.azure.authorization.inputs.GetRoleDefinitionArgs;
import com.pulumiverse.time.Static;
import com.pulumi.azure.pim.ActiveRoleAssignment;
import com.pulumi.azure.pim.ActiveRoleAssignmentArgs;
import com.pulumi.azure.pim.inputs.ActiveRoleAssignmentScheduleArgs;
import com.pulumi.azure.pim.inputs.ActiveRoleAssignmentScheduleExpirationArgs;
import com.pulumi.azure.pim.inputs.ActiveRoleAssignmentTicketArgs;
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 primary = CoreFunctions.getSubscription(GetSubscriptionArgs.builder()
.build());
final var example = CoreFunctions.getClientConfig(%!v(PANIC=Format method: runtime error: invalid memory address or nil pointer dereference);
final var exampleGetRoleDefinition = AuthorizationFunctions.getRoleDefinition(GetRoleDefinitionArgs.builder()
.name("Reader")
.build());
var exampleStatic = new Static("exampleStatic");
var exampleActiveRoleAssignment = new ActiveRoleAssignment("exampleActiveRoleAssignment", ActiveRoleAssignmentArgs.builder()
.scope(primary.id())
.roleDefinitionId(String.format("%s%s", primary.id(),exampleGetRoleDefinition.id()))
.principalId(example.objectId())
.schedule(ActiveRoleAssignmentScheduleArgs.builder()
.startDateTime(exampleStatic.rfc3339())
.expiration(ActiveRoleAssignmentScheduleExpirationArgs.builder()
.durationHours(8)
.build())
.build())
.justification("Expiration Duration Set")
.ticket(ActiveRoleAssignmentTicketArgs.builder()
.number("1")
.system("example ticket system")
.build())
.build());
}
}
resources:
exampleStatic:
type: time:Static
name: example
exampleActiveRoleAssignment:
type: azure:pim:ActiveRoleAssignment
name: example
properties:
scope: ${primary.id}
roleDefinitionId: ${primary.id}${exampleGetRoleDefinition.id}
principalId: ${example.objectId}
schedule:
startDateTime: ${exampleStatic.rfc3339}
expiration:
durationHours: 8
justification: Expiration Duration Set
ticket:
number: '1'
system: example ticket system
variables:
primary:
fn::invoke:
function: azure:core:getSubscription
arguments: {}
example:
fn::invoke:
function: azure:core:getClientConfig
arguments: {}
exampleGetRoleDefinition:
fn::invoke:
function: azure:authorization:getRoleDefinition
arguments:
name: Reader

Management Group)

import * as pulumi from "@pulumi/pulumi";
import * as azure from "@pulumi/azure";
import * as time from "@pulumiverse/time";
const example = azure.core.getClientConfig({});
const exampleGetRoleDefinition = azure.authorization.getRoleDefinition({
name: "Reader",
});
const exampleGroup = new azure.management.Group("example", {name: "Example-Management-Group"});
const exampleStatic = new time.Static("example", {});
const exampleActiveRoleAssignment = new azure.pim.ActiveRoleAssignment("example", {
scope: exampleGroup.id,
roleDefinitionId: exampleGetRoleDefinition.then(exampleGetRoleDefinition => exampleGetRoleDefinition.id),
principalId: example.then(example => example.objectId),
schedule: {
startDateTime: exampleStatic.rfc3339,
expiration: {
durationHours: 8,
},
},
justification: "Expiration Duration Set",
ticket: {
number: "1",
system: "example ticket system",
},
});
import pulumi
import pulumi_azure as azure
import pulumiverse_time as time
example = azure.core.get_client_config()
example_get_role_definition = azure.authorization.get_role_definition(name="Reader")
example_group = azure.management.Group("example", name="Example-Management-Group")
example_static = time.Static("example")
example_active_role_assignment = azure.pim.ActiveRoleAssignment("example",
scope=example_group.id,
role_definition_id=example_get_role_definition.id,
principal_id=example.object_id,
schedule={
"start_date_time": example_static.rfc3339,
"expiration": {
"duration_hours": 8,
},
},
justification="Expiration Duration Set",
ticket={
"number": "1",
"system": "example ticket system",
})
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using Azure = Pulumi.Azure;
using Time = Pulumiverse.Time;
return await Deployment.RunAsync(() =>
{
var example = Azure.Core.GetClientConfig.Invoke();
var exampleGetRoleDefinition = Azure.Authorization.GetRoleDefinition.Invoke(new()
{
Name = "Reader",
});
var exampleGroup = new Azure.Management.Group("example", new()
{
Name = "Example-Management-Group",
});
var exampleStatic = new Time.Static("example");
var exampleActiveRoleAssignment = new Azure.Pim.ActiveRoleAssignment("example", new()
{
Scope = exampleGroup.Id,
RoleDefinitionId = exampleGetRoleDefinition.Apply(getRoleDefinitionResult => getRoleDefinitionResult.Id),
PrincipalId = example.Apply(getClientConfigResult => getClientConfigResult.ObjectId),
Schedule = new Azure.Pim.Inputs.ActiveRoleAssignmentScheduleArgs
{
StartDateTime = exampleStatic.Rfc3339,
Expiration = new Azure.Pim.Inputs.ActiveRoleAssignmentScheduleExpirationArgs
{
DurationHours = 8,
},
},
Justification = "Expiration Duration Set",
Ticket = new Azure.Pim.Inputs.ActiveRoleAssignmentTicketArgs
{
Number = "1",
System = "example ticket system",
},
});
});
package main
import (
"github.com/pulumi/pulumi-azure/sdk/v6/go/azure/authorization"
"github.com/pulumi/pulumi-azure/sdk/v6/go/azure/core"
"github.com/pulumi/pulumi-azure/sdk/v6/go/azure/management"
"github.com/pulumi/pulumi-azure/sdk/v6/go/azure/pim"
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
"github.com/pulumiverse/pulumi-time/sdk/go/time"
)
func main() {
pulumi.Run(func(ctx *pulumi.Context) error {
example, err := core.GetClientConfig(ctx, map[string]interface{}{}, nil)
if err != nil {
return err
}
exampleGetRoleDefinition, err := authorization.LookupRoleDefinition(ctx, &authorization.LookupRoleDefinitionArgs{
Name: pulumi.StringRef("Reader"),
}, nil)
if err != nil {
return err
}
exampleGroup, err := management.NewGroup(ctx, "example", &management.GroupArgs{
Name: pulumi.String("Example-Management-Group"),
})
if err != nil {
return err
}
exampleStatic, err := time.NewStatic(ctx, "example", nil)
if err != nil {
return err
}
_, err = pim.NewActiveRoleAssignment(ctx, "example", &pim.ActiveRoleAssignmentArgs{
Scope: exampleGroup.ID(),
RoleDefinitionId: pulumi.String(exampleGetRoleDefinition.Id),
PrincipalId: pulumi.String(example.ObjectId),
Schedule: &pim.ActiveRoleAssignmentScheduleArgs{
StartDateTime: exampleStatic.Rfc3339,
Expiration: &pim.ActiveRoleAssignmentScheduleExpirationArgs{
DurationHours: pulumi.Int(8),
},
},
Justification: pulumi.String("Expiration Duration Set"),
Ticket: &pim.ActiveRoleAssignmentTicketArgs{
Number: pulumi.String("1"),
System: pulumi.String("example ticket system"),
},
})
if err != nil {
return err
}
return nil
})
}
package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.azure.core.CoreFunctions;
import com.pulumi.azure.authorization.AuthorizationFunctions;
import com.pulumi.azure.authorization.inputs.GetRoleDefinitionArgs;
import com.pulumi.azure.management.Group;
import com.pulumi.azure.management.GroupArgs;
import com.pulumiverse.time.Static;
import com.pulumi.azure.pim.ActiveRoleAssignment;
import com.pulumi.azure.pim.ActiveRoleAssignmentArgs;
import com.pulumi.azure.pim.inputs.ActiveRoleAssignmentScheduleArgs;
import com.pulumi.azure.pim.inputs.ActiveRoleAssignmentScheduleExpirationArgs;
import com.pulumi.azure.pim.inputs.ActiveRoleAssignmentTicketArgs;
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 = CoreFunctions.getClientConfig(%!v(PANIC=Format method: runtime error: invalid memory address or nil pointer dereference);
final var exampleGetRoleDefinition = AuthorizationFunctions.getRoleDefinition(GetRoleDefinitionArgs.builder()
.name("Reader")
.build());
var exampleGroup = new Group("exampleGroup", GroupArgs.builder()
.name("Example-Management-Group")
.build());
var exampleStatic = new Static("exampleStatic");
var exampleActiveRoleAssignment = new ActiveRoleAssignment("exampleActiveRoleAssignment", ActiveRoleAssignmentArgs.builder()
.scope(exampleGroup.id())
.roleDefinitionId(exampleGetRoleDefinition.id())
.principalId(example.objectId())
.schedule(ActiveRoleAssignmentScheduleArgs.builder()
.startDateTime(exampleStatic.rfc3339())
.expiration(ActiveRoleAssignmentScheduleExpirationArgs.builder()
.durationHours(8)
.build())
.build())
.justification("Expiration Duration Set")
.ticket(ActiveRoleAssignmentTicketArgs.builder()
.number("1")
.system("example ticket system")
.build())
.build());
}
}
resources:
exampleGroup:
type: azure:management:Group
name: example
properties:
name: Example-Management-Group
exampleStatic:
type: time:Static
name: example
exampleActiveRoleAssignment:
type: azure:pim:ActiveRoleAssignment
name: example
properties:
scope: ${exampleGroup.id}
roleDefinitionId: ${exampleGetRoleDefinition.id}
principalId: ${example.objectId}
schedule:
startDateTime: ${exampleStatic.rfc3339}
expiration:
durationHours: 8
justification: Expiration Duration Set
ticket:
number: '1'
system: example ticket system
variables:
example:
fn::invoke:
function: azure:core:getClientConfig
arguments: {}
exampleGetRoleDefinition:
fn::invoke:
function: azure:authorization:getRoleDefinition
arguments:
name: Reader

API Providers

This resource uses the following Azure API Providers:

  • Microsoft.Authorization: 2020-10-01

Import

PIM Active Role Assignments can be imported using the following composite resource ID, e.g.

$ pulumi import azure:pim/activeRoleAssignment:ActiveRoleAssignment example /subscriptions/00000000-0000-0000-0000-000000000000|/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/roleDefinitions/00000000-0000-0000-0000-000000000000|00000000-0000-0000-0000-000000000000

Constructors

Link copied to clipboard
constructor(justification: Output<String>? = null, principalId: Output<String>? = null, roleDefinitionId: Output<String>? = null, schedule: Output<ActiveRoleAssignmentScheduleArgs>? = null, scope: Output<String>? = null, ticket: Output<ActiveRoleAssignmentTicketArgs>? = null)

Properties

Link copied to clipboard
val justification: Output<String>? = null

The justification for the role assignment. Changing this forces a new resource to be created.

Link copied to clipboard
val principalId: Output<String>? = null

Object ID of the principal for this role assignment. Changing this forces a new resource to be created.

Link copied to clipboard
val roleDefinitionId: Output<String>? = null

The role definition ID for this role assignment. Changing this forces a new resource to be created.

Link copied to clipboard

A schedule block as defined below. Changing this forces a new resource to be created.

Link copied to clipboard
val scope: Output<String>? = null

The scope for this role assignment, should be a valid resource ID. Changing this forces a new resource to be created.

Link copied to clipboard

A ticket block as defined below. Changing this forces a new resource to be created.

Functions

Link copied to clipboard
open override fun toJava(): ActiveRoleAssignmentArgs