1 | ;
|
2 | var _a;
|
3 | Object.defineProperty(exports, "__esModule", { value: true });
|
4 | exports.OpenIdConnectProvider = void 0;
|
5 | const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
|
6 | const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
7 | const path = require("path");
|
8 | const core_1 = require("@aws-cdk/core");
|
9 | const RESOURCE_TYPE = 'Custom::AWSCDKOpenIdConnectProvider';
|
10 | /**
|
11 | * IAM OIDC identity providers are entities in IAM that describe an external
|
12 | * identity provider (IdP) service that supports the OpenID Connect (OIDC)
|
13 | * standard, such as Google or Salesforce. You use an IAM OIDC identity provider
|
14 | * when you want to establish trust between an OIDC-compatible IdP and your AWS
|
15 | * account. This is useful when creating a mobile app or web application that
|
16 | * requires access to AWS resources, but you don't want to create custom sign-in
|
17 | * code or manage your own user identities.
|
18 | *
|
19 | * @see http://openid.net/connect
|
20 | * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles_providers_oidc.html
|
21 | *
|
22 | * @resource AWS::CloudFormation::CustomResource
|
23 | */
|
24 | class OpenIdConnectProvider extends core_1.Resource {
|
25 | /**
|
26 | * Defines an OpenID Connect provider.
|
27 | * @param scope The definition scope
|
28 | * @param id Construct ID
|
29 | * @param props Initialization properties
|
30 | */
|
31 | constructor(scope, id, props) {
|
32 | super(scope, id);
|
33 | try {
|
34 | jsiiDeprecationWarnings._aws_cdk_aws_iam_OpenIdConnectProviderProps(props);
|
35 | }
|
36 | catch (error) {
|
37 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
38 | Error.captureStackTrace(error, this.constructor);
|
39 | }
|
40 | throw error;
|
41 | }
|
42 | const resource = new core_1.CustomResource(this, 'Resource', {
|
43 | resourceType: RESOURCE_TYPE,
|
44 | serviceToken: this.getOrCreateProvider(),
|
45 | properties: {
|
46 | ClientIDList: props.clientIds,
|
47 | ThumbprintList: props.thumbprints,
|
48 | Url: props.url,
|
49 | },
|
50 | });
|
51 | this.openIdConnectProviderArn = core_1.Token.asString(resource.ref);
|
52 | this.openIdConnectProviderIssuer = core_1.Arn.extractResourceName(this.openIdConnectProviderArn, 'oidc-provider');
|
53 | }
|
54 | /**
|
55 | * Imports an Open ID connect provider from an ARN.
|
56 | * @param scope The definition scope
|
57 | * @param id ID of the construct
|
58 | * @param openIdConnectProviderArn the ARN to import
|
59 | */
|
60 | static fromOpenIdConnectProviderArn(scope, id, openIdConnectProviderArn) {
|
61 | const resourceName = core_1.Arn.extractResourceName(openIdConnectProviderArn, 'oidc-provider');
|
62 | class Import extends core_1.Resource {
|
63 | constructor() {
|
64 | super(...arguments);
|
65 | this.openIdConnectProviderArn = openIdConnectProviderArn;
|
66 | this.openIdConnectProviderIssuer = resourceName;
|
67 | }
|
68 | }
|
69 | return new Import(scope, id);
|
70 | }
|
71 | getOrCreateProvider() {
|
72 | return core_1.CustomResourceProvider.getOrCreate(this, RESOURCE_TYPE, {
|
73 | codeDirectory: path.join(__dirname, 'oidc-provider'),
|
74 | runtime: core_1.CustomResourceProviderRuntime.NODEJS_12_X,
|
75 | policyStatements: [
|
76 | {
|
77 | Effect: 'Allow',
|
78 | Resource: '*',
|
79 | Action: [
|
80 | 'iam:CreateOpenIDConnectProvider',
|
81 | 'iam:DeleteOpenIDConnectProvider',
|
82 | 'iam:UpdateOpenIDConnectProviderThumbprint',
|
83 | 'iam:AddClientIDToOpenIDConnectProvider',
|
84 | 'iam:RemoveClientIDFromOpenIDConnectProvider',
|
85 | ],
|
86 | },
|
87 | ],
|
88 | });
|
89 | }
|
90 | }
|
91 | exports.OpenIdConnectProvider = OpenIdConnectProvider;
|
92 | _a = JSII_RTTI_SYMBOL_1;
|
93 | OpenIdConnectProvider[_a] = { fqn: "@aws-cdk/aws-iam.OpenIdConnectProvider", version: "1.156.1" };
|
94 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"oidc-provider.js","sourceRoot":"","sources":["oidc-provider.ts"],"names":[],"mappings":";;;;;;AAAA,6BAA6B;AAC7B,wCAQuB;AAGvB,MAAM,aAAa,GAAG,qCAAqC,CAAC;AA6E5D;;;;;;;;;;;;;GAaG;AACH,MAAa,qBAAsB,SAAQ,eAAQ;IAyBjD;;;;;OAKG;IACH,YAAmB,KAAgB,EAAE,EAAU,EAAE,KAAiC;QAChF,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;;;;;;;;;;QAEjB,MAAM,QAAQ,GAAG,IAAI,qBAAc,CAAC,IAAI,EAAE,UAAU,EAAE;YACpD,YAAY,EAAE,aAAa;YAC3B,YAAY,EAAE,IAAI,CAAC,mBAAmB,EAAE;YACxC,UAAU,EAAE;gBACV,YAAY,EAAE,KAAK,CAAC,SAAS;gBAC7B,cAAc,EAAE,KAAK,CAAC,WAAW;gBACjC,GAAG,EAAE,KAAK,CAAC,GAAG;aACf;SACF,CAAC,CAAC;QAEH,IAAI,CAAC,wBAAwB,GAAG,YAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;QAC7D,IAAI,CAAC,2BAA2B,GAAG,UAAG,CAAC,mBAAmB,CAAC,IAAI,CAAC,wBAAwB,EAAE,eAAe,CAAC,CAAC;KAC5G;IA7CD;;;;;OAKG;IACI,MAAM,CAAC,4BAA4B,CAAC,KAAgB,EAAE,EAAU,EAAE,wBAAgC;QACvG,MAAM,YAAY,GAAG,UAAG,CAAC,mBAAmB,CAAC,wBAAwB,EAAE,eAAe,CAAC,CAAC;QAExF,MAAM,MAAO,SAAQ,eAAQ;YAA7B;;gBACkB,6BAAwB,GAAG,wBAAwB,CAAC;gBACpD,gCAA2B,GAAG,YAAY,CAAC;YAC7D,CAAC;SAAA;QAED,OAAO,IAAI,MAAM,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;KAC9B;IAgCO,mBAAmB;QACzB,OAAO,6BAAsB,CAAC,WAAW,CAAC,IAAI,EAAE,aAAa,EAAE;YAC7D,aAAa,EAAE,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,eAAe,CAAC;YACpD,OAAO,EAAE,oCAA6B,CAAC,WAAW;YAClD,gBAAgB,EAAE;gBAChB;oBACE,MAAM,EAAE,OAAO;oBACf,QAAQ,EAAE,GAAG;oBACb,MAAM,EAAE;wBACN,iCAAiC;wBACjC,iCAAiC;wBACjC,2CAA2C;wBAC3C,wCAAwC;wBACxC,6CAA6C;qBAC9C;iBACF;aACF;SACF,CAAC,CAAC;KACJ;;AAlEH,sDAmEC","sourcesContent":["import * as path from 'path';\nimport {\n  Arn,\n  CustomResource,\n  CustomResourceProvider,\n  CustomResourceProviderRuntime,\n  IResource,\n  Resource,\n  Token,\n} from '@aws-cdk/core';\nimport { Construct } from 'constructs';\n\nconst RESOURCE_TYPE = 'Custom::AWSCDKOpenIdConnectProvider';\n\n/**\n * Represents an IAM OpenID Connect provider.\n *\n */\nexport interface IOpenIdConnectProvider extends IResource {\n  /**\n   * The Amazon Resource Name (ARN) of the IAM OpenID Connect provider.\n   */\n  readonly openIdConnectProviderArn: string;\n\n  /**\n   * The issuer for OIDC Provider\n   */\n  readonly openIdConnectProviderIssuer: string;\n}\n\n/**\n * Initialization properties for `OpenIdConnectProvider`.\n */\nexport interface OpenIdConnectProviderProps {\n  /**\n   * The URL of the identity provider. The URL must begin with https:// and\n   * should correspond to the iss claim in the provider's OpenID Connect ID\n   * tokens. Per the OIDC standard, path components are allowed but query\n   * parameters are not. Typically the URL consists of only a hostname, like\n   * https://server.example.org or https://example.com.\n   *\n   * You cannot register the same provider multiple times in a single AWS\n   * account. If you try to submit a URL that has already been used for an\n   * OpenID Connect provider in the AWS account, you will get an error.\n   */\n  readonly url: string;\n\n  /**\n   * A list of client IDs (also known as audiences). When a mobile or web app\n   * registers with an OpenID Connect provider, they establish a value that\n   * identifies the application. (This is the value that's sent as the client_id\n   * parameter on OAuth requests.)\n   *\n   * You can register multiple client IDs with the same provider. For example,\n   * you might have multiple applications that use the same OIDC provider. You\n   * cannot register more than 100 client IDs with a single IAM OIDC provider.\n   *\n   * Client IDs are up to 255 characters long.\n   *\n   * @default - no clients are allowed\n   */\n  readonly clientIds?: string[];\n\n  /**\n   * A list of server certificate thumbprints for the OpenID Connect (OIDC)\n   * identity provider's server certificates.\n   *\n   * Typically this list includes only one entry. However, IAM lets you have up\n   * to five thumbprints for an OIDC provider. This lets you maintain multiple\n   * thumbprints if the identity provider is rotating certificates.\n   *\n   * The server certificate thumbprint is the hex-encoded SHA-1 hash value of\n   * the X.509 certificate used by the domain where the OpenID Connect provider\n   * makes its keys available. It is always a 40-character string.\n   *\n   * You must provide at least one thumbprint when creating an IAM OIDC\n   * provider. For example, assume that the OIDC provider is server.example.com\n   * and the provider stores its keys at\n   * https://keys.server.example.com/openid-connect. In that case, the\n   * thumbprint string would be the hex-encoded SHA-1 hash value of the\n   * certificate used by https://keys.server.example.com.\n   *\n   * @default - If no thumbprints are specified (an empty array or `undefined`),\n   * the thumbprint of the root certificate authority will be obtained from the\n   * provider's server as described in https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles_providers_create_oidc_verify-thumbprint.html\n   */\n  readonly thumbprints?: string[];\n}\n\n/**\n * IAM OIDC identity providers are entities in IAM that describe an external\n * identity provider (IdP) service that supports the OpenID Connect (OIDC)\n * standard, such as Google or Salesforce. You use an IAM OIDC identity provider\n * when you want to establish trust between an OIDC-compatible IdP and your AWS\n * account. This is useful when creating a mobile app or web application that\n * requires access to AWS resources, but you don't want to create custom sign-in\n * code or manage your own user identities.\n *\n * @see http://openid.net/connect\n * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles_providers_oidc.html\n *\n * @resource AWS::CloudFormation::CustomResource\n */\nexport class OpenIdConnectProvider extends Resource implements IOpenIdConnectProvider {\n  /**\n   * Imports an Open ID connect provider from an ARN.\n   * @param scope The definition scope\n   * @param id ID of the construct\n   * @param openIdConnectProviderArn the ARN to import\n   */\n  public static fromOpenIdConnectProviderArn(scope: Construct, id: string, openIdConnectProviderArn: string): IOpenIdConnectProvider {\n    const resourceName = Arn.extractResourceName(openIdConnectProviderArn, 'oidc-provider');\n\n    class Import extends Resource implements IOpenIdConnectProvider {\n      public readonly openIdConnectProviderArn = openIdConnectProviderArn;\n      public readonly openIdConnectProviderIssuer = resourceName;\n    }\n\n    return new Import(scope, id);\n  }\n\n  /**\n   * The Amazon Resource Name (ARN) of the IAM OpenID Connect provider.\n   */\n  public readonly openIdConnectProviderArn: string;\n\n  public readonly openIdConnectProviderIssuer: string;\n\n  /**\n   * Defines an OpenID Connect provider.\n   * @param scope The definition scope\n   * @param id Construct ID\n   * @param props Initialization properties\n   */\n  public constructor(scope: Construct, id: string, props: OpenIdConnectProviderProps) {\n    super(scope, id);\n\n    const resource = new CustomResource(this, 'Resource', {\n      resourceType: RESOURCE_TYPE,\n      serviceToken: this.getOrCreateProvider(),\n      properties: {\n        ClientIDList: props.clientIds,\n        ThumbprintList: props.thumbprints,\n        Url: props.url,\n      },\n    });\n\n    this.openIdConnectProviderArn = Token.asString(resource.ref);\n    this.openIdConnectProviderIssuer = Arn.extractResourceName(this.openIdConnectProviderArn, 'oidc-provider');\n  }\n\n  private getOrCreateProvider() {\n    return CustomResourceProvider.getOrCreate(this, RESOURCE_TYPE, {\n      codeDirectory: path.join(__dirname, 'oidc-provider'),\n      runtime: CustomResourceProviderRuntime.NODEJS_12_X,\n      policyStatements: [\n        {\n          Effect: 'Allow',\n          Resource: '*',\n          Action: [\n            'iam:CreateOpenIDConnectProvider',\n            'iam:DeleteOpenIDConnectProvider',\n            'iam:UpdateOpenIDConnectProviderThumbprint',\n            'iam:AddClientIDToOpenIDConnectProvider',\n            'iam:RemoveClientIDFromOpenIDConnectProvider',\n          ],\n        },\n      ],\n    });\n  }\n}\n"]} |
\ | No newline at end of file |