aws-cdk-github-oidc 1.0.0 → 2.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/API.md CHANGED
@@ -22,7 +22,7 @@ new GithubActionsIdentityProvider(scope: Construct, id: string)
22
22
 
23
23
  ##### `scope`<sup>Required</sup> <a name="aws-cdk-github-oidc.GithubActionsIdentityProvider.parameter.scope"></a>
24
24
 
25
- - *Type:* [`@aws-cdk/core.Construct`](#@aws-cdk/core.Construct)
25
+ - *Type:* [`constructs.Construct`](#constructs.Construct)
26
26
 
27
27
  CDK Stack or Construct to which the provider is assigned to.
28
28
 
@@ -49,7 +49,7 @@ GithubActionsIdentityProvider.fromAccount(scope: Construct, id: string)
49
49
 
50
50
  ###### `scope`<sup>Required</sup> <a name="aws-cdk-github-oidc.GithubActionsIdentityProvider.parameter.scope"></a>
51
51
 
52
- - *Type:* [`@aws-cdk/core.Construct`](#@aws-cdk/core.Construct)
52
+ - *Type:* [`constructs.Construct`](#constructs.Construct)
53
53
 
54
54
  CDK Stack or Construct to which the provider is assigned to.
55
55
 
@@ -95,7 +95,7 @@ new GithubActionsRole(scope: Construct, id: string, props: GithubActionsRoleProp
95
95
 
96
96
  ##### `scope`<sup>Required</sup> <a name="aws-cdk-github-oidc.GithubActionsRole.parameter.scope"></a>
97
97
 
98
- - *Type:* [`@aws-cdk/core.Construct`](#@aws-cdk/core.Construct)
98
+ - *Type:* [`constructs.Construct`](#constructs.Construct)
99
99
 
100
100
  ---
101
101
 
@@ -226,7 +226,7 @@ AssumeRole operation will fail.
226
226
  public readonly inlinePolicies: {[ key: string ]: PolicyDocument};
227
227
  ```
228
228
 
229
- - *Type:* {[ key: string ]: [`@aws-cdk/aws-iam.PolicyDocument`](#@aws-cdk/aws-iam.PolicyDocument)}
229
+ - *Type:* {[ key: string ]: [`aws-cdk-lib.aws_iam.PolicyDocument`](#aws-cdk-lib.aws_iam.PolicyDocument)}
230
230
  - *Default:* No policy is inlined in the Role resource.
231
231
 
232
232
  A list of named policies to inline into this role.
@@ -244,7 +244,7 @@ dependencies that could otherwise be introduced).
244
244
  public readonly managedPolicies: IManagedPolicy[];
245
245
  ```
246
246
 
247
- - *Type:* [`@aws-cdk/aws-iam.IManagedPolicy`](#@aws-cdk/aws-iam.IManagedPolicy)[]
247
+ - *Type:* [`aws-cdk-lib.aws_iam.IManagedPolicy`](#aws-cdk-lib.aws_iam.IManagedPolicy)[]
248
248
  - *Default:* No managed policies.
249
249
 
250
250
  A list of managed policies associated with this role.
@@ -260,7 +260,7 @@ You can add managed policies later using
260
260
  public readonly maxSessionDuration: Duration;
261
261
  ```
262
262
 
263
- - *Type:* [`@aws-cdk/core.Duration`](#@aws-cdk/core.Duration)
263
+ - *Type:* [`aws-cdk-lib.Duration`](#aws-cdk-lib.Duration)
264
264
  - *Default:* Duration.hours(1)
265
265
 
266
266
  The maximum session duration that you want to set for the specified role.
@@ -304,7 +304,7 @@ Friendly Names and Paths in IAM User Guide.
304
304
  public readonly permissionsBoundary: IManagedPolicy;
305
305
  ```
306
306
 
307
- - *Type:* [`@aws-cdk/aws-iam.IManagedPolicy`](#@aws-cdk/aws-iam.IManagedPolicy)
307
+ - *Type:* [`aws-cdk-lib.aws_iam.IManagedPolicy`](#aws-cdk-lib.aws_iam.IManagedPolicy)
308
308
  - *Default:* No permissions boundary.
309
309
 
310
310
  AWS supports permissions boundaries for IAM entities (users or roles).
@@ -467,7 +467,7 @@ AssumeRole operation will fail.
467
467
  public readonly inlinePolicies: {[ key: string ]: PolicyDocument};
468
468
  ```
469
469
 
470
- - *Type:* {[ key: string ]: [`@aws-cdk/aws-iam.PolicyDocument`](#@aws-cdk/aws-iam.PolicyDocument)}
470
+ - *Type:* {[ key: string ]: [`aws-cdk-lib.aws_iam.PolicyDocument`](#aws-cdk-lib.aws_iam.PolicyDocument)}
471
471
  - *Default:* No policy is inlined in the Role resource.
472
472
 
473
473
  A list of named policies to inline into this role.
@@ -485,7 +485,7 @@ dependencies that could otherwise be introduced).
485
485
  public readonly managedPolicies: IManagedPolicy[];
486
486
  ```
487
487
 
488
- - *Type:* [`@aws-cdk/aws-iam.IManagedPolicy`](#@aws-cdk/aws-iam.IManagedPolicy)[]
488
+ - *Type:* [`aws-cdk-lib.aws_iam.IManagedPolicy`](#aws-cdk-lib.aws_iam.IManagedPolicy)[]
489
489
  - *Default:* No managed policies.
490
490
 
491
491
  A list of managed policies associated with this role.
@@ -501,7 +501,7 @@ You can add managed policies later using
501
501
  public readonly maxSessionDuration: Duration;
502
502
  ```
503
503
 
504
- - *Type:* [`@aws-cdk/core.Duration`](#@aws-cdk/core.Duration)
504
+ - *Type:* [`aws-cdk-lib.Duration`](#aws-cdk-lib.Duration)
505
505
  - *Default:* Duration.hours(1)
506
506
 
507
507
  The maximum session duration that you want to set for the specified role.
@@ -545,7 +545,7 @@ Friendly Names and Paths in IAM User Guide.
545
545
  public readonly permissionsBoundary: IManagedPolicy;
546
546
  ```
547
547
 
548
- - *Type:* [`@aws-cdk/aws-iam.IManagedPolicy`](#@aws-cdk/aws-iam.IManagedPolicy)
548
+ - *Type:* [`aws-cdk-lib.aws_iam.IManagedPolicy`](#aws-cdk-lib.aws_iam.IManagedPolicy)
549
549
  - *Default:* No permissions boundary.
550
550
 
551
551
  AWS supports permissions boundaries for IAM entities (users or roles).
@@ -590,7 +590,7 @@ Acknowledging IAM Resources in AWS CloudFormation Templates.
590
590
 
591
591
  ### IGithubActionsIdentityProvider <a name="aws-cdk-github-oidc.IGithubActionsIdentityProvider"></a>
592
592
 
593
- - *Extends:* [`@aws-cdk/aws-iam.IOpenIdConnectProvider`](#@aws-cdk/aws-iam.IOpenIdConnectProvider)
593
+ - *Extends:* [`aws-cdk-lib.aws_iam.IOpenIdConnectProvider`](#aws-cdk-lib.aws_iam.IOpenIdConnectProvider)
594
594
 
595
595
  - *Implemented By:* [`aws-cdk-github-oidc.GithubActionsIdentityProvider`](#aws-cdk-github-oidc.GithubActionsIdentityProvider), [`aws-cdk-github-oidc.IGithubActionsIdentityProvider`](#aws-cdk-github-oidc.IGithubActionsIdentityProvider)
596
596
 
@@ -602,12 +602,12 @@ Describes a Github OpenID Connect Identity Provider for AWS IAM.
602
602
  ##### `node`<sup>Required</sup> <a name="aws-cdk-github-oidc.IGithubActionsIdentityProvider.property.node"></a>
603
603
 
604
604
  ```typescript
605
- public readonly node: ConstructNode;
605
+ public readonly node: Node;
606
606
  ```
607
607
 
608
- - *Type:* [`@aws-cdk/core.ConstructNode`](#@aws-cdk/core.ConstructNode)
608
+ - *Type:* [`constructs.Node`](#constructs.Node)
609
609
 
610
- The construct tree node for this construct.
610
+ The tree node.
611
611
 
612
612
  ---
613
613
 
@@ -617,7 +617,7 @@ The construct tree node for this construct.
617
617
  public readonly env: ResourceEnvironment;
618
618
  ```
619
619
 
620
- - *Type:* [`@aws-cdk/core.ResourceEnvironment`](#@aws-cdk/core.ResourceEnvironment)
620
+ - *Type:* [`aws-cdk-lib.ResourceEnvironment`](#aws-cdk-lib.ResourceEnvironment)
621
621
 
622
622
  The environment this resource belongs to.
623
623
 
@@ -636,7 +636,7 @@ that might be different than the stack they were imported into.
636
636
  public readonly stack: Stack;
637
637
  ```
638
638
 
639
- - *Type:* [`@aws-cdk/core.Stack`](#@aws-cdk/core.Stack)
639
+ - *Type:* [`aws-cdk-lib.Stack`](#aws-cdk-lib.Stack)
640
640
 
641
641
  The stack in which this resource is defined.
642
642
 
package/changelog.md ADDED
@@ -0,0 +1,7 @@
1
+
2
+ ## [2.2.0](https://github.com/aripalo/aws-cdk-github-oidc/compare/v2.1.0...v2.2.0) (2022-02-22)
3
+
4
+
5
+ ### Features
6
+
7
+ * upgrade deps ([0eb64f3](https://github.com/aripalo/aws-cdk-github-oidc/commit/0eb64f37a2c982ebda22207d09f99fade4bdd89a))
@@ -1,8 +1,7 @@
1
- import { IManagedPolicy, PolicyDocument } from '@aws-cdk/aws-iam';
2
- import { Duration } from '@aws-cdk/core';
1
+ import { Duration } from 'aws-cdk-lib';
2
+ import { IManagedPolicy, PolicyDocument } from 'aws-cdk-lib/aws-iam';
3
3
  /**
4
4
  * Properties for defining an IAM Role.
5
- *
6
5
  * These are copied fron @aws-cdk/aws-iam, but since JSII does not support
7
6
  * TypeScript <Partial<iam.RoleProps>> (or Omit), we have to do this stupid thing.
8
7
  *
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWFtLXJvbGUtcHJvcHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaWFtLXJvbGUtcHJvcHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIElNYW5hZ2VkUG9saWN5LFxuICBQb2xpY3lEb2N1bWVudCxcbn0gZnJvbSAnQGF3cy1jZGsvYXdzLWlhbSc7XG5pbXBvcnQgeyBEdXJhdGlvbiB9IGZyb20gJ0Bhd3MtY2RrL2NvcmUnO1xuXG5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcbmV4cG9ydCBpbnRlcmZhY2UgUm9sZVByb3BzIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcbiAgcmVhZG9ubHkgZXh0ZXJuYWxJZHM/OiBzdHJpbmdbXTtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG4gIHJlYWRvbmx5IG1hbmFnZWRQb2xpY2llcz86IElNYW5hZ2VkUG9saWN5W107XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG4gIHJlYWRvbmx5IGlubGluZVBvbGljaWVzPzoge1xuICAgIFtuYW1lOiBzdHJpbmddOiBQb2xpY3lEb2N1bWVudDtcbiAgfTtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxuICByZWFkb25seSBwYXRoPzogc3RyaW5nO1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcbiAgcmVhZG9ubHkgcGVybWlzc2lvbnNCb3VuZGFyeT86IElNYW5hZ2VkUG9saWN5O1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxuICByZWFkb25seSByb2xlTmFtZT86IHN0cmluZztcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcbiAgcmVhZG9ubHkgbWF4U2Vzc2lvbkR1cmF0aW9uPzogRHVyYXRpb247XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG4gIHJlYWRvbmx5IGRlc2NyaXB0aW9uPzogc3RyaW5nO1xufVxuIl19
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWFtLXJvbGUtcHJvcHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaWFtLXJvbGUtcHJvcHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IER1cmF0aW9uIH0gZnJvbSAnYXdzLWNkay1saWInO1xuaW1wb3J0IHtcbiAgSU1hbmFnZWRQb2xpY3ksXG4gIFBvbGljeURvY3VtZW50LFxufSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtaWFtJztcblxuXG4vKipcbiAqIFByb3BlcnRpZXMgZm9yIGRlZmluaW5nIGFuIElBTSBSb2xlLlxuICogVGhlc2UgYXJlIGNvcGllZCBmcm9uIEBhd3MtY2RrL2F3cy1pYW0sIGJ1dCBzaW5jZSBKU0lJIGRvZXMgbm90IHN1cHBvcnRcbiAqIFR5cGVTY3JpcHQgPFBhcnRpYWw8aWFtLlJvbGVQcm9wcz4+IChvciBPbWl0KSwgd2UgaGF2ZSB0byBkbyB0aGlzIHN0dXBpZCB0aGluZy5cbiAqXG4gKiBCYXNpY2FsbHkgZXhhY3RseSB0aGUgc2FtZSBhcyBzb3VyY2UsIGJ1dCB3aXRoIGFzc3VtZWRCeSByZW1vdmVkLlxuICpcbiAqIEBzdGFiaWxpdHkgc3RhYmxlXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUm9sZVByb3BzIHtcbiAgLyoqXG4gICAqIExpc3Qgb2YgSURzIHRoYXQgdGhlIHJvbGUgYXNzdW1lciBuZWVkcyB0byBwcm92aWRlIG9uZSBvZiB3aGVuIGFzc3VtaW5nIHRoaXMgcm9sZS5cbiAgICpcbiAgICogSWYgdGhlIGNvbmZpZ3VyZWQgYW5kIHByb3ZpZGVkIGV4dGVybmFsIElEcyBkbyBub3QgbWF0Y2gsIHRoZVxuICAgKiBBc3N1bWVSb2xlIG9wZXJhdGlvbiB3aWxsIGZhaWwuXG4gICAqXG4gICAqIEBkZWZhdWx0IE5vIGV4dGVybmFsIElEIHJlcXVpcmVkXG4gICAqIEBzdGFiaWxpdHkgc3RhYmxlXG4gICAqL1xuICByZWFkb25seSBleHRlcm5hbElkcz86IHN0cmluZ1tdO1xuICAvKipcbiAgICogQSBsaXN0IG9mIG1hbmFnZWQgcG9saWNpZXMgYXNzb2NpYXRlZCB3aXRoIHRoaXMgcm9sZS5cbiAgICpcbiAgICogWW91IGNhbiBhZGQgbWFuYWdlZCBwb2xpY2llcyBsYXRlciB1c2luZ1xuICAgKiBgYWRkTWFuYWdlZFBvbGljeShNYW5hZ2VkUG9saWN5LmZyb21Bd3NNYW5hZ2VkUG9saWN5TmFtZShwb2xpY3lOYW1lKSlgLlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIE5vIG1hbmFnZWQgcG9saWNpZXMuXG4gICAqIEBzdGFiaWxpdHkgc3RhYmxlXG4gICAqL1xuICByZWFkb25seSBtYW5hZ2VkUG9saWNpZXM/OiBJTWFuYWdlZFBvbGljeVtdO1xuICAvKipcbiAgICogQSBsaXN0IG9mIG5hbWVkIHBvbGljaWVzIHRvIGlubGluZSBpbnRvIHRoaXMgcm9sZS5cbiAgICpcbiAgICogVGhlc2UgcG9saWNpZXMgd2lsbCBiZVxuICAgKiBjcmVhdGVkIHdpdGggdGhlIHJvbGUsIHdoZXJlYXMgdGhvc2UgYWRkZWQgYnkgYGBhZGRUb1BvbGljeWBgIGFyZSBhZGRlZFxuICAgKiB1c2luZyBhIHNlcGFyYXRlIENsb3VkRm9ybWF0aW9uIHJlc291cmNlIChhbGxvd2luZyBhIHdheSBhcm91bmQgY2lyY3VsYXJcbiAgICogZGVwZW5kZW5jaWVzIHRoYXQgY291bGQgb3RoZXJ3aXNlIGJlIGludHJvZHVjZWQpLlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIE5vIHBvbGljeSBpcyBpbmxpbmVkIGluIHRoZSBSb2xlIHJlc291cmNlLlxuICAgKiBAc3RhYmlsaXR5IHN0YWJsZVxuICAgKi9cbiAgcmVhZG9ubHkgaW5saW5lUG9saWNpZXM/OiB7XG4gICAgW25hbWU6IHN0cmluZ106IFBvbGljeURvY3VtZW50O1xuICB9O1xuICAvKipcbiAgICogVGhlIHBhdGggYXNzb2NpYXRlZCB3aXRoIHRoaXMgcm9sZS5cbiAgICpcbiAgICogRm9yIGluZm9ybWF0aW9uIGFib3V0IElBTSBwYXRocywgc2VlXG4gICAqIEZyaWVuZGx5IE5hbWVzIGFuZCBQYXRocyBpbiBJQU0gVXNlciBHdWlkZS5cbiAgICpcbiAgICogQGRlZmF1bHQgL1xuICAgKiBAc3RhYmlsaXR5IHN0YWJsZVxuICAgKi9cbiAgcmVhZG9ubHkgcGF0aD86IHN0cmluZztcbiAgLyoqXG4gICAqIEFXUyBzdXBwb3J0cyBwZXJtaXNzaW9ucyBib3VuZGFyaWVzIGZvciBJQU0gZW50aXRpZXMgKHVzZXJzIG9yIHJvbGVzKS5cbiAgICpcbiAgICogQSBwZXJtaXNzaW9ucyBib3VuZGFyeSBpcyBhbiBhZHZhbmNlZCBmZWF0dXJlIGZvciB1c2luZyBhIG1hbmFnZWQgcG9saWN5XG4gICAqIHRvIHNldCB0aGUgbWF4aW11bSBwZXJtaXNzaW9ucyB0aGF0IGFuIGlkZW50aXR5LWJhc2VkIHBvbGljeSBjYW4gZ3JhbnQgdG9cbiAgICogYW4gSUFNIGVudGl0eS4gQW4gZW50aXR5J3MgcGVybWlzc2lvbnMgYm91bmRhcnkgYWxsb3dzIGl0IHRvIHBlcmZvcm0gb25seVxuICAgKiB0aGUgYWN0aW9ucyB0aGF0IGFyZSBhbGxvd2VkIGJ5IGJvdGggaXRzIGlkZW50aXR5LWJhc2VkIHBvbGljaWVzIGFuZCBpdHNcbiAgICogcGVybWlzc2lvbnMgYm91bmRhcmllcy5cbiAgICpcbiAgICogQGRlZmF1bHQgLSBObyBwZXJtaXNzaW9ucyBib3VuZGFyeS5cbiAgICogQHN0YWJpbGl0eSBzdGFibGVcbiAgICogQGxpbmsgaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0lBTS9sYXRlc3QvVXNlckd1aWRlL2FjY2Vzc19wb2xpY2llc19ib3VuZGFyaWVzLmh0bWxcbiAgICovXG4gIHJlYWRvbmx5IHBlcm1pc3Npb25zQm91bmRhcnk/OiBJTWFuYWdlZFBvbGljeTtcbiAgLyoqXG4gICAqIEEgbmFtZSBmb3IgdGhlIElBTSByb2xlLlxuICAgKlxuICAgKiBGb3IgdmFsaWQgdmFsdWVzLCBzZWUgdGhlIFJvbGVOYW1lIHBhcmFtZXRlciBmb3JcbiAgICogdGhlIENyZWF0ZVJvbGUgYWN0aW9uIGluIHRoZSBJQU0gQVBJIFJlZmVyZW5jZS5cbiAgICpcbiAgICogSU1QT1JUQU5UOiBJZiB5b3Ugc3BlY2lmeSBhIG5hbWUsIHlvdSBjYW5ub3QgcGVyZm9ybSB1cGRhdGVzIHRoYXQgcmVxdWlyZVxuICAgKiByZXBsYWNlbWVudCBvZiB0aGlzIHJlc291cmNlLiBZb3UgY2FuIHBlcmZvcm0gdXBkYXRlcyB0aGF0IHJlcXVpcmUgbm8gb3JcbiAgICogc29tZSBpbnRlcnJ1cHRpb24uIElmIHlvdSBtdXN0IHJlcGxhY2UgdGhlIHJlc291cmNlLCBzcGVjaWZ5IGEgbmV3IG5hbWUuXG4gICAqXG4gICAqIElmIHlvdSBzcGVjaWZ5IGEgbmFtZSwgeW91IG11c3Qgc3BlY2lmeSB0aGUgQ0FQQUJJTElUWV9OQU1FRF9JQU0gdmFsdWUgdG9cbiAgICogYWNrbm93bGVkZ2UgeW91ciB0ZW1wbGF0ZSdzIGNhcGFiaWxpdGllcy4gRm9yIG1vcmUgaW5mb3JtYXRpb24sIHNlZVxuICAgKiBBY2tub3dsZWRnaW5nIElBTSBSZXNvdXJjZXMgaW4gQVdTIENsb3VkRm9ybWF0aW9uIFRlbXBsYXRlcy5cbiAgICpcbiAgICogQGRlZmF1bHQgLSBBV1MgQ2xvdWRGb3JtYXRpb24gZ2VuZXJhdGVzIGEgdW5pcXVlIHBoeXNpY2FsIElEIGFuZCB1c2VzIHRoYXQgSURcbiAgICogZm9yIHRoZSByb2xlIG5hbWUuXG4gICAqIEBzdGFiaWxpdHkgc3RhYmxlXG4gICAqL1xuICByZWFkb25seSByb2xlTmFtZT86IHN0cmluZztcbiAgLyoqXG4gICAqIFRoZSBtYXhpbXVtIHNlc3Npb24gZHVyYXRpb24gdGhhdCB5b3Ugd2FudCB0byBzZXQgZm9yIHRoZSBzcGVjaWZpZWQgcm9sZS5cbiAgICpcbiAgICogVGhpcyBzZXR0aW5nIGNhbiBoYXZlIGEgdmFsdWUgZnJvbSAxIGhvdXIgKDM2MDBzZWMpIHRvIDEyICg0MzIwMHNlYykgaG91cnMuXG4gICAqXG4gICAqIEFueW9uZSB3aG8gYXNzdW1lcyB0aGUgcm9sZSBmcm9tIHRoZSBBV1MgQ0xJIG9yIEFQSSBjYW4gdXNlIHRoZVxuICAgKiBEdXJhdGlvblNlY29uZHMgQVBJIHBhcmFtZXRlciBvciB0aGUgZHVyYXRpb24tc2Vjb25kcyBDTEkgcGFyYW1ldGVyIHRvXG4gICAqIHJlcXVlc3QgYSBsb25nZXIgc2Vzc2lvbi4gVGhlIE1heFNlc3Npb25EdXJhdGlvbiBzZXR0aW5nIGRldGVybWluZXMgdGhlXG4gICAqIG1heGltdW0gZHVyYXRpb24gdGhhdCBjYW4gYmUgcmVxdWVzdGVkIHVzaW5nIHRoZSBEdXJhdGlvblNlY29uZHNcbiAgICogcGFyYW1ldGVyLlxuICAgKlxuICAgKiBJZiB1c2VycyBkb24ndCBzcGVjaWZ5IGEgdmFsdWUgZm9yIHRoZSBEdXJhdGlvblNlY29uZHMgcGFyYW1ldGVyLCB0aGVpclxuICAgKiBzZWN1cml0eSBjcmVkZW50aWFscyBhcmUgdmFsaWQgZm9yIG9uZSBob3VyIGJ5IGRlZmF1bHQuIFRoaXMgYXBwbGllcyB3aGVuXG4gICAqIHlvdSB1c2UgdGhlIEFzc3VtZVJvbGUqIEFQSSBvcGVyYXRpb25zIG9yIHRoZSBhc3N1bWUtcm9sZSogQ0xJIG9wZXJhdGlvbnNcbiAgICogYnV0IGRvZXMgbm90IGFwcGx5IHdoZW4geW91IHVzZSB0aG9zZSBvcGVyYXRpb25zIHRvIGNyZWF0ZSBhIGNvbnNvbGUgVVJMLlxuICAgKlxuICAgKiBAZGVmYXVsdCBEdXJhdGlvbi5ob3VycygxKVxuICAgKiBAc3RhYmlsaXR5IHN0YWJsZVxuICAgKiBAbGluayBodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vSUFNL2xhdGVzdC9Vc2VyR3VpZGUvaWRfcm9sZXNfdXNlLmh0bWxcbiAgICovXG4gIHJlYWRvbmx5IG1heFNlc3Npb25EdXJhdGlvbj86IER1cmF0aW9uO1xuICAvKipcbiAgICogQSBkZXNjcmlwdGlvbiBvZiB0aGUgcm9sZS5cbiAgICpcbiAgICogSXQgY2FuIGJlIHVwIHRvIDEwMDAgY2hhcmFjdGVycyBsb25nLlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIE5vIGRlc2NyaXB0aW9uLlxuICAgKiBAc3RhYmlsaXR5IHN0YWJsZVxuICAgKi9cbiAgcmVhZG9ubHkgZGVzY3JpcHRpb24/OiBzdHJpbmc7XG59XG4iXX0=
package/lib/provider.d.ts CHANGED
@@ -1,56 +1,44 @@
1
- import * as iam from '@aws-cdk/aws-iam';
2
- import * as cdk from '@aws-cdk/core';
1
+ import * as iam from 'aws-cdk-lib/aws-iam';
2
+ import { Construct } from 'constructs';
3
3
  /**
4
- * (experimental) Describes a Github OpenID Connect Identity Provider for AWS IAM.
5
- *
6
- * @experimental
4
+ * Describes a Github OpenID Connect Identity Provider for AWS IAM.
7
5
  */
8
6
  export interface IGithubActionsIdentityProvider extends iam.IOpenIdConnectProvider {
9
7
  }
10
8
  /**
11
- * (experimental) Github Actions as OpenID Connect Identity Provider for AWS IAM. There can be only one (per AWS Account).
9
+ * Github Actions as OpenID Connect Identity Provider for AWS IAM.
10
+ * There can be only one (per AWS Account).
12
11
  *
13
12
  * Use `fromAccount` to retrieve a reference to existing Github OIDC provider.
14
13
  *
15
14
  * @see https://docs.github.com/en/actions/deployment/security-hardening-your-deployments/configuring-openid-connect-in-amazon-web-services
16
- * @experimental
17
15
  */
18
16
  export declare class GithubActionsIdentityProvider extends iam.OpenIdConnectProvider implements IGithubActionsIdentityProvider {
19
- /**
20
- * @experimental
21
- */
22
17
  static readonly issuer: string;
23
- /**
24
- * @experimental
25
- */
26
18
  static readonly thumbprints: string[];
27
19
  /**
28
- * (experimental) Retrieve a reference to existing Github OIDC provider in your AWS account.
29
- *
20
+ * Retrieve a reference to existing Github OIDC provider in your AWS account.
30
21
  * An AWS account can only have single Github OIDC provider configured into it,
31
22
  * so internally the reference is made by constructing the ARN from AWS
32
23
  * Account ID & Github issuer URL.
33
24
  *
34
- * @param scope CDK Stack or Construct to which the provider is assigned to.
35
- * @param id CDK Construct ID given to the construct.
25
+ * @param scope CDK Stack or Construct to which the provider is assigned to
26
+ * @param id CDK Construct ID given to the construct
36
27
  * @returns a CDK Construct representing the Github OIDC provider
37
- * @experimental
38
- * @example
39
28
  *
29
+ * @example
40
30
  * GithubActionsIdentityProvider.fromAccount(scope, "GithubProvider");
41
31
  */
42
- static fromAccount(scope: cdk.Construct, id: string): IGithubActionsIdentityProvider;
32
+ static fromAccount(scope: Construct, id: string): IGithubActionsIdentityProvider;
43
33
  /**
44
- * (experimental) Define a new Github OpenID Connect Identity PRovider for AWS IAM.
45
- *
34
+ * Define a new Github OpenID Connect Identity PRovider for AWS IAM.
46
35
  * There can be only one (per AWS Account).
47
36
  *
48
- * @param scope CDK Stack or Construct to which the provider is assigned to.
49
- * @param id CDK Construct ID given to the construct.
50
- * @experimental
51
- * @example
37
+ * @param scope CDK Stack or Construct to which the provider is assigned to
38
+ * @param id CDK Construct ID given to the construct
52
39
  *
40
+ * @example
53
41
  * new GithubActionsIdentityProvider(scope, "GithubProvider");
54
42
  */
55
- constructor(scope: cdk.Construct, id: string);
43
+ constructor(scope: Construct, id: string);
56
44
  }
package/lib/provider.js CHANGED
@@ -3,27 +3,25 @@ var _a;
3
3
  Object.defineProperty(exports, "__esModule", { value: true });
4
4
  exports.GithubActionsIdentityProvider = void 0;
5
5
  const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
- const iam = require("@aws-cdk/aws-iam");
7
- const cdk = require("@aws-cdk/core");
6
+ const cdk = require("aws-cdk-lib");
7
+ const iam = require("aws-cdk-lib/aws-iam");
8
8
  /**
9
- * (experimental) Github Actions as OpenID Connect Identity Provider for AWS IAM. There can be only one (per AWS Account).
9
+ * Github Actions as OpenID Connect Identity Provider for AWS IAM.
10
+ * There can be only one (per AWS Account).
10
11
  *
11
12
  * Use `fromAccount` to retrieve a reference to existing Github OIDC provider.
12
13
  *
13
14
  * @see https://docs.github.com/en/actions/deployment/security-hardening-your-deployments/configuring-openid-connect-in-amazon-web-services
14
- * @experimental
15
15
  */
16
16
  class GithubActionsIdentityProvider extends iam.OpenIdConnectProvider {
17
17
  /**
18
- * (experimental) Define a new Github OpenID Connect Identity PRovider for AWS IAM.
19
- *
18
+ * Define a new Github OpenID Connect Identity PRovider for AWS IAM.
20
19
  * There can be only one (per AWS Account).
21
20
  *
22
- * @param scope CDK Stack or Construct to which the provider is assigned to.
23
- * @param id CDK Construct ID given to the construct.
24
- * @experimental
25
- * @example
21
+ * @param scope CDK Stack or Construct to which the provider is assigned to
22
+ * @param id CDK Construct ID given to the construct
26
23
  *
24
+ * @example
27
25
  * new GithubActionsIdentityProvider(scope, "GithubProvider");
28
26
  */
29
27
  constructor(scope, id) {
@@ -34,18 +32,16 @@ class GithubActionsIdentityProvider extends iam.OpenIdConnectProvider {
34
32
  });
35
33
  }
36
34
  /**
37
- * (experimental) Retrieve a reference to existing Github OIDC provider in your AWS account.
38
- *
35
+ * Retrieve a reference to existing Github OIDC provider in your AWS account.
39
36
  * An AWS account can only have single Github OIDC provider configured into it,
40
37
  * so internally the reference is made by constructing the ARN from AWS
41
38
  * Account ID & Github issuer URL.
42
39
  *
43
- * @param scope CDK Stack or Construct to which the provider is assigned to.
44
- * @param id CDK Construct ID given to the construct.
40
+ * @param scope CDK Stack or Construct to which the provider is assigned to
41
+ * @param id CDK Construct ID given to the construct
45
42
  * @returns a CDK Construct representing the Github OIDC provider
46
- * @experimental
47
- * @example
48
43
  *
44
+ * @example
49
45
  * GithubActionsIdentityProvider.fromAccount(scope, "GithubProvider");
50
46
  */
51
47
  static fromAccount(scope, id) {
@@ -56,16 +52,10 @@ class GithubActionsIdentityProvider extends iam.OpenIdConnectProvider {
56
52
  }
57
53
  exports.GithubActionsIdentityProvider = GithubActionsIdentityProvider;
58
54
  _a = JSII_RTTI_SYMBOL_1;
59
- GithubActionsIdentityProvider[_a] = { fqn: "aws-cdk-github-oidc.GithubActionsIdentityProvider", version: "1.0.0" };
60
- /**
61
- * @experimental
62
- */
55
+ GithubActionsIdentityProvider[_a] = { fqn: "aws-cdk-github-oidc.GithubActionsIdentityProvider", version: "2.2.0" };
63
56
  GithubActionsIdentityProvider.issuer = 'token.actions.githubusercontent.com';
64
- /**
65
- * @experimental
66
- */
67
57
  GithubActionsIdentityProvider.thumbprints = [
68
58
  'a031c46782e6e6c662c2c87c76da9aa62ccabd8e',
69
59
  '6938fd4d98bab03faadb97b34396831e3780aea1',
70
60
  ];
71
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvcHJvdmlkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSx3Q0FBd0M7QUFDeEMscUNBQXFDOzs7Ozs7Ozs7QUFNckMsTUFBYSw2QkFBOEIsU0FBUSxHQUFHLENBQUMscUJBQXFCOzs7Ozs7Ozs7Ozs7O0lBZ0IxRSxZQUFZLEtBQW9CLEVBQUUsRUFBVTtRQUMxQyxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsRUFBRTtZQUNmLEdBQUcsRUFBRSxXQUFXLDZCQUE2QixDQUFDLE1BQU0sRUFBRTtZQUN0RCxXQUFXLEVBQUUsNkJBQTZCLENBQUMsV0FBVztZQUN0RCxTQUFTLEVBQUUsQ0FBQyxtQkFBbUIsQ0FBQztTQUNqQyxDQUFDLENBQUM7SUFDTCxDQUFDOzs7Ozs7Ozs7Ozs7Ozs7O0lBYk0sTUFBTSxDQUFDLFdBQVcsQ0FBQyxLQUFvQixFQUFFLEVBQVU7UUFDeEQsTUFBTSxTQUFTLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUMsT0FBTyxDQUFDO1FBQzlDLE1BQU0sV0FBVyxHQUFHLGdCQUFnQixTQUFTLGtCQUFrQiw2QkFBNkIsQ0FBQyxNQUFNLEVBQUUsQ0FBQztRQUN0RyxPQUFPLEdBQUcsQ0FBQyxxQkFBcUIsQ0FBQyw0QkFBNEIsQ0FBQyxLQUFLLEVBQUUsRUFBRSxFQUFFLFdBQVcsQ0FBQyxDQUFDO0lBQ3hGLENBQUM7O0FBYkgsc0VBdUJDOzs7Ozs7QUFyQndCLG9DQUFNLEdBQVcscUNBQXFDLENBQUM7Ozs7QUFDdkQseUNBQVcsR0FBYTtJQUM3QywwQ0FBMEM7SUFDMUMsMENBQTBDO0NBQzNDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBpYW0gZnJvbSAnQGF3cy1jZGsvYXdzLWlhbSc7XG5pbXBvcnQgKiBhcyBjZGsgZnJvbSAnQGF3cy1jZGsvY29yZSc7XG5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxuZXhwb3J0IGludGVyZmFjZSBJR2l0aHViQWN0aW9uc0lkZW50aXR5UHJvdmlkZXIgZXh0ZW5kcyBpYW0uSU9wZW5JZENvbm5lY3RQcm92aWRlciB7fVxuXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG5leHBvcnQgY2xhc3MgR2l0aHViQWN0aW9uc0lkZW50aXR5UHJvdmlkZXIgZXh0ZW5kcyBpYW0uT3BlbklkQ29ubmVjdFByb3ZpZGVyIGltcGxlbWVudHMgSUdpdGh1YkFjdGlvbnNJZGVudGl0eVByb3ZpZGVyIHtcblxuICBwdWJsaWMgc3RhdGljIHJlYWRvbmx5IGlzc3Vlcjogc3RyaW5nID0gJ3Rva2VuLmFjdGlvbnMuZ2l0aHVidXNlcmNvbnRlbnQuY29tJztcbiAgcHVibGljIHN0YXRpYyByZWFkb25seSB0aHVtYnByaW50czogc3RyaW5nW10gPSBbXG4gICAgJ2EwMzFjNDY3ODJlNmU2YzY2MmMyYzg3Yzc2ZGE5YWE2MmNjYWJkOGUnLFxuICAgICc2OTM4ZmQ0ZDk4YmFiMDNmYWFkYjk3YjM0Mzk2ODMxZTM3ODBhZWExJyxcbiAgXTtcblxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG4gIHB1YmxpYyBzdGF0aWMgZnJvbUFjY291bnQoc2NvcGU6IGNkay5Db25zdHJ1Y3QsIGlkOiBzdHJpbmcpOiBJR2l0aHViQWN0aW9uc0lkZW50aXR5UHJvdmlkZXIge1xuICAgIGNvbnN0IGFjY291bnRJZCA9IGNkay5TdGFjay5vZihzY29wZSkuYWNjb3VudDtcbiAgICBjb25zdCBwcm92aWRlckFybiA9IGBhcm46YXdzOmlhbTo6JHthY2NvdW50SWR9Om9pZGMtcHJvdmlkZXIvJHtHaXRodWJBY3Rpb25zSWRlbnRpdHlQcm92aWRlci5pc3N1ZXJ9YDtcbiAgICByZXR1cm4gaWFtLk9wZW5JZENvbm5lY3RQcm92aWRlci5mcm9tT3BlbklkQ29ubmVjdFByb3ZpZGVyQXJuKHNjb3BlLCBpZCwgcHJvdmlkZXJBcm4pO1xuICB9XG5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBjZGsuQ29uc3RydWN0LCBpZDogc3RyaW5nKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkLCB7XG4gICAgICB1cmw6IGBodHRwczovLyR7R2l0aHViQWN0aW9uc0lkZW50aXR5UHJvdmlkZXIuaXNzdWVyfWAsXG4gICAgICB0aHVtYnByaW50czogR2l0aHViQWN0aW9uc0lkZW50aXR5UHJvdmlkZXIudGh1bWJwcmludHMsXG4gICAgICBjbGllbnRJZHM6IFsnc3RzLmFtYXpvbmF3cy5jb20nXSxcbiAgICB9KTtcbiAgfVxufVxuIl19
61
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvcHJvdmlkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxtQ0FBbUM7QUFDbkMsMkNBQTJDO0FBUTNDOzs7Ozs7O0dBT0c7QUFDSCxNQUFhLDZCQUE4QixTQUFRLEdBQUcsQ0FBQyxxQkFBcUI7SUEyQjFFOzs7Ozs7Ozs7T0FTRztJQUNILFlBQVksS0FBZ0IsRUFBRSxFQUFVO1FBQ3RDLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxFQUFFO1lBQ2YsR0FBRyxFQUFFLFdBQVcsNkJBQTZCLENBQUMsTUFBTSxFQUFFO1lBQ3RELFdBQVcsRUFBRSw2QkFBNkIsQ0FBQyxXQUFXO1lBQ3RELFNBQVMsRUFBRSxDQUFDLG1CQUFtQixDQUFDO1NBQ2pDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFuQ0Q7Ozs7Ozs7Ozs7OztPQVlHO0lBQ0ksTUFBTSxDQUFDLFdBQVcsQ0FBQyxLQUFnQixFQUFFLEVBQVU7UUFDcEQsTUFBTSxTQUFTLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUMsT0FBTyxDQUFDO1FBQzlDLE1BQU0sV0FBVyxHQUFHLGdCQUFnQixTQUFTLGtCQUFrQiw2QkFBNkIsQ0FBQyxNQUFNLEVBQUUsQ0FBQztRQUN0RyxPQUFPLEdBQUcsQ0FBQyxxQkFBcUIsQ0FBQyw0QkFBNEIsQ0FBQyxLQUFLLEVBQUUsRUFBRSxFQUFFLFdBQVcsQ0FBQyxDQUFDO0lBQ3hGLENBQUM7O0FBekJILHNFQTRDQzs7O0FBMUN3QixvQ0FBTSxHQUFXLHFDQUFxQyxDQUFDO0FBQ3ZELHlDQUFXLEdBQWE7SUFDN0MsMENBQTBDO0lBQzFDLDBDQUEwQztDQUMzQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgY2RrIGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCAqIGFzIGlhbSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtaWFtJztcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xuXG4vKipcbiAqIERlc2NyaWJlcyBhIEdpdGh1YiBPcGVuSUQgQ29ubmVjdCBJZGVudGl0eSBQcm92aWRlciBmb3IgQVdTIElBTS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBJR2l0aHViQWN0aW9uc0lkZW50aXR5UHJvdmlkZXIgZXh0ZW5kcyBpYW0uSU9wZW5JZENvbm5lY3RQcm92aWRlciB7fVxuXG4vKipcbiAqIEdpdGh1YiBBY3Rpb25zIGFzIE9wZW5JRCBDb25uZWN0IElkZW50aXR5IFByb3ZpZGVyIGZvciBBV1MgSUFNLlxuICogVGhlcmUgY2FuIGJlIG9ubHkgb25lIChwZXIgQVdTIEFjY291bnQpLlxuICpcbiAqIFVzZSBgZnJvbUFjY291bnRgIHRvIHJldHJpZXZlIGEgcmVmZXJlbmNlIHRvIGV4aXN0aW5nIEdpdGh1YiBPSURDIHByb3ZpZGVyLlxuICpcbiAqIEBzZWUgaHR0cHM6Ly9kb2NzLmdpdGh1Yi5jb20vZW4vYWN0aW9ucy9kZXBsb3ltZW50L3NlY3VyaXR5LWhhcmRlbmluZy15b3VyLWRlcGxveW1lbnRzL2NvbmZpZ3VyaW5nLW9wZW5pZC1jb25uZWN0LWluLWFtYXpvbi13ZWItc2VydmljZXNcbiAqL1xuZXhwb3J0IGNsYXNzIEdpdGh1YkFjdGlvbnNJZGVudGl0eVByb3ZpZGVyIGV4dGVuZHMgaWFtLk9wZW5JZENvbm5lY3RQcm92aWRlciBpbXBsZW1lbnRzIElHaXRodWJBY3Rpb25zSWRlbnRpdHlQcm92aWRlciB7XG5cbiAgcHVibGljIHN0YXRpYyByZWFkb25seSBpc3N1ZXI6IHN0cmluZyA9ICd0b2tlbi5hY3Rpb25zLmdpdGh1YnVzZXJjb250ZW50LmNvbSc7XG4gIHB1YmxpYyBzdGF0aWMgcmVhZG9ubHkgdGh1bWJwcmludHM6IHN0cmluZ1tdID0gW1xuICAgICdhMDMxYzQ2NzgyZTZlNmM2NjJjMmM4N2M3NmRhOWFhNjJjY2FiZDhlJyxcbiAgICAnNjkzOGZkNGQ5OGJhYjAzZmFhZGI5N2IzNDM5NjgzMWUzNzgwYWVhMScsXG4gIF07XG5cbiAgLyoqXG4gICAqIFJldHJpZXZlIGEgcmVmZXJlbmNlIHRvIGV4aXN0aW5nIEdpdGh1YiBPSURDIHByb3ZpZGVyIGluIHlvdXIgQVdTIGFjY291bnQuXG4gICAqIEFuIEFXUyBhY2NvdW50IGNhbiBvbmx5IGhhdmUgc2luZ2xlIEdpdGh1YiBPSURDIHByb3ZpZGVyIGNvbmZpZ3VyZWQgaW50byBpdCxcbiAgICogc28gaW50ZXJuYWxseSB0aGUgcmVmZXJlbmNlIGlzIG1hZGUgYnkgY29uc3RydWN0aW5nIHRoZSBBUk4gZnJvbSBBV1NcbiAgICogQWNjb3VudCBJRCAmIEdpdGh1YiBpc3N1ZXIgVVJMLlxuICAgKlxuICAgKiBAcGFyYW0gc2NvcGUgQ0RLIFN0YWNrIG9yIENvbnN0cnVjdCB0byB3aGljaCB0aGUgcHJvdmlkZXIgaXMgYXNzaWduZWQgdG9cbiAgICogQHBhcmFtIGlkIENESyBDb25zdHJ1Y3QgSUQgZ2l2ZW4gdG8gdGhlIGNvbnN0cnVjdFxuICAgKiBAcmV0dXJucyBhIENESyBDb25zdHJ1Y3QgcmVwcmVzZW50aW5nIHRoZSBHaXRodWIgT0lEQyBwcm92aWRlclxuICAgKlxuICAgKiBAZXhhbXBsZVxuICAgKiBHaXRodWJBY3Rpb25zSWRlbnRpdHlQcm92aWRlci5mcm9tQWNjb3VudChzY29wZSwgXCJHaXRodWJQcm92aWRlclwiKTtcbiAgICovXG4gIHB1YmxpYyBzdGF0aWMgZnJvbUFjY291bnQoc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZyk6IElHaXRodWJBY3Rpb25zSWRlbnRpdHlQcm92aWRlciB7XG4gICAgY29uc3QgYWNjb3VudElkID0gY2RrLlN0YWNrLm9mKHNjb3BlKS5hY2NvdW50O1xuICAgIGNvbnN0IHByb3ZpZGVyQXJuID0gYGFybjphd3M6aWFtOjoke2FjY291bnRJZH06b2lkYy1wcm92aWRlci8ke0dpdGh1YkFjdGlvbnNJZGVudGl0eVByb3ZpZGVyLmlzc3Vlcn1gO1xuICAgIHJldHVybiBpYW0uT3BlbklkQ29ubmVjdFByb3ZpZGVyLmZyb21PcGVuSWRDb25uZWN0UHJvdmlkZXJBcm4oc2NvcGUsIGlkLCBwcm92aWRlckFybik7XG4gIH1cblxuICAvKipcbiAgICogRGVmaW5lIGEgbmV3IEdpdGh1YiBPcGVuSUQgQ29ubmVjdCBJZGVudGl0eSBQUm92aWRlciBmb3IgQVdTIElBTS5cbiAgICogVGhlcmUgY2FuIGJlIG9ubHkgb25lIChwZXIgQVdTIEFjY291bnQpLlxuICAgKlxuICAgKiBAcGFyYW0gc2NvcGUgQ0RLIFN0YWNrIG9yIENvbnN0cnVjdCB0byB3aGljaCB0aGUgcHJvdmlkZXIgaXMgYXNzaWduZWQgdG9cbiAgICogQHBhcmFtIGlkIENESyBDb25zdHJ1Y3QgSUQgZ2l2ZW4gdG8gdGhlIGNvbnN0cnVjdFxuICAgKlxuICAgKiBAZXhhbXBsZVxuICAgKiBuZXcgR2l0aHViQWN0aW9uc0lkZW50aXR5UHJvdmlkZXIoc2NvcGUsIFwiR2l0aHViUHJvdmlkZXJcIik7XG4gICAqL1xuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkLCB7XG4gICAgICB1cmw6IGBodHRwczovLyR7R2l0aHViQWN0aW9uc0lkZW50aXR5UHJvdmlkZXIuaXNzdWVyfWAsXG4gICAgICB0aHVtYnByaW50czogR2l0aHViQWN0aW9uc0lkZW50aXR5UHJvdmlkZXIudGh1bWJwcmludHMsXG4gICAgICBjbGllbnRJZHM6IFsnc3RzLmFtYXpvbmF3cy5jb20nXSxcbiAgICB9KTtcbiAgfVxufVxuIl19
package/lib/role.d.ts CHANGED
@@ -1,67 +1,58 @@
1
- import * as iam from '@aws-cdk/aws-iam';
2
- import * as cdk from '@aws-cdk/core';
1
+ import * as iam from 'aws-cdk-lib/aws-iam';
2
+ import { Construct } from 'constructs';
3
3
  import { RoleProps } from './iam-role-props';
4
4
  import { IGithubActionsIdentityProvider } from './provider';
5
5
  /**
6
- * (experimental) Github related configuration that forms the trust policy for this IAM Role.
7
- *
8
- * @experimental
6
+ * Github related configuration that forms the trust policy for this IAM Role.
9
7
  */
10
8
  export interface GithubConfiguration {
11
9
  /**
12
- * (experimental) Reference to Github OpenID Connect Provider configured in AWS IAM.
10
+ * Reference to Github OpenID Connect Provider configured in AWS IAM.
13
11
  *
14
12
  * Either pass an construct defined by `new GithubActionsIdentityProvider`
15
13
  * or a retrieved reference from `GithubActionsIdentityProvider.fromAccount`.
16
14
  * There can be only one (per AWS Account).
17
- *
18
- * @experimental
19
15
  */
20
16
  readonly provider: IGithubActionsIdentityProvider;
21
17
  /**
22
- * (experimental) Repository owner (organization or username).
18
+ * Repository owner (organization or username).
23
19
  *
24
- * @experimental
25
20
  * @example
26
- *
27
21
  * 'octo-org'
28
22
  */
29
23
  readonly owner: string;
30
24
  /**
31
- * (experimental) Repository name (slug) without the owner.
25
+ * Repository name (slug) without the owner.
32
26
  *
33
- * @experimental
34
27
  * @example
35
- *
36
28
  * 'octo-repo'
37
29
  */
38
30
  readonly repo: string;
39
31
  /**
40
- * (experimental) Subject condition filter, appended after `repo:${owner}/${repo}:` string in IAM Role trust relationship.
32
+ * Subject condition filter, appended after `repo:${owner}/${repo}:` string in IAM Role trust relationship.
41
33
  *
42
- * @default '*'
34
+ * @default
35
+ * '*'
43
36
  *
44
37
  * You may use this value to only allow Github to assume the role on specific branches, tags, environments, pull requests etc.
45
- * @see https://docs.github.com/en/actions/deployment/security-hardening-your-deployments/about-security-hardening-with-openid-connect#examples
46
- * @experimental
47
38
  * @example
48
- *
49
39
  * 'ref:refs/tags/v*'
50
40
  * 'ref:refs/heads/demo-branch'
51
41
  * 'pull_request'
52
42
  * 'environment:Production'
43
+ *
44
+ * @see https://docs.github.com/en/actions/deployment/security-hardening-your-deployments/about-security-hardening-with-openid-connect#examples
53
45
  */
54
46
  readonly filter?: string;
55
47
  }
56
48
  /**
57
- * (experimental) Props that define the IAM Role that can be assumed by Github Actions workflow via Github OpenID Connect Identity Provider.
49
+ * Props that define the IAM Role that can be assumed by Github Actions workflow
50
+ * via Github OpenID Connect Identity Provider.
58
51
  *
59
52
  * Besides `GithubConfiguration`, you may pass in any `iam.RoleProps` except `assumedBy`
60
53
  * which will be defined by this construct (CDK will fail if you do).
61
54
  *
62
- * @experimental
63
55
  * @example
64
- *
65
56
  * {
66
57
  * provider: GithubActionsIdentityProvider.fromAccount(scope, "GithubProvider"),
67
58
  * owner: 'octo-org',
@@ -73,14 +64,13 @@ export interface GithubConfiguration {
73
64
  export interface GithubActionsRoleProps extends GithubConfiguration, RoleProps {
74
65
  }
75
66
  /**
76
- * (experimental) Define an IAM Role that can be assumed by Github Actions workflow via Github OpenID Connect Identity Provider.
67
+ * Define an IAM Role that can be assumed by Github Actions workflow
68
+ * via Github OpenID Connect Identity Provider.
77
69
  *
78
70
  * Besides `GithubConfiguration`, you may pass in any `iam.RoleProps` except `assumedBy`
79
71
  * which will be defined by this construct (CDK will fail if you do).
80
72
  *
81
- * @experimental
82
73
  * @example
83
- *
84
74
  * const uploadRole = new GithubActionsRole(scope, "UploadRole", {
85
75
  * provider: GithubActionsIdentityProvider.fromAccount(scope, "GithubProvider"),
86
76
  * owner: 'octo-org',
@@ -105,14 +95,13 @@ export declare class GithubActionsRole extends iam.Role {
105
95
  /** Formats the `sub` value used in trust policy. */
106
96
  private static formatSubject;
107
97
  /**
108
- * (experimental) Define an IAM Role that can be assumed by Github Actions workflow via Github OpenID Connect Identity Provider.
98
+ * Define an IAM Role that can be assumed by Github Actions workflow
99
+ * via Github OpenID Connect Identity Provider.
109
100
  *
110
101
  * Besides `GithubConfiguration`, you may pass in any `iam.RoleProps` except `assumedBy`
111
102
  * which will be defined by this construct (CDK will fail if you do).
112
103
  *
113
- * @experimental
114
104
  * @example
115
- *
116
105
  * const uploadRole = new GithubActionsRole(scope, "UploadRole", {
117
106
  * provider: GithubActionsIdentityProvider.fromAccount(scope, "GithubProvider"),
118
107
  * owner: 'octo-org',
@@ -123,5 +112,5 @@ export declare class GithubActionsRole extends iam.Role {
123
112
  *
124
113
  * myBucket.grantWrite(uploadRole);
125
114
  */
126
- constructor(scope: cdk.Construct, id: string, props: GithubActionsRoleProps);
115
+ constructor(scope: Construct, id: string, props: GithubActionsRoleProps);
127
116
  }
package/lib/role.js CHANGED
@@ -3,19 +3,18 @@ var _a;
3
3
  Object.defineProperty(exports, "__esModule", { value: true });
4
4
  exports.GithubActionsRole = void 0;
5
5
  const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
- const iam = require("@aws-cdk/aws-iam");
7
- const cdk = require("@aws-cdk/core");
6
+ const cdk = require("aws-cdk-lib");
7
+ const iam = require("aws-cdk-lib/aws-iam");
8
8
  const owner_regexp_1 = require("./owner-regexp");
9
9
  const provider_1 = require("./provider");
10
10
  /**
11
- * (experimental) Define an IAM Role that can be assumed by Github Actions workflow via Github OpenID Connect Identity Provider.
11
+ * Define an IAM Role that can be assumed by Github Actions workflow
12
+ * via Github OpenID Connect Identity Provider.
12
13
  *
13
14
  * Besides `GithubConfiguration`, you may pass in any `iam.RoleProps` except `assumedBy`
14
15
  * which will be defined by this construct (CDK will fail if you do).
15
16
  *
16
- * @experimental
17
17
  * @example
18
- *
19
18
  * const uploadRole = new GithubActionsRole(scope, "UploadRole", {
20
19
  * provider: GithubActionsIdentityProvider.fromAccount(scope, "GithubProvider"),
21
20
  * owner: 'octo-org',
@@ -28,14 +27,13 @@ const provider_1 = require("./provider");
28
27
  */
29
28
  class GithubActionsRole extends iam.Role {
30
29
  /**
31
- * (experimental) Define an IAM Role that can be assumed by Github Actions workflow via Github OpenID Connect Identity Provider.
30
+ * Define an IAM Role that can be assumed by Github Actions workflow
31
+ * via Github OpenID Connect Identity Provider.
32
32
  *
33
33
  * Besides `GithubConfiguration`, you may pass in any `iam.RoleProps` except `assumedBy`
34
34
  * which will be defined by this construct (CDK will fail if you do).
35
35
  *
36
- * @experimental
37
36
  * @example
38
- *
39
37
  * const uploadRole = new GithubActionsRole(scope, "UploadRole", {
40
38
  * provider: GithubActionsIdentityProvider.fromAccount(scope, "GithubProvider"),
41
39
  * owner: 'octo-org',
@@ -103,5 +101,5 @@ class GithubActionsRole extends iam.Role {
103
101
  }
104
102
  exports.GithubActionsRole = GithubActionsRole;
105
103
  _a = JSII_RTTI_SYMBOL_1;
106
- GithubActionsRole[_a] = { fqn: "aws-cdk-github-oidc.GithubActionsRole", version: "1.0.0" };
107
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"role.js","sourceRoot":"","sources":["../src/role.ts"],"names":[],"mappings":";;;;;AAAA,wCAAwC;AACxC,qCAAqC;AAErC,iDAAiD;AACjD,yCAA2F;;;;;;;;;;;;;;;;;;;;AAsB3F,MAAa,iBAAkB,SAAQ,GAAG,CAAC,IAAI;;;;;;;;;;;;;;;;;;;;IAsC7C,YAAY,KAAoB,EAAE,EAAU,EAAE,KAA6B;QAEzE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,KAAK,CAAC;QAExC,sBAAsB;QACtB,iBAAiB,CAAC,aAAa,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAC9C,iBAAiB,CAAC,YAAY,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QAE5C,iBAAiB;QACjB,MAAM,OAAO,GAAG,iBAAiB,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACvD,MAAM,SAAS,GAAG,iBAAiB,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;QAE5D,+BAA+B;QAC/B,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,GAAG,SAAS;YACZ,SAAS,EAAE,IAAI,GAAG,CAAC,oBAAoB,CAAC,QAAQ,CAAC,wBAAwB,EAAE;gBACzE,UAAU,EAAE;oBACV,oDAAoD;oBACpD,CAAC,GAAG,wCAA6B,CAAC,MAAM,MAAM,CAAC,EAAE,OAAO;iBACzD;gBACD,YAAY,EAAE;oBACZ,uEAAuE;oBACvE,0KAA0K;oBAC1K,CAAC,GAAG,wCAA6B,CAAC,MAAM,MAAM,CAAC,EAAE,mBAAmB;iBACrE;aACF,CAAC;SACH,CAAC,CAAC;IAEL,CAAC;IAhED;;;;OAIG;IACK,MAAM,CAAC,gBAAgB,CAAC,KAA6B;QAC3D,MAAM,YAAY,GAAQ,KAAK,CAAC;QAChC,OAAO,YAAY,CAAC,QAAQ,CAAC;QAC7B,OAAO,YAAY,CAAC,KAAK,CAAC;QAC1B,OAAO,YAAY,CAAC,IAAI,CAAC;QACzB,OAAO,YAAY,CAAC,MAAM,CAAC;QAC3B,OAAO,YAAY,CAAC;IACtB,CAAC;IAED,8DAA8D;IACtD,MAAM,CAAC,aAAa,CAAC,KAAoB,EAAE,KAAa;QAC9D,IAAI,sBAAmB,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,EAAE;YAC5C,GAAG,CAAC,WAAW,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,oCAAoC,KAAK,0KAA0K,CAAC,CAAC;SACzP;IACH,CAAC;IAED,4DAA4D;IACpD,MAAM,CAAC,YAAY,CAAC,KAAoB,EAAE,IAAY;QAC5D,IAAI,IAAI,KAAK,EAAE,EAAE;YACf,GAAG,CAAC,WAAW,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,mCAAmC,IAAI,6BAA6B,CAAC,CAAC;SAC1G;IACH,CAAC;IAED,oDAAoD;IAC5C,MAAM,CAAC,aAAa,CAAC,KAA0B;QACrD,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,GAAG,GAAG,EAAE,GAAG,KAAK,CAAC;QAC5C,OAAO,QAAQ,KAAK,IAAI,IAAI,IAAI,MAAM,EAAE,CAAC;IAC3C,CAAC;;AAlCH,8CAmEC","sourcesContent":["import * as iam from '@aws-cdk/aws-iam';\nimport * as cdk from '@aws-cdk/core';\nimport { RoleProps } from './iam-role-props';\nimport githubUsernameRegex from './owner-regexp';\nimport { GithubActionsIdentityProvider, IGithubActionsIdentityProvider } from './provider';\n\n                                                                                      \nexport interface GithubConfiguration {\n\n                                                                                                                                                                                                                                                                                                   \n  readonly provider: IGithubActionsIdentityProvider;\n\n                                                                                                \n  readonly owner: string;\n\n                                                                                              \n  readonly repo: string;\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            \n  readonly filter?: string;\n}\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      \nexport interface GithubActionsRoleProps extends GithubConfiguration, RoleProps {}\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 \nexport class GithubActionsRole extends iam.Role {\n\n  /**\n   * Extracts props given for the created IAM Role Construct.\n   * @param props for the GithubActionsRole\n   * @returns for the IAM Role\n   */\n  private static extractRoleProps(props: GithubActionsRoleProps): iam.RoleProps {\n    const extractProps = <any>props;\n    delete extractProps.provider;\n    delete extractProps.owner;\n    delete extractProps.repo;\n    delete extractProps.filter;\n    return extractProps;\n  }\n\n  /** Validates the Github owner (organization or user) name. */\n  private static validateOwner(scope: cdk.Construct, owner: string): void {\n    if (githubUsernameRegex.test(owner) !== true) {\n      cdk.Annotations.of(scope).addError(`Invalid Github Repository Owner \"${owner}\". Must only contain alphanumeric characters or hyphens, cannot have multiple consecutive hyphens, cannot begin or end with a hypen and maximum lenght is 39 characters.`);\n    }\n  }\n\n  /** Validates the Github repository name (without owner). */\n  private static validateRepo(scope: cdk.Construct, repo: string): void {\n    if (repo === '') {\n      cdk.Annotations.of(scope).addError(`Invalid Github Repository Name \"${repo}\". May not be empty string.`);\n    }\n  }\n\n  /** Formats the `sub` value used in trust policy. */\n  private static formatSubject(props: GithubConfiguration): string {\n    const { owner, repo, filter = '*' } = props;\n    return `repo:${owner}/${repo}:${filter}`;\n  }\n\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     \n  constructor(scope: cdk.Construct, id: string, props: GithubActionsRoleProps) {\n\n    const { provider, owner, repo } = props;\n\n    // Perform validations\n    GithubActionsRole.validateOwner(scope, owner);\n    GithubActionsRole.validateRepo(scope, repo);\n\n    // Prepare values\n    const subject = GithubActionsRole.formatSubject(props);\n    const roleProps = GithubActionsRole.extractRoleProps(props);\n\n    // The actual IAM Role creation\n    super(scope, id, {\n      ...roleProps,\n      assumedBy: new iam.WebIdentityPrincipal(provider.openIdConnectProviderArn, {\n        StringLike: {\n          // Only allow specified subjects to assume this role\n          [`${GithubActionsIdentityProvider.issuer}:sub`]: subject,\n        },\n        StringEquals: {\n          // Audience is always sts.amazonaws.com with AWS official Github Action\n          // https://docs.github.com/en/actions/deployment/security-hardening-your-deployments/configuring-openid-connect-in-amazon-web-services#adding-the-identity-provider-to-aws\n          [`${GithubActionsIdentityProvider.issuer}:aud`]: 'sts.amazonaws.com',\n        },\n      }),\n    });\n\n  }\n}\n\n"]}
104
+ GithubActionsRole[_a] = { fqn: "aws-cdk-github-oidc.GithubActionsRole", version: "2.2.0" };
105
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"role.js","sourceRoot":"","sources":["../src/role.ts"],"names":[],"mappings":";;;;;AAAA,mCAAmC;AACnC,2CAA2C;AAG3C,iDAAiD;AACjD,yCAA2F;AAoE3F;;;;;;;;;;;;;;;;;GAiBG;AACH,MAAa,iBAAkB,SAAQ,GAAG,CAAC,IAAI;IAqC7C;;;;;;;;;;;;;;;;;OAiBG;IACH,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA6B;QAErE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,KAAK,CAAC;QAExC,sBAAsB;QACtB,iBAAiB,CAAC,aAAa,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAC9C,iBAAiB,CAAC,YAAY,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QAE5C,iBAAiB;QACjB,MAAM,OAAO,GAAG,iBAAiB,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACvD,MAAM,SAAS,GAAG,iBAAiB,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;QAE5D,+BAA+B;QAC/B,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,GAAG,SAAS;YACZ,SAAS,EAAE,IAAI,GAAG,CAAC,oBAAoB,CAAC,QAAQ,CAAC,wBAAwB,EAAE;gBACzE,UAAU,EAAE;oBACV,oDAAoD;oBACpD,CAAC,GAAG,wCAA6B,CAAC,MAAM,MAAM,CAAC,EAAE,OAAO;iBACzD;gBACD,YAAY,EAAE;oBACZ,uEAAuE;oBACvE,0KAA0K;oBAC1K,CAAC,GAAG,wCAA6B,CAAC,MAAM,MAAM,CAAC,EAAE,mBAAmB;iBACrE;aACF,CAAC;SACH,CAAC,CAAC;IAEL,CAAC;IAjFD;;;;OAIG;IACK,MAAM,CAAC,gBAAgB,CAAC,KAA6B;QAC3D,MAAM,YAAY,GAAQ,KAAK,CAAC;QAChC,OAAO,YAAY,CAAC,QAAQ,CAAC;QAC7B,OAAO,YAAY,CAAC,KAAK,CAAC;QAC1B,OAAO,YAAY,CAAC,IAAI,CAAC;QACzB,OAAO,YAAY,CAAC,MAAM,CAAC;QAC3B,OAAO,YAAY,CAAC;IACtB,CAAC;IAED,8DAA8D;IACtD,MAAM,CAAC,aAAa,CAAC,KAAgB,EAAE,KAAa;QAC1D,IAAI,sBAAmB,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,EAAE;YAC5C,GAAG,CAAC,WAAW,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,oCAAoC,KAAK,0KAA0K,CAAC,CAAC;SACzP;IACH,CAAC;IAED,4DAA4D;IACpD,MAAM,CAAC,YAAY,CAAC,KAAgB,EAAE,IAAY;QACxD,IAAI,IAAI,KAAK,EAAE,EAAE;YACf,GAAG,CAAC,WAAW,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,mCAAmC,IAAI,6BAA6B,CAAC,CAAC;SAC1G;IACH,CAAC;IAED,oDAAoD;IAC5C,MAAM,CAAC,aAAa,CAAC,KAA0B;QACrD,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,GAAG,GAAG,EAAE,GAAG,KAAK,CAAC;QAC5C,OAAO,QAAQ,KAAK,IAAI,IAAI,IAAI,MAAM,EAAE,CAAC;IAC3C,CAAC;;AAlCH,8CAoFC","sourcesContent":["import * as cdk from 'aws-cdk-lib';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport { Construct } from 'constructs';\nimport { RoleProps } from './iam-role-props';\nimport githubUsernameRegex from './owner-regexp';\nimport { GithubActionsIdentityProvider, IGithubActionsIdentityProvider } from './provider';\n\n/**\n * Github related configuration that forms the trust policy for this IAM Role.\n */\nexport interface GithubConfiguration {\n\n  /**\n   * Reference to Github OpenID Connect Provider configured in AWS IAM.\n   *\n   * Either pass an construct defined by `new GithubActionsIdentityProvider`\n   * or a retrieved reference from `GithubActionsIdentityProvider.fromAccount`.\n   * There can be only one (per AWS Account).\n   */\n  readonly provider: IGithubActionsIdentityProvider;\n\n  /**\n   * Repository owner (organization or username).\n   *\n   * @example\n   * 'octo-org'\n   */\n  readonly owner: string;\n\n  /**\n   * Repository name (slug) without the owner.\n   *\n   * @example\n   * 'octo-repo'\n   */\n  readonly repo: string;\n\n  /**\n   * Subject condition filter, appended after `repo:${owner}/${repo}:` string in IAM Role trust relationship.\n   *\n   * @default\n   * '*'\n   *\n   * You may use this value to only allow Github to assume the role on specific branches, tags, environments, pull requests etc.\n   * @example\n   * 'ref:refs/tags/v*'\n   * 'ref:refs/heads/demo-branch'\n   * 'pull_request'\n   * 'environment:Production'\n   *\n   * @see https://docs.github.com/en/actions/deployment/security-hardening-your-deployments/about-security-hardening-with-openid-connect#examples\n   */\n  readonly filter?: string;\n}\n\n/**\n * Props that define the IAM Role that can be assumed by Github Actions workflow\n * via Github OpenID Connect Identity Provider.\n *\n * Besides `GithubConfiguration`, you may pass in any `iam.RoleProps` except `assumedBy`\n * which will be defined by this construct (CDK will fail if you do).\n *\n * @example\n * {\n *   provider: GithubActionsIdentityProvider.fromAccount(scope, \"GithubProvider\"),\n *   owner: 'octo-org',\n *   repo: 'octo-repo',\n *   filter: 'ref:refs/tags/v*',\n *   roleName: 'MyDeployRole',\n * }\n */\nexport interface GithubActionsRoleProps extends GithubConfiguration, RoleProps {}\n\n/**\n * Define an IAM Role that can be assumed by Github Actions workflow\n * via Github OpenID Connect Identity Provider.\n *\n * Besides `GithubConfiguration`, you may pass in any `iam.RoleProps` except `assumedBy`\n * which will be defined by this construct (CDK will fail if you do).\n *\n * @example\n * const uploadRole = new GithubActionsRole(scope, \"UploadRole\", {\n *   provider: GithubActionsIdentityProvider.fromAccount(scope, \"GithubProvider\"),\n *   owner: 'octo-org',\n *   repo: 'octo-repo',\n *   filter: 'ref:refs/tags/v*',\n *   roleName: 'MyUploadRole',\n * });\n *\n * myBucket.grantWrite(uploadRole);\n */\nexport class GithubActionsRole extends iam.Role {\n\n  /**\n   * Extracts props given for the created IAM Role Construct.\n   * @param props for the GithubActionsRole\n   * @returns for the IAM Role\n   */\n  private static extractRoleProps(props: GithubActionsRoleProps): iam.RoleProps {\n    const extractProps = <any>props;\n    delete extractProps.provider;\n    delete extractProps.owner;\n    delete extractProps.repo;\n    delete extractProps.filter;\n    return extractProps;\n  }\n\n  /** Validates the Github owner (organization or user) name. */\n  private static validateOwner(scope: Construct, owner: string): void {\n    if (githubUsernameRegex.test(owner) !== true) {\n      cdk.Annotations.of(scope).addError(`Invalid Github Repository Owner \"${owner}\". Must only contain alphanumeric characters or hyphens, cannot have multiple consecutive hyphens, cannot begin or end with a hypen and maximum lenght is 39 characters.`);\n    }\n  }\n\n  /** Validates the Github repository name (without owner). */\n  private static validateRepo(scope: Construct, repo: string): void {\n    if (repo === '') {\n      cdk.Annotations.of(scope).addError(`Invalid Github Repository Name \"${repo}\". May not be empty string.`);\n    }\n  }\n\n  /** Formats the `sub` value used in trust policy. */\n  private static formatSubject(props: GithubConfiguration): string {\n    const { owner, repo, filter = '*' } = props;\n    return `repo:${owner}/${repo}:${filter}`;\n  }\n\n\n  /**\n   * Define an IAM Role that can be assumed by Github Actions workflow\n   * via Github OpenID Connect Identity Provider.\n   *\n   * Besides `GithubConfiguration`, you may pass in any `iam.RoleProps` except `assumedBy`\n   * which will be defined by this construct (CDK will fail if you do).\n   *\n   * @example\n   * const uploadRole = new GithubActionsRole(scope, \"UploadRole\", {\n   *   provider: GithubActionsIdentityProvider.fromAccount(scope, \"GithubProvider\"),\n   *   owner: 'octo-org',\n   *   repo: 'octo-repo',\n   *   filter: 'ref:refs/tags/v*',\n   *   roleName: 'MyUploadRole',\n   * });\n   *\n   * myBucket.grantWrite(uploadRole);\n   */\n  constructor(scope: Construct, id: string, props: GithubActionsRoleProps) {\n\n    const { provider, owner, repo } = props;\n\n    // Perform validations\n    GithubActionsRole.validateOwner(scope, owner);\n    GithubActionsRole.validateRepo(scope, repo);\n\n    // Prepare values\n    const subject = GithubActionsRole.formatSubject(props);\n    const roleProps = GithubActionsRole.extractRoleProps(props);\n\n    // The actual IAM Role creation\n    super(scope, id, {\n      ...roleProps,\n      assumedBy: new iam.WebIdentityPrincipal(provider.openIdConnectProviderArn, {\n        StringLike: {\n          // Only allow specified subjects to assume this role\n          [`${GithubActionsIdentityProvider.issuer}:sub`]: subject,\n        },\n        StringEquals: {\n          // Audience is always sts.amazonaws.com with AWS official Github Action\n          // https://docs.github.com/en/actions/deployment/security-hardening-your-deployments/configuring-openid-connect-in-amazon-web-services#adding-the-identity-provider-to-aws\n          [`${GithubActionsIdentityProvider.issuer}:aud`]: 'sts.amazonaws.com',\n        },\n      }),\n    });\n\n  }\n}\n\n"]}