UNPKG

14.7 kBJavaScriptView Raw
1"use strict";
2var _a;
3Object.defineProperty(exports, "__esModule", { value: true });
4exports.OpenIdConnectProvider = void 0;
5const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
6const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
7const path = require("path");
8const core_1 = require("@aws-cdk/core");
9const 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 */
24class 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, OpenIdConnectProvider);
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_14_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}
91exports.OpenIdConnectProvider = OpenIdConnectProvider;
92_a = JSII_RTTI_SYMBOL_1;
93OpenIdConnectProvider[_a] = { fqn: "@aws-cdk/aws-iam.OpenIdConnectProvider", version: "1.161.0" };
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;;;;;;+CAhCR,qBAAqB;;;;QAkC9B,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_14_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