CompositePrincipal
- class aws_cdk.aws_iam.CompositePrincipal(*principals)
Bases:
PrincipalBase
Represents a principal that has multiple types of principals.
A composite principal cannot have conditions. i.e. multiple ServicePrincipals that form a composite principal
- ExampleMetadata:
infused
Example:
# vpc: ec2.Vpc role = iam.Role(self, "RDSDirectoryServicesRole", assumed_by=iam.CompositePrincipal( iam.ServicePrincipal("rds.amazonaws.com"), iam.ServicePrincipal("directoryservice.rds.amazonaws.com")), managed_policies=[ iam.ManagedPolicy.from_aws_managed_policy_name("service-role/AmazonRDSDirectoryServiceAccess") ] ) instance = rds.DatabaseInstance(self, "Instance", engine=rds.DatabaseInstanceEngine.mysql(version=rds.MysqlEngineVersion.VER_8_0_19), vpc=vpc, domain="d-????????", # The ID of the domain for the instance to join. domain_role=role )
- Parameters:
principals (
IPrincipal
) –
Methods
- add_principals(*principals)
Adds IAM principals to the composite principal.
Composite principals cannot have conditions.
- Parameters:
principals (
IPrincipal
) – IAM principals that will be added to the composite principal.- Return type:
- add_to_assume_role_policy(doc)
Add the principal to the AssumeRolePolicyDocument.
Add the statements to the AssumeRolePolicyDocument necessary to give this principal permissions to assume the given role.
- Parameters:
doc (
PolicyDocument
) –- Return type:
None
- add_to_policy(statement)
Add to the policy of this principal.
- Parameters:
statement (
PolicyStatement
) –- Return type:
bool
- add_to_principal_policy(_statement)
Add to the policy of this principal.
- Parameters:
_statement (
PolicyStatement
) –- Return type:
- dedupe_string()
Return whether or not this principal is equal to the given principal.
- Return type:
Optional
[str
]
- to_json()
JSON-ify the principal.
Used when JSON.stringify() is called
- Return type:
Mapping
[str
,List
[str
]]
- to_string()
Returns a string representation of an object.
- Return type:
str
- with_conditions(conditions)
Returns a new PrincipalWithConditions using this principal as the base, with the passed conditions added.
When there is a value for the same operator and key in both the principal and the conditions parameter, the value from the conditions parameter will be used.
- Parameters:
conditions (
Mapping
[str
,Any
]) –- Return type:
- Returns:
a new PrincipalWithConditions object.
- with_session_tags()
Returns a new principal using this principal as the base, with session tags enabled.
- Return type:
- Returns:
a new SessionTagsPrincipal object.
Attributes
- assume_role_action
When this Principal is used in an AssumeRole policy, the action to use.
- grant_principal
The principal to grant permissions to.
- policy_fragment
Return the policy fragment that identifies this principal in a Policy.
- principal_account
The AWS account ID of this principal.
Can be undefined when the account is not known (for example, for service principals). Can be a Token - in that case, it’s assumed to be AWS::AccountId.
- principals
Returns the principals that make up the CompositePrincipal.