aws-cdk-github-oidc 2.4.1 → 3.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/.jsii +676 -82
- package/.nvmrc +1 -1
- package/API.md +1210 -123
- package/lib/iam-role-props.d.ts +2 -2
- package/lib/iam-role-props.js +1 -1
- package/lib/index.d.ts +3 -3
- package/lib/index.js +2 -1
- package/lib/provider.d.ts +2 -2
- package/lib/provider.js +19 -19
- package/lib/role.d.ts +4 -4
- package/lib/role.js +33 -33
- package/package.json +71 -63
- package/pnpm-workspace.yaml +17 -0
- package/sonar-project.properties +7 -0
- package/.gitattributes +0 -24
package/lib/iam-role-props.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { Duration } from
|
|
2
|
-
import { IManagedPolicy, PolicyDocument } from
|
|
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
5
|
* These are copied fron @aws-cdk/aws-iam, but since JSII does not support
|
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWFtLXJvbGUtcHJvcHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaWFtLXJvbGUtcHJvcHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IER1cmF0aW9uIH0gZnJvbSBcImF3cy1jZGstbGliXCI7XG5pbXBvcnQgeyBJTWFuYWdlZFBvbGljeSwgUG9saWN5RG9jdW1lbnQgfSBmcm9tIFwiYXdzLWNkay1saWIvYXdzLWlhbVwiO1xuXG4vKipcbiAqIFByb3BlcnRpZXMgZm9yIGRlZmluaW5nIGFuIElBTSBSb2xlLlxuICogVGhlc2UgYXJlIGNvcGllZCBmcm9uIEBhd3MtY2RrL2F3cy1pYW0sIGJ1dCBzaW5jZSBKU0lJIGRvZXMgbm90IHN1cHBvcnRcbiAqIFR5cGVTY3JpcHQgPFBhcnRpYWw8aWFtLlJvbGVQcm9wcz4+IChvciBPbWl0KSwgd2UgaGF2ZSB0byBkbyB0aGlzIHN0dXBpZCB0aGluZy5cbiAqXG4gKiBCYXNpY2FsbHkgZXhhY3RseSB0aGUgc2FtZSBhcyBzb3VyY2UsIGJ1dCB3aXRoIGFzc3VtZWRCeSByZW1vdmVkLlxuICpcbiAqIEBzdGFiaWxpdHkgc3RhYmxlXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUm9sZVByb3BzIHtcbiAgLyoqXG4gICAqIExpc3Qgb2YgSURzIHRoYXQgdGhlIHJvbGUgYXNzdW1lciBuZWVkcyB0byBwcm92aWRlIG9uZSBvZiB3aGVuIGFzc3VtaW5nIHRoaXMgcm9sZS5cbiAgICpcbiAgICogSWYgdGhlIGNvbmZpZ3VyZWQgYW5kIHByb3ZpZGVkIGV4dGVybmFsIElEcyBkbyBub3QgbWF0Y2gsIHRoZVxuICAgKiBBc3N1bWVSb2xlIG9wZXJhdGlvbiB3aWxsIGZhaWwuXG4gICAqXG4gICAqIEBkZWZhdWx0IE5vIGV4dGVybmFsIElEIHJlcXVpcmVkXG4gICAqIEBzdGFiaWxpdHkgc3RhYmxlXG4gICAqL1xuICByZWFkb25seSBleHRlcm5hbElkcz86IHN0cmluZ1tdO1xuICAvKipcbiAgICogQSBsaXN0IG9mIG1hbmFnZWQgcG9saWNpZXMgYXNzb2NpYXRlZCB3aXRoIHRoaXMgcm9sZS5cbiAgICpcbiAgICogWW91IGNhbiBhZGQgbWFuYWdlZCBwb2xpY2llcyBsYXRlciB1c2luZ1xuICAgKiBgYWRkTWFuYWdlZFBvbGljeShNYW5hZ2VkUG9saWN5LmZyb21Bd3NNYW5hZ2VkUG9saWN5TmFtZShwb2xpY3lOYW1lKSlgLlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIE5vIG1hbmFnZWQgcG9saWNpZXMuXG4gICAqIEBzdGFiaWxpdHkgc3RhYmxlXG4gICAqL1xuICByZWFkb25seSBtYW5hZ2VkUG9saWNpZXM/OiBJTWFuYWdlZFBvbGljeVtdO1xuICAvKipcbiAgICogQSBsaXN0IG9mIG5hbWVkIHBvbGljaWVzIHRvIGlubGluZSBpbnRvIHRoaXMgcm9sZS5cbiAgICpcbiAgICogVGhlc2UgcG9saWNpZXMgd2lsbCBiZVxuICAgKiBjcmVhdGVkIHdpdGggdGhlIHJvbGUsIHdoZXJlYXMgdGhvc2UgYWRkZWQgYnkgYGBhZGRUb1BvbGljeWBgIGFyZSBhZGRlZFxuICAgKiB1c2luZyBhIHNlcGFyYXRlIENsb3VkRm9ybWF0aW9uIHJlc291cmNlIChhbGxvd2luZyBhIHdheSBhcm91bmQgY2lyY3VsYXJcbiAgICogZGVwZW5kZW5jaWVzIHRoYXQgY291bGQgb3RoZXJ3aXNlIGJlIGludHJvZHVjZWQpLlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIE5vIHBvbGljeSBpcyBpbmxpbmVkIGluIHRoZSBSb2xlIHJlc291cmNlLlxuICAgKiBAc3RhYmlsaXR5IHN0YWJsZVxuICAgKi9cbiAgcmVhZG9ubHkgaW5saW5lUG9saWNpZXM/OiB7XG4gICAgW25hbWU6IHN0cmluZ106IFBvbGljeURvY3VtZW50O1xuICB9O1xuICAvKipcbiAgICogVGhlIHBhdGggYXNzb2NpYXRlZCB3aXRoIHRoaXMgcm9sZS5cbiAgICpcbiAgICogRm9yIGluZm9ybWF0aW9uIGFib3V0IElBTSBwYXRocywgc2VlXG4gICAqIEZyaWVuZGx5IE5hbWVzIGFuZCBQYXRocyBpbiBJQU0gVXNlciBHdWlkZS5cbiAgICpcbiAgICogQGRlZmF1bHQgL1xuICAgKiBAc3RhYmlsaXR5IHN0YWJsZVxuICAgKi9cbiAgcmVhZG9ubHkgcGF0aD86IHN0cmluZztcbiAgLyoqXG4gICAqIEFXUyBzdXBwb3J0cyBwZXJtaXNzaW9ucyBib3VuZGFyaWVzIGZvciBJQU0gZW50aXRpZXMgKHVzZXJzIG9yIHJvbGVzKS5cbiAgICpcbiAgICogQSBwZXJtaXNzaW9ucyBib3VuZGFyeSBpcyBhbiBhZHZhbmNlZCBmZWF0dXJlIGZvciB1c2luZyBhIG1hbmFnZWQgcG9saWN5XG4gICAqIHRvIHNldCB0aGUgbWF4aW11bSBwZXJtaXNzaW9ucyB0aGF0IGFuIGlkZW50aXR5LWJhc2VkIHBvbGljeSBjYW4gZ3JhbnQgdG9cbiAgICogYW4gSUFNIGVudGl0eS4gQW4gZW50aXR5J3MgcGVybWlzc2lvbnMgYm91bmRhcnkgYWxsb3dzIGl0IHRvIHBlcmZvcm0gb25seVxuICAgKiB0aGUgYWN0aW9ucyB0aGF0IGFyZSBhbGxvd2VkIGJ5IGJvdGggaXRzIGlkZW50aXR5LWJhc2VkIHBvbGljaWVzIGFuZCBpdHNcbiAgICogcGVybWlzc2lvbnMgYm91bmRhcmllcy5cbiAgICpcbiAgICogQGRlZmF1bHQgLSBObyBwZXJtaXNzaW9ucyBib3VuZGFyeS5cbiAgICogQHN0YWJpbGl0eSBzdGFibGVcbiAgICogQGxpbmsgaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0lBTS9sYXRlc3QvVXNlckd1aWRlL2FjY2Vzc19wb2xpY2llc19ib3VuZGFyaWVzLmh0bWxcbiAgICovXG4gIHJlYWRvbmx5IHBlcm1pc3Npb25zQm91bmRhcnk/OiBJTWFuYWdlZFBvbGljeTtcbiAgLyoqXG4gICAqIEEgbmFtZSBmb3IgdGhlIElBTSByb2xlLlxuICAgKlxuICAgKiBGb3IgdmFsaWQgdmFsdWVzLCBzZWUgdGhlIFJvbGVOYW1lIHBhcmFtZXRlciBmb3JcbiAgICogdGhlIENyZWF0ZVJvbGUgYWN0aW9uIGluIHRoZSBJQU0gQVBJIFJlZmVyZW5jZS5cbiAgICpcbiAgICogSU1QT1JUQU5UOiBJZiB5b3Ugc3BlY2lmeSBhIG5hbWUsIHlvdSBjYW5ub3QgcGVyZm9ybSB1cGRhdGVzIHRoYXQgcmVxdWlyZVxuICAgKiByZXBsYWNlbWVudCBvZiB0aGlzIHJlc291cmNlLiBZb3UgY2FuIHBlcmZvcm0gdXBkYXRlcyB0aGF0IHJlcXVpcmUgbm8gb3JcbiAgICogc29tZSBpbnRlcnJ1cHRpb24uIElmIHlvdSBtdXN0IHJlcGxhY2UgdGhlIHJlc291cmNlLCBzcGVjaWZ5IGEgbmV3IG5hbWUuXG4gICAqXG4gICAqIElmIHlvdSBzcGVjaWZ5IGEgbmFtZSwgeW91IG11c3Qgc3BlY2lmeSB0aGUgQ0FQQUJJTElUWV9OQU1FRF9JQU0gdmFsdWUgdG9cbiAgICogYWNrbm93bGVkZ2UgeW91ciB0ZW1wbGF0ZSdzIGNhcGFiaWxpdGllcy4gRm9yIG1vcmUgaW5mb3JtYXRpb24sIHNlZVxuICAgKiBBY2tub3dsZWRnaW5nIElBTSBSZXNvdXJjZXMgaW4gQVdTIENsb3VkRm9ybWF0aW9uIFRlbXBsYXRlcy5cbiAgICpcbiAgICogQGRlZmF1bHQgLSBBV1MgQ2xvdWRGb3JtYXRpb24gZ2VuZXJhdGVzIGEgdW5pcXVlIHBoeXNpY2FsIElEIGFuZCB1c2VzIHRoYXQgSURcbiAgICogZm9yIHRoZSByb2xlIG5hbWUuXG4gICAqIEBzdGFiaWxpdHkgc3RhYmxlXG4gICAqL1xuICByZWFkb25seSByb2xlTmFtZT86IHN0cmluZztcbiAgLyoqXG4gICAqIFRoZSBtYXhpbXVtIHNlc3Npb24gZHVyYXRpb24gdGhhdCB5b3Ugd2FudCB0byBzZXQgZm9yIHRoZSBzcGVjaWZpZWQgcm9sZS5cbiAgICpcbiAgICogVGhpcyBzZXR0aW5nIGNhbiBoYXZlIGEgdmFsdWUgZnJvbSAxIGhvdXIgKDM2MDBzZWMpIHRvIDEyICg0MzIwMHNlYykgaG91cnMuXG4gICAqXG4gICAqIEFueW9uZSB3aG8gYXNzdW1lcyB0aGUgcm9sZSBmcm9tIHRoZSBBV1MgQ0xJIG9yIEFQSSBjYW4gdXNlIHRoZVxuICAgKiBEdXJhdGlvblNlY29uZHMgQVBJIHBhcmFtZXRlciBvciB0aGUgZHVyYXRpb24tc2Vjb25kcyBDTEkgcGFyYW1ldGVyIHRvXG4gICAqIHJlcXVlc3QgYSBsb25nZXIgc2Vzc2lvbi4gVGhlIE1heFNlc3Npb25EdXJhdGlvbiBzZXR0aW5nIGRldGVybWluZXMgdGhlXG4gICAqIG1heGltdW0gZHVyYXRpb24gdGhhdCBjYW4gYmUgcmVxdWVzdGVkIHVzaW5nIHRoZSBEdXJhdGlvblNlY29uZHNcbiAgICogcGFyYW1ldGVyLlxuICAgKlxuICAgKiBJZiB1c2VycyBkb24ndCBzcGVjaWZ5IGEgdmFsdWUgZm9yIHRoZSBEdXJhdGlvblNlY29uZHMgcGFyYW1ldGVyLCB0aGVpclxuICAgKiBzZWN1cml0eSBjcmVkZW50aWFscyBhcmUgdmFsaWQgZm9yIG9uZSBob3VyIGJ5IGRlZmF1bHQuIFRoaXMgYXBwbGllcyB3aGVuXG4gICAqIHlvdSB1c2UgdGhlIEFzc3VtZVJvbGUqIEFQSSBvcGVyYXRpb25zIG9yIHRoZSBhc3N1bWUtcm9sZSogQ0xJIG9wZXJhdGlvbnNcbiAgICogYnV0IGRvZXMgbm90IGFwcGx5IHdoZW4geW91IHVzZSB0aG9zZSBvcGVyYXRpb25zIHRvIGNyZWF0ZSBhIGNvbnNvbGUgVVJMLlxuICAgKlxuICAgKiBAZGVmYXVsdCBEdXJhdGlvbi5ob3VycygxKVxuICAgKiBAc3RhYmlsaXR5IHN0YWJsZVxuICAgKiBAbGluayBodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vSUFNL2xhdGVzdC9Vc2VyR3VpZGUvaWRfcm9sZXNfdXNlLmh0bWxcbiAgICovXG4gIHJlYWRvbmx5IG1heFNlc3Npb25EdXJhdGlvbj86IER1cmF0aW9uO1xuICAvKipcbiAgICogQSBkZXNjcmlwdGlvbiBvZiB0aGUgcm9sZS5cbiAgICpcbiAgICogSXQgY2FuIGJlIHVwIHRvIDEwMDAgY2hhcmFjdGVycyBsb25nLlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIE5vIGRlc2NyaXB0aW9uLlxuICAgKiBAc3RhYmlsaXR5IHN0YWJsZVxuICAgKi9cbiAgcmVhZG9ubHkgZGVzY3JpcHRpb24/OiBzdHJpbmc7XG59XG4iXX0=
|
package/lib/index.d.ts
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export { GithubActionsIdentityProvider, IGithubActionsIdentityProvider } from
|
|
2
|
-
export { GithubActionsRole, GithubActionsRoleProps, GithubConfiguration } from
|
|
3
|
-
export { RoleProps } from
|
|
1
|
+
export { GithubActionsIdentityProvider, IGithubActionsIdentityProvider, } from "./provider";
|
|
2
|
+
export { GithubActionsRole, GithubActionsRoleProps, GithubConfiguration, } from "./role";
|
|
3
|
+
export { RoleProps } from "./iam-role-props";
|
package/lib/index.js
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.GithubActionsRole = exports.GithubActionsIdentityProvider = void 0;
|
|
3
4
|
var provider_1 = require("./provider");
|
|
4
5
|
Object.defineProperty(exports, "GithubActionsIdentityProvider", { enumerable: true, get: function () { return provider_1.GithubActionsIdentityProvider; } });
|
|
5
6
|
var role_1 = require("./role");
|
|
6
7
|
Object.defineProperty(exports, "GithubActionsRole", { enumerable: true, get: function () { return role_1.GithubActionsRole; } });
|
|
7
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsdUNBR29CO0FBRmxCLHlIQUFBLDZCQUE2QixPQUFBO0FBRy9CLCtCQUlnQjtBQUhkLHlHQUFBLGlCQUFpQixPQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHtcbiAgR2l0aHViQWN0aW9uc0lkZW50aXR5UHJvdmlkZXIsXG4gIElHaXRodWJBY3Rpb25zSWRlbnRpdHlQcm92aWRlcixcbn0gZnJvbSBcIi4vcHJvdmlkZXJcIjtcbmV4cG9ydCB7XG4gIEdpdGh1YkFjdGlvbnNSb2xlLFxuICBHaXRodWJBY3Rpb25zUm9sZVByb3BzLFxuICBHaXRodWJDb25maWd1cmF0aW9uLFxufSBmcm9tIFwiLi9yb2xlXCI7XG5leHBvcnQgeyBSb2xlUHJvcHMgfSBmcm9tIFwiLi9pYW0tcm9sZS1wcm9wc1wiO1xuIl19
|
package/lib/provider.d.ts
CHANGED
package/lib/provider.js
CHANGED
|
@@ -14,22 +14,6 @@ const iam = require("aws-cdk-lib/aws-iam");
|
|
|
14
14
|
* @see https://docs.github.com/en/actions/deployment/security-hardening-your-deployments/configuring-openid-connect-in-amazon-web-services
|
|
15
15
|
*/
|
|
16
16
|
class GithubActionsIdentityProvider extends iam.OpenIdConnectProvider {
|
|
17
|
-
/**
|
|
18
|
-
* Define a new Github OpenID Connect Identity PRovider for AWS IAM.
|
|
19
|
-
* There can be only one (per AWS Account).
|
|
20
|
-
*
|
|
21
|
-
* @param scope CDK Stack or Construct to which the provider is assigned to
|
|
22
|
-
* @param id CDK Construct ID given to the construct
|
|
23
|
-
*
|
|
24
|
-
* @example
|
|
25
|
-
* new GithubActionsIdentityProvider(scope, "GithubProvider");
|
|
26
|
-
*/
|
|
27
|
-
constructor(scope, id) {
|
|
28
|
-
super(scope, id, {
|
|
29
|
-
url: `https://${GithubActionsIdentityProvider.issuer}`,
|
|
30
|
-
clientIds: ['sts.amazonaws.com'],
|
|
31
|
-
});
|
|
32
|
-
}
|
|
33
17
|
/**
|
|
34
18
|
* Retrieve a reference to existing Github OIDC provider in your AWS account.
|
|
35
19
|
* An AWS account can only have single Github OIDC provider configured into it,
|
|
@@ -48,9 +32,25 @@ class GithubActionsIdentityProvider extends iam.OpenIdConnectProvider {
|
|
|
48
32
|
const providerArn = `arn:aws:iam::${accountId}:oidc-provider/${GithubActionsIdentityProvider.issuer}`;
|
|
49
33
|
return iam.OpenIdConnectProvider.fromOpenIdConnectProviderArn(scope, id, providerArn);
|
|
50
34
|
}
|
|
35
|
+
/**
|
|
36
|
+
* Define a new Github OpenID Connect Identity PRovider for AWS IAM.
|
|
37
|
+
* There can be only one (per AWS Account).
|
|
38
|
+
*
|
|
39
|
+
* @param scope CDK Stack or Construct to which the provider is assigned to
|
|
40
|
+
* @param id CDK Construct ID given to the construct
|
|
41
|
+
*
|
|
42
|
+
* @example
|
|
43
|
+
* new GithubActionsIdentityProvider(scope, "GithubProvider");
|
|
44
|
+
*/
|
|
45
|
+
constructor(scope, id) {
|
|
46
|
+
super(scope, id, {
|
|
47
|
+
url: `https://${GithubActionsIdentityProvider.issuer}`,
|
|
48
|
+
clientIds: ["sts.amazonaws.com"],
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
51
|
}
|
|
52
52
|
exports.GithubActionsIdentityProvider = GithubActionsIdentityProvider;
|
|
53
53
|
_a = JSII_RTTI_SYMBOL_1;
|
|
54
|
-
GithubActionsIdentityProvider[_a] = { fqn: "aws-cdk-github-oidc.GithubActionsIdentityProvider", version: "
|
|
55
|
-
GithubActionsIdentityProvider.issuer =
|
|
56
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
54
|
+
GithubActionsIdentityProvider[_a] = { fqn: "aws-cdk-github-oidc.GithubActionsIdentityProvider", version: "3.0.0" };
|
|
55
|
+
GithubActionsIdentityProvider.issuer = "token.actions.githubusercontent.com";
|
|
56
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvcHJvdmlkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxtQ0FBbUM7QUFDbkMsMkNBQTJDO0FBUzNDOzs7Ozs7O0dBT0c7QUFDSCxNQUFhLDZCQUNYLFNBQVEsR0FBRyxDQUFDLHFCQUFxQjtJQUtqQzs7Ozs7Ozs7Ozs7O09BWUc7SUFDSSxNQUFNLENBQUMsV0FBVyxDQUN2QixLQUFnQixFQUNoQixFQUFVO1FBRVYsTUFBTSxTQUFTLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUMsT0FBTyxDQUFDO1FBQzlDLE1BQU0sV0FBVyxHQUFHLGdCQUFnQixTQUFTLGtCQUFrQiw2QkFBNkIsQ0FBQyxNQUFNLEVBQUUsQ0FBQztRQUN0RyxPQUFPLEdBQUcsQ0FBQyxxQkFBcUIsQ0FBQyw0QkFBNEIsQ0FDM0QsS0FBSyxFQUNMLEVBQUUsRUFDRixXQUFXLENBQ1osQ0FBQztJQUNKLENBQUM7SUFFRDs7Ozs7Ozs7O09BU0c7SUFDSCxZQUFZLEtBQWdCLEVBQUUsRUFBVTtRQUN0QyxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsRUFBRTtZQUNmLEdBQUcsRUFBRSxXQUFXLDZCQUE2QixDQUFDLE1BQU0sRUFBRTtZQUN0RCxTQUFTLEVBQUUsQ0FBQyxtQkFBbUIsQ0FBQztTQUNqQyxDQUFDLENBQUM7SUFDTCxDQUFDOztBQS9DSCxzRUFnREM7OztBQTVDd0Isb0NBQU0sR0FBVyxxQ0FBcUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGNkayBmcm9tIFwiYXdzLWNkay1saWJcIjtcbmltcG9ydCAqIGFzIGlhbSBmcm9tIFwiYXdzLWNkay1saWIvYXdzLWlhbVwiO1xuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSBcImNvbnN0cnVjdHNcIjtcblxuLyoqXG4gKiBEZXNjcmliZXMgYSBHaXRodWIgT3BlbklEIENvbm5lY3QgSWRlbnRpdHkgUHJvdmlkZXIgZm9yIEFXUyBJQU0uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgSUdpdGh1YkFjdGlvbnNJZGVudGl0eVByb3ZpZGVyXG4gIGV4dGVuZHMgaWFtLklPcGVuSWRDb25uZWN0UHJvdmlkZXIge31cblxuLyoqXG4gKiBHaXRodWIgQWN0aW9ucyBhcyBPcGVuSUQgQ29ubmVjdCBJZGVudGl0eSBQcm92aWRlciBmb3IgQVdTIElBTS5cbiAqIFRoZXJlIGNhbiBiZSBvbmx5IG9uZSAocGVyIEFXUyBBY2NvdW50KS5cbiAqXG4gKiBVc2UgYGZyb21BY2NvdW50YCB0byByZXRyaWV2ZSBhIHJlZmVyZW5jZSB0byBleGlzdGluZyBHaXRodWIgT0lEQyBwcm92aWRlci5cbiAqXG4gKiBAc2VlIGh0dHBzOi8vZG9jcy5naXRodWIuY29tL2VuL2FjdGlvbnMvZGVwbG95bWVudC9zZWN1cml0eS1oYXJkZW5pbmcteW91ci1kZXBsb3ltZW50cy9jb25maWd1cmluZy1vcGVuaWQtY29ubmVjdC1pbi1hbWF6b24td2ViLXNlcnZpY2VzXG4gKi9cbmV4cG9ydCBjbGFzcyBHaXRodWJBY3Rpb25zSWRlbnRpdHlQcm92aWRlclxuICBleHRlbmRzIGlhbS5PcGVuSWRDb25uZWN0UHJvdmlkZXJcbiAgaW1wbGVtZW50cyBJR2l0aHViQWN0aW9uc0lkZW50aXR5UHJvdmlkZXJcbntcbiAgcHVibGljIHN0YXRpYyByZWFkb25seSBpc3N1ZXI6IHN0cmluZyA9IFwidG9rZW4uYWN0aW9ucy5naXRodWJ1c2VyY29udGVudC5jb21cIjtcblxuICAvKipcbiAgICogUmV0cmlldmUgYSByZWZlcmVuY2UgdG8gZXhpc3RpbmcgR2l0aHViIE9JREMgcHJvdmlkZXIgaW4geW91ciBBV1MgYWNjb3VudC5cbiAgICogQW4gQVdTIGFjY291bnQgY2FuIG9ubHkgaGF2ZSBzaW5nbGUgR2l0aHViIE9JREMgcHJvdmlkZXIgY29uZmlndXJlZCBpbnRvIGl0LFxuICAgKiBzbyBpbnRlcm5hbGx5IHRoZSByZWZlcmVuY2UgaXMgbWFkZSBieSBjb25zdHJ1Y3RpbmcgdGhlIEFSTiBmcm9tIEFXU1xuICAgKiBBY2NvdW50IElEICYgR2l0aHViIGlzc3VlciBVUkwuXG4gICAqXG4gICAqIEBwYXJhbSBzY29wZSBDREsgU3RhY2sgb3IgQ29uc3RydWN0IHRvIHdoaWNoIHRoZSBwcm92aWRlciBpcyBhc3NpZ25lZCB0b1xuICAgKiBAcGFyYW0gaWQgQ0RLIENvbnN0cnVjdCBJRCBnaXZlbiB0byB0aGUgY29uc3RydWN0XG4gICAqIEByZXR1cm5zIGEgQ0RLIENvbnN0cnVjdCByZXByZXNlbnRpbmcgdGhlIEdpdGh1YiBPSURDIHByb3ZpZGVyXG4gICAqXG4gICAqIEBleGFtcGxlXG4gICAqIEdpdGh1YkFjdGlvbnNJZGVudGl0eVByb3ZpZGVyLmZyb21BY2NvdW50KHNjb3BlLCBcIkdpdGh1YlByb3ZpZGVyXCIpO1xuICAgKi9cbiAgcHVibGljIHN0YXRpYyBmcm9tQWNjb3VudChcbiAgICBzY29wZTogQ29uc3RydWN0LFxuICAgIGlkOiBzdHJpbmcsXG4gICk6IElHaXRodWJBY3Rpb25zSWRlbnRpdHlQcm92aWRlciB7XG4gICAgY29uc3QgYWNjb3VudElkID0gY2RrLlN0YWNrLm9mKHNjb3BlKS5hY2NvdW50O1xuICAgIGNvbnN0IHByb3ZpZGVyQXJuID0gYGFybjphd3M6aWFtOjoke2FjY291bnRJZH06b2lkYy1wcm92aWRlci8ke0dpdGh1YkFjdGlvbnNJZGVudGl0eVByb3ZpZGVyLmlzc3Vlcn1gO1xuICAgIHJldHVybiBpYW0uT3BlbklkQ29ubmVjdFByb3ZpZGVyLmZyb21PcGVuSWRDb25uZWN0UHJvdmlkZXJBcm4oXG4gICAgICBzY29wZSxcbiAgICAgIGlkLFxuICAgICAgcHJvdmlkZXJBcm4sXG4gICAgKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBEZWZpbmUgYSBuZXcgR2l0aHViIE9wZW5JRCBDb25uZWN0IElkZW50aXR5IFBSb3ZpZGVyIGZvciBBV1MgSUFNLlxuICAgKiBUaGVyZSBjYW4gYmUgb25seSBvbmUgKHBlciBBV1MgQWNjb3VudCkuXG4gICAqXG4gICAqIEBwYXJhbSBzY29wZSBDREsgU3RhY2sgb3IgQ29uc3RydWN0IHRvIHdoaWNoIHRoZSBwcm92aWRlciBpcyBhc3NpZ25lZCB0b1xuICAgKiBAcGFyYW0gaWQgQ0RLIENvbnN0cnVjdCBJRCBnaXZlbiB0byB0aGUgY29uc3RydWN0XG4gICAqXG4gICAqIEBleGFtcGxlXG4gICAqIG5ldyBHaXRodWJBY3Rpb25zSWRlbnRpdHlQcm92aWRlcihzY29wZSwgXCJHaXRodWJQcm92aWRlclwiKTtcbiAgICovXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcpIHtcbiAgICBzdXBlcihzY29wZSwgaWQsIHtcbiAgICAgIHVybDogYGh0dHBzOi8vJHtHaXRodWJBY3Rpb25zSWRlbnRpdHlQcm92aWRlci5pc3N1ZXJ9YCxcbiAgICAgIGNsaWVudElkczogW1wic3RzLmFtYXpvbmF3cy5jb21cIl0sXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
|
package/lib/role.d.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import * as iam from
|
|
2
|
-
import { Construct } from
|
|
3
|
-
import { RoleProps } from
|
|
4
|
-
import { IGithubActionsIdentityProvider } from
|
|
1
|
+
import * as iam from "aws-cdk-lib/aws-iam";
|
|
2
|
+
import { Construct } from "constructs";
|
|
3
|
+
import { RoleProps } from "./iam-role-props";
|
|
4
|
+
import { IGithubActionsIdentityProvider } from "./provider";
|
|
5
5
|
/**
|
|
6
6
|
* Github related configuration that forms the trust policy for this IAM Role.
|
|
7
7
|
*/
|
package/lib/role.js
CHANGED
|
@@ -26,6 +26,36 @@ const provider_1 = require("./provider");
|
|
|
26
26
|
* myBucket.grantWrite(uploadRole);
|
|
27
27
|
*/
|
|
28
28
|
class GithubActionsRole extends iam.Role {
|
|
29
|
+
/**
|
|
30
|
+
* Extracts props given for the created IAM Role Construct.
|
|
31
|
+
* @param props for the GithubActionsRole
|
|
32
|
+
* @returns for the IAM Role
|
|
33
|
+
*/
|
|
34
|
+
static extractRoleProps(props) {
|
|
35
|
+
const extractProps = props;
|
|
36
|
+
delete extractProps.provider;
|
|
37
|
+
delete extractProps.owner;
|
|
38
|
+
delete extractProps.repo;
|
|
39
|
+
delete extractProps.filter;
|
|
40
|
+
return extractProps;
|
|
41
|
+
}
|
|
42
|
+
/** Validates the Github owner (organization or user) name. */
|
|
43
|
+
static validateOwner(scope, owner) {
|
|
44
|
+
if (owner_regexp_1.default.test(owner) !== true) {
|
|
45
|
+
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.`);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
/** Validates the Github repository name (without owner). */
|
|
49
|
+
static validateRepo(scope, repo) {
|
|
50
|
+
if (repo === "") {
|
|
51
|
+
cdk.Annotations.of(scope).addError(`Invalid Github Repository Name "${repo}". May not be empty string.`);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
/** Formats the `sub` value used in trust policy. */
|
|
55
|
+
static formatSubject(props) {
|
|
56
|
+
const { owner, repo, filter = "*" } = props;
|
|
57
|
+
return `repo:${owner}/${repo}:${filter}`;
|
|
58
|
+
}
|
|
29
59
|
/**
|
|
30
60
|
* Define an IAM Role that can be assumed by Github Actions workflow
|
|
31
61
|
* via Github OpenID Connect Identity Provider.
|
|
@@ -63,43 +93,13 @@ class GithubActionsRole extends iam.Role {
|
|
|
63
93
|
StringEquals: {
|
|
64
94
|
// Audience is always sts.amazonaws.com with AWS official Github Action
|
|
65
95
|
// https://docs.github.com/en/actions/deployment/security-hardening-your-deployments/configuring-openid-connect-in-amazon-web-services#adding-the-identity-provider-to-aws
|
|
66
|
-
[`${provider_1.GithubActionsIdentityProvider.issuer}:aud`]:
|
|
96
|
+
[`${provider_1.GithubActionsIdentityProvider.issuer}:aud`]: "sts.amazonaws.com",
|
|
67
97
|
},
|
|
68
98
|
}),
|
|
69
99
|
});
|
|
70
100
|
}
|
|
71
|
-
/**
|
|
72
|
-
* Extracts props given for the created IAM Role Construct.
|
|
73
|
-
* @param props for the GithubActionsRole
|
|
74
|
-
* @returns for the IAM Role
|
|
75
|
-
*/
|
|
76
|
-
static extractRoleProps(props) {
|
|
77
|
-
const extractProps = props;
|
|
78
|
-
delete extractProps.provider;
|
|
79
|
-
delete extractProps.owner;
|
|
80
|
-
delete extractProps.repo;
|
|
81
|
-
delete extractProps.filter;
|
|
82
|
-
return extractProps;
|
|
83
|
-
}
|
|
84
|
-
/** Validates the Github owner (organization or user) name. */
|
|
85
|
-
static validateOwner(scope, owner) {
|
|
86
|
-
if (owner_regexp_1.default.test(owner) !== true) {
|
|
87
|
-
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.`);
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
/** Validates the Github repository name (without owner). */
|
|
91
|
-
static validateRepo(scope, repo) {
|
|
92
|
-
if (repo === '') {
|
|
93
|
-
cdk.Annotations.of(scope).addError(`Invalid Github Repository Name "${repo}". May not be empty string.`);
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
/** Formats the `sub` value used in trust policy. */
|
|
97
|
-
static formatSubject(props) {
|
|
98
|
-
const { owner, repo, filter = '*' } = props;
|
|
99
|
-
return `repo:${owner}/${repo}:${filter}`;
|
|
100
|
-
}
|
|
101
101
|
}
|
|
102
102
|
exports.GithubActionsRole = GithubActionsRole;
|
|
103
103
|
_a = JSII_RTTI_SYMBOL_1;
|
|
104
|
-
GithubActionsRole[_a] = { fqn: "aws-cdk-github-oidc.GithubActionsRole", version: "
|
|
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"]}
|
|
104
|
+
GithubActionsRole[_a] = { fqn: "aws-cdk-github-oidc.GithubActionsRole", version: "3.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,yCAGoB;AAoEpB;;;;;;;;;;;;;;;;;GAiBG;AACH,MAAa,iBAAkB,SAAQ,GAAG,CAAC,IAAI;IAC7C;;;;OAIG;IACK,MAAM,CAAC,gBAAgB,CAC7B,KAA6B;QAE7B,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,CAAC;YAC7C,GAAG,CAAC,WAAW,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,QAAQ,CAChC,oCAAoC,KAAK,0KAA0K,CACpN,CAAC;QACJ,CAAC;IACH,CAAC;IAED,4DAA4D;IACpD,MAAM,CAAC,YAAY,CAAC,KAAgB,EAAE,IAAY;QACxD,IAAI,IAAI,KAAK,EAAE,EAAE,CAAC;YAChB,GAAG,CAAC,WAAW,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,QAAQ,CAChC,mCAAmC,IAAI,6BAA6B,CACrE,CAAC;QACJ,CAAC;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;IAED;;;;;;;;;;;;;;;;;OAiBG;IACH,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA6B;QACrE,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,CACrC,QAAQ,CAAC,wBAAwB,EACjC;gBACE,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,EAC7C,mBAAmB;iBACtB;aACF,CACF;SACF,CAAC,CAAC;IACL,CAAC;;AAzFH,8CA0FC","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 {\n  GithubActionsIdentityProvider,\n  IGithubActionsIdentityProvider,\n} from \"./provider\";\n\n/**\n * Github related configuration that forms the trust policy for this IAM Role.\n */\nexport interface GithubConfiguration {\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\n  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   * 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(\n    props: GithubActionsRoleProps,\n  ): 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(\n        `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\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(\n        `Invalid Github Repository Name \"${repo}\". May not be empty string.`,\n      );\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   * 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    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(\n        provider.openIdConnectProviderArn,\n        {\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`]:\n              \"sts.amazonaws.com\",\n          },\n        },\n      ),\n    });\n  }\n}\n"]}
|
package/package.json
CHANGED
|
@@ -5,69 +5,41 @@
|
|
|
5
5
|
"type": "git",
|
|
6
6
|
"url": "https://github.com/aripalo/aws-cdk-github-oidc.git"
|
|
7
7
|
},
|
|
8
|
-
"scripts": {
|
|
9
|
-
"build": "npx projen build",
|
|
10
|
-
"bump": "npx projen bump",
|
|
11
|
-
"clobber": "npx projen clobber",
|
|
12
|
-
"compat": "npx projen compat",
|
|
13
|
-
"compile": "npx projen compile",
|
|
14
|
-
"default": "npx projen default",
|
|
15
|
-
"docgen": "npx projen docgen",
|
|
16
|
-
"eject": "npx projen eject",
|
|
17
|
-
"eslint": "npx projen eslint",
|
|
18
|
-
"package": "npx projen package",
|
|
19
|
-
"package-all": "npx projen package-all",
|
|
20
|
-
"package:go": "npx projen package:go",
|
|
21
|
-
"package:js": "npx projen package:js",
|
|
22
|
-
"package:python": "npx projen package:python",
|
|
23
|
-
"post-compile": "npx projen post-compile",
|
|
24
|
-
"post-upgrade": "npx projen post-upgrade",
|
|
25
|
-
"pre-compile": "npx projen pre-compile",
|
|
26
|
-
"release": "npx projen release",
|
|
27
|
-
"test": "npx projen test",
|
|
28
|
-
"test:watch": "npx projen test:watch",
|
|
29
|
-
"unbump": "npx projen unbump",
|
|
30
|
-
"upgrade": "npx projen upgrade",
|
|
31
|
-
"watch": "npx projen watch",
|
|
32
|
-
"projen": "npx projen"
|
|
33
|
-
},
|
|
34
8
|
"author": {
|
|
35
9
|
"name": "Ari Palo",
|
|
36
10
|
"email": "opensource@aripalo.com",
|
|
37
|
-
"organization":
|
|
11
|
+
"organization": true
|
|
38
12
|
},
|
|
39
13
|
"devDependencies": {
|
|
40
|
-
"@
|
|
41
|
-
"@types/jest": "^
|
|
42
|
-
"@types/node": "^
|
|
43
|
-
"@typescript-eslint/eslint-plugin": "^
|
|
44
|
-
"@typescript-eslint/parser": "^
|
|
45
|
-
"aws-cdk-lib": "2.
|
|
46
|
-
"
|
|
47
|
-
"
|
|
48
|
-
"eslint
|
|
14
|
+
"@alma-cdk/construct-library": "0.0.20",
|
|
15
|
+
"@types/jest": "^30",
|
|
16
|
+
"@types/node": "^20",
|
|
17
|
+
"@typescript-eslint/eslint-plugin": "^8",
|
|
18
|
+
"@typescript-eslint/parser": "^8",
|
|
19
|
+
"aws-cdk-lib": "2.220.0",
|
|
20
|
+
"commit-and-tag-version": "^12",
|
|
21
|
+
"constructs": "10.3.0",
|
|
22
|
+
"eslint": "^9",
|
|
23
|
+
"eslint-config-prettier": "^10.1.8",
|
|
49
24
|
"eslint-import-resolver-typescript": "^2.7.1",
|
|
50
25
|
"eslint-plugin-import": "^2.28.0",
|
|
51
|
-
"
|
|
52
|
-
"jest
|
|
53
|
-
"
|
|
26
|
+
"eslint-plugin-prettier": "^5.5.5",
|
|
27
|
+
"jest": "^30",
|
|
28
|
+
"jest-junit": "^16",
|
|
29
|
+
"jsii": "~5.9.0",
|
|
54
30
|
"jsii-diff": "^1.86.1",
|
|
55
|
-
"jsii-docgen": "^
|
|
31
|
+
"jsii-docgen": "^10.5.0",
|
|
56
32
|
"jsii-pacmak": "^1.86.1",
|
|
57
|
-
"jsii-rosetta": "
|
|
58
|
-
"
|
|
59
|
-
"projen": "^0.
|
|
60
|
-
"
|
|
61
|
-
"ts-
|
|
62
|
-
"typescript": "^
|
|
33
|
+
"jsii-rosetta": "~5.9.0",
|
|
34
|
+
"prettier": "^3.8.1",
|
|
35
|
+
"projen": "^0.99.27",
|
|
36
|
+
"ts-jest": "^29",
|
|
37
|
+
"ts-node": "^10.9.2",
|
|
38
|
+
"typescript": "^5.9"
|
|
63
39
|
},
|
|
64
40
|
"peerDependencies": {
|
|
65
|
-
"aws-cdk-lib": "^2.
|
|
66
|
-
"constructs": "^10.
|
|
67
|
-
},
|
|
68
|
-
"overrides": {
|
|
69
|
-
"@types/babel__traverse": "7.18.2",
|
|
70
|
-
"@types/prettier": "2.6.0"
|
|
41
|
+
"aws-cdk-lib": "^2.220.0",
|
|
42
|
+
"constructs": "^10.3.0"
|
|
71
43
|
},
|
|
72
44
|
"keywords": [
|
|
73
45
|
"aws",
|
|
@@ -81,15 +53,21 @@
|
|
|
81
53
|
"openid-connect"
|
|
82
54
|
],
|
|
83
55
|
"engines": {
|
|
84
|
-
"node": ">=
|
|
56
|
+
"node": ">= 20 <= 24"
|
|
85
57
|
},
|
|
86
58
|
"main": "lib/index.js",
|
|
87
59
|
"license": "Apache-2.0",
|
|
88
|
-
"
|
|
60
|
+
"publishConfig": {
|
|
61
|
+
"access": "public"
|
|
62
|
+
},
|
|
63
|
+
"version": "3.0.0",
|
|
89
64
|
"jest": {
|
|
65
|
+
"coverageProvider": "v8",
|
|
90
66
|
"testMatch": [
|
|
91
|
-
"<rootDir
|
|
92
|
-
"<rootDir
|
|
67
|
+
"<rootDir>/@(src|test)/**/*(*.)@(spec|test).ts?(x)",
|
|
68
|
+
"<rootDir>/@(src|test)/**/__tests__/**/*.ts?(x)",
|
|
69
|
+
"<rootDir>/@(projenrc)/**/*(*.)@(spec|test).ts?(x)",
|
|
70
|
+
"<rootDir>/@(projenrc)/**/__tests__/**/*.ts?(x)"
|
|
93
71
|
],
|
|
94
72
|
"clearMocks": true,
|
|
95
73
|
"collectCoverage": true,
|
|
@@ -119,11 +97,13 @@
|
|
|
119
97
|
}
|
|
120
98
|
]
|
|
121
99
|
],
|
|
122
|
-
"
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
100
|
+
"transform": {
|
|
101
|
+
"^.+\\.[t]sx?$": [
|
|
102
|
+
"ts-jest",
|
|
103
|
+
{
|
|
104
|
+
"tsconfig": "tsconfig.dev.json"
|
|
105
|
+
}
|
|
106
|
+
]
|
|
127
107
|
}
|
|
128
108
|
},
|
|
129
109
|
"types": "lib/index.d.ts",
|
|
@@ -144,5 +124,33 @@
|
|
|
144
124
|
"rootDir": "src"
|
|
145
125
|
}
|
|
146
126
|
},
|
|
147
|
-
"//": "~~ Generated by projen. To modify, edit .projenrc.
|
|
148
|
-
|
|
127
|
+
"//": "~~ Generated by projen. To modify, edit .projenrc.ts and run \"pnpm exec projen\".",
|
|
128
|
+
"scripts": {
|
|
129
|
+
"build": "pnpm exec projen build",
|
|
130
|
+
"bump": "pnpm exec projen bump",
|
|
131
|
+
"clobber": "pnpm exec projen clobber",
|
|
132
|
+
"compat": "pnpm exec projen compat",
|
|
133
|
+
"compile": "pnpm exec projen compile",
|
|
134
|
+
"default": "pnpm exec projen default",
|
|
135
|
+
"docgen": "pnpm exec projen docgen",
|
|
136
|
+
"eject": "pnpm exec projen eject",
|
|
137
|
+
"eslint": "pnpm exec projen eslint",
|
|
138
|
+
"format": "pnpm exec projen format",
|
|
139
|
+
"package": "pnpm exec projen package",
|
|
140
|
+
"package-all": "pnpm exec projen package-all",
|
|
141
|
+
"package:go": "pnpm exec projen package:go",
|
|
142
|
+
"package:js": "pnpm exec projen package:js",
|
|
143
|
+
"package:python": "pnpm exec projen package:python",
|
|
144
|
+
"post-compile": "pnpm exec projen post-compile",
|
|
145
|
+
"post-upgrade": "pnpm exec projen post-upgrade",
|
|
146
|
+
"pre-compile": "pnpm exec projen pre-compile",
|
|
147
|
+
"release": "pnpm exec projen release",
|
|
148
|
+
"test": "pnpm exec projen test",
|
|
149
|
+
"test:update": "pnpm exec projen test:update",
|
|
150
|
+
"test:watch": "pnpm exec projen test:watch",
|
|
151
|
+
"unbump": "pnpm exec projen unbump",
|
|
152
|
+
"upgrade": "pnpm exec projen upgrade",
|
|
153
|
+
"watch": "pnpm exec projen watch",
|
|
154
|
+
"projen": "pnpm exec projen"
|
|
155
|
+
}
|
|
156
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
# ~~ Generated by projen. To modify, edit .projenrc.ts and run "pnpm exec projen".
|
|
2
|
+
|
|
3
|
+
minimumReleaseAge: 4320
|
|
4
|
+
minimumReleaseAgeExclude:
|
|
5
|
+
- "@alma-cdk/construct-library"
|
|
6
|
+
trustPolicy: no-downgrade
|
|
7
|
+
trustPolicyIgnoreAfter: 20160
|
|
8
|
+
trustPolicyExclude:
|
|
9
|
+
- jsii@5.9.33
|
|
10
|
+
- jsii@5.9.35
|
|
11
|
+
nodeLinker: hoisted
|
|
12
|
+
resolutionMode: highest
|
|
13
|
+
strictDepBuilds: true
|
|
14
|
+
onlyBuiltDependencies:
|
|
15
|
+
- unrs-resolver
|
|
16
|
+
blockExoticSubdeps: true
|
|
17
|
+
overrides: {}
|
package/.gitattributes
DELETED
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
# ~~ Generated by projen. To modify, edit .projenrc.js and run "npx projen".
|
|
2
|
-
|
|
3
|
-
*.snap linguist-generated
|
|
4
|
-
/.eslintrc.json linguist-generated
|
|
5
|
-
/.gitattributes linguist-generated
|
|
6
|
-
/.github/pull_request_template.md linguist-generated
|
|
7
|
-
/.github/workflows/build.yml linguist-generated
|
|
8
|
-
/.github/workflows/pull-request-lint.yml linguist-generated
|
|
9
|
-
/.github/workflows/release.yml linguist-generated
|
|
10
|
-
/.github/workflows/upgrade-main.yml linguist-generated
|
|
11
|
-
/.gitignore linguist-generated
|
|
12
|
-
/.mergify.yml linguist-generated
|
|
13
|
-
/.npmignore linguist-generated
|
|
14
|
-
/.npmrc linguist-generated
|
|
15
|
-
/.nvmrc linguist-generated
|
|
16
|
-
/.projen/** linguist-generated
|
|
17
|
-
/.projen/deps.json linguist-generated
|
|
18
|
-
/.projen/files.json linguist-generated
|
|
19
|
-
/.projen/tasks.json linguist-generated
|
|
20
|
-
/API.md linguist-generated
|
|
21
|
-
/LICENSE linguist-generated
|
|
22
|
-
/package-lock.json linguist-generated
|
|
23
|
-
/package.json linguist-generated
|
|
24
|
-
/tsconfig.dev.json linguist-generated
|