UNPKG

@aws-cdk/aws-iam

Version:

CDK routines for easily assigning correct and minimal IAM permissions

100 lines 16.2 kB
"use strict"; var _a; Object.defineProperty(exports, "__esModule", { value: true }); exports.OpenIdConnectProvider = void 0; const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const path = require("path"); const core_1 = require("@aws-cdk/core"); const RESOURCE_TYPE = 'Custom::AWSCDKOpenIdConnectProvider'; /** * IAM OIDC identity providers are entities in IAM that describe an external * identity provider (IdP) service that supports the OpenID Connect (OIDC) * standard, such as Google or Salesforce. You use an IAM OIDC identity provider * when you want to establish trust between an OIDC-compatible IdP and your AWS * account. This is useful when creating a mobile app or web application that * requires access to AWS resources, but you don't want to create custom sign-in * code or manage your own user identities. * * @see http://openid.net/connect * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles_providers_oidc.html * * @resource AWS::CloudFormation::CustomResource */ class OpenIdConnectProvider extends core_1.Resource { /** * Defines an OpenID Connect provider. * @param scope The definition scope * @param id Construct ID * @param props Initialization properties */ constructor(scope, id, props) { super(scope, id); try { jsiiDeprecationWarnings._aws_cdk_aws_iam_OpenIdConnectProviderProps(props); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, OpenIdConnectProvider); } throw error; } const provider = this.getOrCreateProvider(); const resource = new core_1.CustomResource(this, 'Resource', { resourceType: RESOURCE_TYPE, serviceToken: provider.serviceToken, properties: { ClientIDList: props.clientIds, ThumbprintList: props.thumbprints, Url: props.url, // code changes can cause thumbprint changes in case they weren't explicitly provided. // add the code hash as a property so that CFN invokes the UPDATE handler in these cases, // thus updating the thumbprint if necessary. CodeHash: provider.codeHash, }, }); this.openIdConnectProviderArn = core_1.Token.asString(resource.ref); this.openIdConnectProviderIssuer = core_1.Arn.extractResourceName(this.openIdConnectProviderArn, 'oidc-provider'); this.openIdConnectProviderthumbprints = core_1.Token.asString(resource.getAtt('Thumbprints')); } /** * Imports an Open ID connect provider from an ARN. * @param scope The definition scope * @param id ID of the construct * @param openIdConnectProviderArn the ARN to import */ static fromOpenIdConnectProviderArn(scope, id, openIdConnectProviderArn) { const resourceName = core_1.Arn.extractResourceName(openIdConnectProviderArn, 'oidc-provider'); class Import extends core_1.Resource { constructor() { super(...arguments); this.openIdConnectProviderArn = openIdConnectProviderArn; this.openIdConnectProviderIssuer = resourceName; } } return new Import(scope, id); } getOrCreateProvider() { return core_1.CustomResourceProvider.getOrCreateProvider(this, RESOURCE_TYPE, { codeDirectory: path.join(__dirname, 'oidc-provider'), runtime: core_1.CustomResourceProviderRuntime.NODEJS_16_X, policyStatements: [ { Effect: 'Allow', Resource: '*', Action: [ 'iam:CreateOpenIDConnectProvider', 'iam:DeleteOpenIDConnectProvider', 'iam:UpdateOpenIDConnectProviderThumbprint', 'iam:AddClientIDToOpenIDConnectProvider', 'iam:RemoveClientIDFromOpenIDConnectProvider', ], }, ], }); } } exports.OpenIdConnectProvider = OpenIdConnectProvider; _a = JSII_RTTI_SYMBOL_1; OpenIdConnectProvider[_a] = { fqn: "@aws-cdk/aws-iam.OpenIdConnectProvider", version: "1.204.0" }; //# 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;IA8BjD;;;;;OAKG;IACH,YAAmB,KAAgB,EAAE,EAAU,EAAE,KAAiC;QAChF,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;;;;;;+CArCR,qBAAqB;;;;QAuC9B,MAAM,QAAQ,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC5C,MAAM,QAAQ,GAAG,IAAI,qBAAc,CAAC,IAAI,EAAE,UAAU,EAAE;YACpD,YAAY,EAAE,aAAa;YAC3B,YAAY,EAAE,QAAQ,CAAC,YAAY;YACnC,UAAU,EAAE;gBACV,YAAY,EAAE,KAAK,CAAC,SAAS;gBAC7B,cAAc,EAAE,KAAK,CAAC,WAAW;gBACjC,GAAG,EAAE,KAAK,CAAC,GAAG;gBAEd,sFAAsF;gBACtF,yFAAyF;gBACzF,6CAA6C;gBAC7C,QAAQ,EAAE,QAAQ,CAAC,QAAQ;aAC5B;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;QAC3G,IAAI,CAAC,gCAAgC,GAAG,YAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC;KACxF;IAzDD;;;;;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;IA4CO,mBAAmB;QACzB,OAAO,6BAAsB,CAAC,mBAAmB,CAAC,IAAI,EAAE,aAAa,EAAE;YACrE,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;;AA9EH,sDA+EC","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   * The thumbprints configured for this provider.\n   */\n  public readonly openIdConnectProviderthumbprints: 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 provider = this.getOrCreateProvider();\n    const resource = new CustomResource(this, 'Resource', {\n      resourceType: RESOURCE_TYPE,\n      serviceToken: provider.serviceToken,\n      properties: {\n        ClientIDList: props.clientIds,\n        ThumbprintList: props.thumbprints,\n        Url: props.url,\n\n        // code changes can cause thumbprint changes in case they weren't explicitly provided.\n        // add the code hash as a property so that CFN invokes the UPDATE handler in these cases,\n        // thus updating the thumbprint if necessary.\n        CodeHash: provider.codeHash,\n      },\n    });\n\n    this.openIdConnectProviderArn = Token.asString(resource.ref);\n    this.openIdConnectProviderIssuer = Arn.extractResourceName(this.openIdConnectProviderArn, 'oidc-provider');\n    this.openIdConnectProviderthumbprints = Token.asString(resource.getAtt('Thumbprints'));\n  }\n\n  private getOrCreateProvider() {\n    return CustomResourceProvider.getOrCreateProvider(this, RESOURCE_TYPE, {\n      codeDirectory: path.join(__dirname, 'oidc-provider'),\n      runtime: CustomResourceProviderRuntime.NODEJS_16_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"]}