aws-cdk-github-oidc 0.0.23 → 2.0.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/.gitattributes +22 -18
- package/.jsii +2878 -137
- package/API.md +17 -17
- package/changelog.md +12 -0
- package/lib/iam-role-props.d.ts +2 -3
- package/lib/iam-role-props.js +1 -1
- package/lib/provider.d.ts +15 -27
- package/lib/provider.js +14 -24
- package/lib/role.d.ts +18 -29
- package/lib/role.js +8 -10
- package/package.json +33 -36
- package/releasetag.txt +1 -0
- package/version.txt +1 -0
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:* [
|
|
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:* [
|
|
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:* [
|
|
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 ]: [
|
|
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:* [
|
|
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:* [
|
|
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:* [
|
|
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 ]: [
|
|
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:* [
|
|
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:* [
|
|
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:* [
|
|
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:* [
|
|
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:
|
|
605
|
+
public readonly node: Node;
|
|
606
606
|
```
|
|
607
607
|
|
|
608
|
-
- *Type:* [
|
|
608
|
+
- *Type:* [`constructs.Node`](#constructs.Node)
|
|
609
609
|
|
|
610
|
-
The
|
|
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:* [
|
|
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:* [
|
|
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,12 @@
|
|
|
1
|
+
|
|
2
|
+
## [2.0.0](https://github.com/aripalo/aws-cdk-github-oidc/compare/v0.0.23...v2.0.0) (2022-02-22)
|
|
3
|
+
|
|
4
|
+
|
|
5
|
+
### ⚠ BREAKING CHANGES
|
|
6
|
+
|
|
7
|
+
* Not compatibe with CDK v1 anymore
|
|
8
|
+
|
|
9
|
+
### Features
|
|
10
|
+
|
|
11
|
+
* release for both CDK v1 and v2 ([6b5bd42](https://github.com/aripalo/aws-cdk-github-oidc/commit/6b5bd428140b21376e2f9805a0c549eeef3b1bab))
|
|
12
|
+
* Support CDK v2 ([773205c](https://github.com/aripalo/aws-cdk-github-oidc/commit/773205c2f8a4c0a0822646c446e34757bdf43973))
|
package/lib/iam-role-props.d.ts
CHANGED
|
@@ -1,8 +1,7 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
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
|
*
|
package/lib/iam-role-props.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
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 '
|
|
2
|
-
import
|
|
1
|
+
import * as iam from 'aws-cdk-lib/aws-iam';
|
|
2
|
+
import { Construct } from 'constructs';
|
|
3
3
|
/**
|
|
4
|
-
*
|
|
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
|
-
*
|
|
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
|
-
*
|
|
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:
|
|
32
|
+
static fromAccount(scope: Construct, id: string): IGithubActionsIdentityProvider;
|
|
43
33
|
/**
|
|
44
|
-
*
|
|
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:
|
|
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
|
|
7
|
-
const
|
|
6
|
+
const cdk = require("aws-cdk-lib");
|
|
7
|
+
const iam = require("aws-cdk-lib/aws-iam");
|
|
8
8
|
/**
|
|
9
|
-
*
|
|
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
|
-
*
|
|
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
|
-
*
|
|
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: "0.0
|
|
60
|
-
/**
|
|
61
|
-
* @experimental
|
|
62
|
-
*/
|
|
55
|
+
GithubActionsIdentityProvider[_a] = { fqn: "aws-cdk-github-oidc.GithubActionsIdentityProvider", version: "2.0.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,
|
|
61
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvcHJvdmlkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxtQ0FBbUM7QUFDbkMsMkNBQTJDO0FBUTNDOzs7Ozs7O0dBT0c7QUFDSCxNQUFhLDZCQUE4QixTQUFRLEdBQUcsQ0FBQyxxQkFBcUI7SUEyQjFFOzs7Ozs7Ozs7T0FTRztJQUNILFlBQVksS0FBZ0IsRUFBRSxFQUFVO1FBQ3RDLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxFQUFFO1lBQ2YsR0FBRyxFQUFFLFdBQVcsNkJBQTZCLENBQUMsTUFBTSxFQUFFO1lBQ3RELFdBQVcsRUFBRSw2QkFBNkIsQ0FBQyxXQUFXO1lBQ3RELFNBQVMsRUFBRSxDQUFDLG1CQUFtQixDQUFDO1NBQ2pDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFuQ0Q7Ozs7Ozs7Ozs7OztPQVlHO0lBQ0ksTUFBTSxDQUFDLFdBQVcsQ0FBQyxLQUFnQixFQUFFLEVBQVU7UUFDcEQsTUFBTSxTQUFTLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUMsT0FBTyxDQUFDO1FBQzlDLE1BQU0sV0FBVyxHQUFHLGdCQUFnQixTQUFTLGtCQUFrQiw2QkFBNkIsQ0FBQyxNQUFNLEVBQUUsQ0FBQztRQUN0RyxPQUFPLEdBQUcsQ0FBQyxxQkFBcUIsQ0FBQyw0QkFBNEIsQ0FBQyxLQUFLLEVBQUUsRUFBRSxFQUFFLFdBQVcsQ0FBQyxDQUFDO0lBQ3hGLENBQUM7O0FBekJILHNFQTRDQzs7O0FBMUN3QixvQ0FBTSxHQUFXLHFDQUFxQyxDQUFDO0FBQ3ZELHlDQUFXLEdBQWE7SUFDN0MsMENBQTBDO0lBQzFDLDBDQUEwQztDQUMzQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgY2RrIGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCAqIGFzIGlhbSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtaWFtJztcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xuXG4vKipcbiAqIERlc2NyaWJlcyBhIEdpdGh1YiBPcGVuSUQgQ29ubmVjdCBJZGVudGl0eSBQcm92aWRlciBmb3IgQVdTIElBTS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBJR2l0aHViQWN0aW9uc0lkZW50aXR5UHJvdmlkZXIgZXh0ZW5kcyBpYW0uSU9wZW5JZENvbm5lY3RQcm92aWRlciB7fVxuXG4vKipcbiAqIEdpdGh1YiBBY3Rpb25zIGFzIE9wZW5JRCBDb25uZWN0IElkZW50aXR5IFByb3ZpZGVyIGZvciBBV1MgSUFNLlxuICogVGhlcmUgY2FuIGJlIG9ubHkgb25lIChwZXIgQVdTIEFjY291bnQpLlxuICpcbiAqIFVzZSBgZnJvbUFjY291bnRgIHRvIHJldHJpZXZlIGEgcmVmZXJlbmNlIHRvIGV4aXN0aW5nIEdpdGh1YiBPSURDIHByb3ZpZGVyLlxuICpcbiAqIEBzZWUgaHR0cHM6Ly9kb2NzLmdpdGh1Yi5jb20vZW4vYWN0aW9ucy9kZXBsb3ltZW50L3NlY3VyaXR5LWhhcmRlbmluZy15b3VyLWRlcGxveW1lbnRzL2NvbmZpZ3VyaW5nLW9wZW5pZC1jb25uZWN0LWluLWFtYXpvbi13ZWItc2VydmljZXNcbiAqL1xuZXhwb3J0IGNsYXNzIEdpdGh1YkFjdGlvbnNJZGVudGl0eVByb3ZpZGVyIGV4dGVuZHMgaWFtLk9wZW5JZENvbm5lY3RQcm92aWRlciBpbXBsZW1lbnRzIElHaXRodWJBY3Rpb25zSWRlbnRpdHlQcm92aWRlciB7XG5cbiAgcHVibGljIHN0YXRpYyByZWFkb25seSBpc3N1ZXI6IHN0cmluZyA9ICd0b2tlbi5hY3Rpb25zLmdpdGh1YnVzZXJjb250ZW50LmNvbSc7XG4gIHB1YmxpYyBzdGF0aWMgcmVhZG9ubHkgdGh1bWJwcmludHM6IHN0cmluZ1tdID0gW1xuICAgICdhMDMxYzQ2NzgyZTZlNmM2NjJjMmM4N2M3NmRhOWFhNjJjY2FiZDhlJyxcbiAgICAnNjkzOGZkNGQ5OGJhYjAzZmFhZGI5N2IzNDM5NjgzMWUzNzgwYWVhMScsXG4gIF07XG5cbiAgLyoqXG4gICAqIFJldHJpZXZlIGEgcmVmZXJlbmNlIHRvIGV4aXN0aW5nIEdpdGh1YiBPSURDIHByb3ZpZGVyIGluIHlvdXIgQVdTIGFjY291bnQuXG4gICAqIEFuIEFXUyBhY2NvdW50IGNhbiBvbmx5IGhhdmUgc2luZ2xlIEdpdGh1YiBPSURDIHByb3ZpZGVyIGNvbmZpZ3VyZWQgaW50byBpdCxcbiAgICogc28gaW50ZXJuYWxseSB0aGUgcmVmZXJlbmNlIGlzIG1hZGUgYnkgY29uc3RydWN0aW5nIHRoZSBBUk4gZnJvbSBBV1NcbiAgICogQWNjb3VudCBJRCAmIEdpdGh1YiBpc3N1ZXIgVVJMLlxuICAgKlxuICAgKiBAcGFyYW0gc2NvcGUgQ0RLIFN0YWNrIG9yIENvbnN0cnVjdCB0byB3aGljaCB0aGUgcHJvdmlkZXIgaXMgYXNzaWduZWQgdG9cbiAgICogQHBhcmFtIGlkIENESyBDb25zdHJ1Y3QgSUQgZ2l2ZW4gdG8gdGhlIGNvbnN0cnVjdFxuICAgKiBAcmV0dXJucyBhIENESyBDb25zdHJ1Y3QgcmVwcmVzZW50aW5nIHRoZSBHaXRodWIgT0lEQyBwcm92aWRlclxuICAgKlxuICAgKiBAZXhhbXBsZVxuICAgKiBHaXRodWJBY3Rpb25zSWRlbnRpdHlQcm92aWRlci5mcm9tQWNjb3VudChzY29wZSwgXCJHaXRodWJQcm92aWRlclwiKTtcbiAgICovXG4gIHB1YmxpYyBzdGF0aWMgZnJvbUFjY291bnQoc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZyk6IElHaXRodWJBY3Rpb25zSWRlbnRpdHlQcm92aWRlciB7XG4gICAgY29uc3QgYWNjb3VudElkID0gY2RrLlN0YWNrLm9mKHNjb3BlKS5hY2NvdW50O1xuICAgIGNvbnN0IHByb3ZpZGVyQXJuID0gYGFybjphd3M6aWFtOjoke2FjY291bnRJZH06b2lkYy1wcm92aWRlci8ke0dpdGh1YkFjdGlvbnNJZGVudGl0eVByb3ZpZGVyLmlzc3Vlcn1gO1xuICAgIHJldHVybiBpYW0uT3BlbklkQ29ubmVjdFByb3ZpZGVyLmZyb21PcGVuSWRDb25uZWN0UHJvdmlkZXJBcm4oc2NvcGUsIGlkLCBwcm92aWRlckFybik7XG4gIH1cblxuICAvKipcbiAgICogRGVmaW5lIGEgbmV3IEdpdGh1YiBPcGVuSUQgQ29ubmVjdCBJZGVudGl0eSBQUm92aWRlciBmb3IgQVdTIElBTS5cbiAgICogVGhlcmUgY2FuIGJlIG9ubHkgb25lIChwZXIgQVdTIEFjY291bnQpLlxuICAgKlxuICAgKiBAcGFyYW0gc2NvcGUgQ0RLIFN0YWNrIG9yIENvbnN0cnVjdCB0byB3aGljaCB0aGUgcHJvdmlkZXIgaXMgYXNzaWduZWQgdG9cbiAgICogQHBhcmFtIGlkIENESyBDb25zdHJ1Y3QgSUQgZ2l2ZW4gdG8gdGhlIGNvbnN0cnVjdFxuICAgKlxuICAgKiBAZXhhbXBsZVxuICAgKiBuZXcgR2l0aHViQWN0aW9uc0lkZW50aXR5UHJvdmlkZXIoc2NvcGUsIFwiR2l0aHViUHJvdmlkZXJcIik7XG4gICAqL1xuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkLCB7XG4gICAgICB1cmw6IGBodHRwczovLyR7R2l0aHViQWN0aW9uc0lkZW50aXR5UHJvdmlkZXIuaXNzdWVyfWAsXG4gICAgICB0aHVtYnByaW50czogR2l0aHViQWN0aW9uc0lkZW50aXR5UHJvdmlkZXIudGh1bWJwcmludHMsXG4gICAgICBjbGllbnRJZHM6IFsnc3RzLmFtYXpvbmF3cy5jb20nXSxcbiAgICB9KTtcbiAgfVxufVxuIl19
|
package/lib/role.d.ts
CHANGED
|
@@ -1,67 +1,58 @@
|
|
|
1
|
-
import * as iam from '
|
|
2
|
-
import
|
|
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
|
-
*
|
|
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
|
-
*
|
|
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
|
-
*
|
|
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
|
-
*
|
|
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
|
-
*
|
|
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
|
-
*
|
|
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
|
-
*
|
|
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
|
-
*
|
|
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:
|
|
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
|
|
7
|
-
const
|
|
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
|
-
*
|
|
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
|
-
*
|
|
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: "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.0.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"]}
|