UNPKG

@aws-cdk/aws-apigateway

Version:

The CDK Construct Library for AWS::ApiGateway

168 lines 20 kB
"use strict"; var _a, _b; Object.defineProperty(exports, "__esModule", { value: true }); exports.RateLimitedApiKey = exports.ApiKey = void 0; const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const iam = require("@aws-cdk/aws-iam"); const core_1 = require("@aws-cdk/core"); const apigateway_generated_1 = require("./apigateway.generated"); const usage_plan_1 = require("./usage-plan"); /** * Base implementation that is common to the various implementations of IApiKey */ class ApiKeyBase extends core_1.Resource { /** * Permits the IAM principal all read operations through this key * * @param grantee The principal to grant access to */ grantRead(grantee) { return iam.Grant.addToPrincipal({ grantee, actions: readPermissions, resourceArns: [this.keyArn], }); } /** * Permits the IAM principal all write operations through this key * * @param grantee The principal to grant access to */ grantWrite(grantee) { return iam.Grant.addToPrincipal({ grantee, actions: writePermissions, resourceArns: [this.keyArn], }); } /** * Permits the IAM principal all read and write operations through this key * * @param grantee The principal to grant access to */ grantReadWrite(grantee) { return iam.Grant.addToPrincipal({ grantee, actions: [...readPermissions, ...writePermissions], resourceArns: [this.keyArn], }); } } /** * An API Gateway ApiKey. * * An ApiKey can be distributed to API clients that are executing requests * for Method resources that require an Api Key. */ class ApiKey extends ApiKeyBase { constructor(scope, id, props = {}) { super(scope, id, { physicalName: props.apiKeyName, }); try { jsiiDeprecationWarnings._aws_cdk_aws_apigateway_ApiKeyProps(props); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, ApiKey); } throw error; } const resource = new apigateway_generated_1.CfnApiKey(this, 'Resource', { customerId: props.customerId, description: props.description, enabled: props.enabled ?? true, generateDistinctId: props.generateDistinctId, name: this.physicalName, stageKeys: this.renderStageKeys(props.resources), value: props.value, }); this.keyId = resource.ref; this.keyArn = core_1.Stack.of(this).formatArn({ service: 'apigateway', account: '', resource: '/apikeys', arnFormat: core_1.ArnFormat.SLASH_RESOURCE_NAME, resourceName: this.keyId, }); } /** * Import an ApiKey by its Id */ static fromApiKeyId(scope, id, apiKeyId) { class Import extends ApiKeyBase { constructor() { super(...arguments); this.keyId = apiKeyId; this.keyArn = core_1.Stack.of(this).formatArn({ service: 'apigateway', account: '', resource: '/apikeys', arnFormat: core_1.ArnFormat.SLASH_RESOURCE_NAME, resourceName: apiKeyId, }); } } return new Import(scope, id); } renderStageKeys(resources) { if (!resources) { return undefined; } return resources.map((resource) => { const restApi = resource; const restApiId = restApi.restApiId; const stageName = restApi.deploymentStage.stageName.toString(); return { restApiId, stageName }; }); } } exports.ApiKey = ApiKey; _a = JSII_RTTI_SYMBOL_1; ApiKey[_a] = { fqn: "@aws-cdk/aws-apigateway.ApiKey", version: "1.204.0" }; /** * An API Gateway ApiKey, for which a rate limiting configuration can be specified. * * @resource AWS::ApiGateway::ApiKey */ class RateLimitedApiKey extends ApiKeyBase { constructor(scope, id, props = {}) { super(scope, id, { physicalName: props.apiKeyName, }); try { jsiiDeprecationWarnings._aws_cdk_aws_apigateway_RateLimitedApiKeyProps(props); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, RateLimitedApiKey); } throw error; } const resource = new ApiKey(this, 'Resource', props); if (props.apiStages || props.quota || props.throttle) { const usageplan = new usage_plan_1.UsagePlan(this, 'UsagePlanResource', { apiStages: props.apiStages, quota: props.quota, throttle: props.throttle, }); usageplan.addApiKey(resource); } this.keyId = resource.keyId; this.keyArn = resource.keyArn; } } exports.RateLimitedApiKey = RateLimitedApiKey; _b = JSII_RTTI_SYMBOL_1; RateLimitedApiKey[_b] = { fqn: "@aws-cdk/aws-apigateway.RateLimitedApiKey", version: "1.204.0" }; const readPermissions = [ 'apigateway:GET', ]; const writePermissions = [ 'apigateway:POST', 'apigateway:PUT', 'apigateway:PATCH', 'apigateway:DELETE', ]; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api-key.js","sourceRoot":"","sources":["api-key.ts"],"names":[],"mappings":"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","sourcesContent":["import * as iam from '@aws-cdk/aws-iam';\nimport { ArnFormat, IResource as IResourceBase, Resource, Stack } from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { CfnApiKey } from './apigateway.generated';\nimport { ResourceOptions } from './resource';\nimport { IRestApi } from './restapi';\nimport { QuotaSettings, ThrottleSettings, UsagePlan, UsagePlanPerApiStage } from './usage-plan';\n\n/**\n * API keys are alphanumeric string values that you distribute to\n * app developer customers to grant access to your API\n */\nexport interface IApiKey extends IResourceBase {\n  /**\n   * The API key ID.\n   * @attribute\n   */\n  readonly keyId: string;\n\n  /**\n   * The API key ARN.\n   */\n  readonly keyArn: string;\n}\n\n/**\n * The options for creating an API Key.\n */\nexport interface ApiKeyOptions extends ResourceOptions {\n  /**\n   * A name for the API key. If you don't specify a name, AWS CloudFormation generates a unique physical ID and uses that ID for the API key name.\n   * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-apigateway-apikey.html#cfn-apigateway-apikey-name\n   * @default automically generated name\n   */\n  readonly apiKeyName?: string;\n\n  /**\n   * The value of the API key. Must be at least 20 characters long.\n   * @link https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-apigateway-apikey.html#cfn-apigateway-apikey-value\n   * @default none\n   */\n  readonly value?: string;\n\n  /**\n   * A description of the purpose of the API key.\n   * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-apigateway-apikey.html#cfn-apigateway-apikey-description\n   * @default none\n   */\n  readonly description?: string;\n}\n\n/**\n * ApiKey Properties.\n */\nexport interface ApiKeyProps extends ApiKeyOptions {\n  /**\n   * A list of resources this api key is associated with.\n   * @default none\n   */\n  readonly resources?: IRestApi[];\n\n  /**\n   * An AWS Marketplace customer identifier to use when integrating with the AWS SaaS Marketplace.\n   * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-apigateway-apikey.html#cfn-apigateway-apikey-customerid\n   * @default none\n   */\n  readonly customerId?: string;\n\n  /**\n   * Indicates whether the API key can be used by clients.\n   * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-apigateway-apikey.html#cfn-apigateway-apikey-enabled\n   * @default true\n   */\n  readonly enabled?: boolean;\n\n  /**\n   * Specifies whether the key identifier is distinct from the created API key value.\n   * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-apigateway-apikey.html#cfn-apigateway-apikey-generatedistinctid\n   * @default false\n   */\n  readonly generateDistinctId?: boolean;\n}\n\n/**\n * Base implementation that is common to the various implementations of IApiKey\n */\nabstract class ApiKeyBase extends Resource implements IApiKey {\n  public abstract readonly keyId: string;\n  public abstract readonly keyArn: string;\n\n  /**\n   * Permits the IAM principal all read operations through this key\n   *\n   * @param grantee The principal to grant access to\n   */\n  public grantRead(grantee: iam.IGrantable): iam.Grant {\n    return iam.Grant.addToPrincipal({\n      grantee,\n      actions: readPermissions,\n      resourceArns: [this.keyArn],\n    });\n  }\n\n  /**\n   * Permits the IAM principal all write operations through this key\n   *\n   * @param grantee The principal to grant access to\n   */\n  public grantWrite(grantee: iam.IGrantable): iam.Grant {\n    return iam.Grant.addToPrincipal({\n      grantee,\n      actions: writePermissions,\n      resourceArns: [this.keyArn],\n    });\n  }\n\n  /**\n   * Permits the IAM principal all read and write operations through this key\n   *\n   * @param grantee The principal to grant access to\n   */\n  public grantReadWrite(grantee: iam.IGrantable): iam.Grant {\n    return iam.Grant.addToPrincipal({\n      grantee,\n      actions: [...readPermissions, ...writePermissions],\n      resourceArns: [this.keyArn],\n    });\n  }\n}\n\n/**\n * An API Gateway ApiKey.\n *\n * An ApiKey can be distributed to API clients that are executing requests\n * for Method resources that require an Api Key.\n */\nexport class ApiKey extends ApiKeyBase {\n\n  /**\n   * Import an ApiKey by its Id\n   */\n  public static fromApiKeyId(scope: Construct, id: string, apiKeyId: string): IApiKey {\n    class Import extends ApiKeyBase {\n      public keyId = apiKeyId;\n      public keyArn = Stack.of(this).formatArn({\n        service: 'apigateway',\n        account: '',\n        resource: '/apikeys',\n        arnFormat: ArnFormat.SLASH_RESOURCE_NAME,\n        resourceName: apiKeyId,\n      });\n    }\n\n    return new Import(scope, id);\n  }\n\n  public readonly keyId: string;\n  public readonly keyArn: string;\n\n  constructor(scope: Construct, id: string, props: ApiKeyProps = { }) {\n    super(scope, id, {\n      physicalName: props.apiKeyName,\n    });\n\n    const resource = new CfnApiKey(this, 'Resource', {\n      customerId: props.customerId,\n      description: props.description,\n      enabled: props.enabled ?? true,\n      generateDistinctId: props.generateDistinctId,\n      name: this.physicalName,\n      stageKeys: this.renderStageKeys(props.resources),\n      value: props.value,\n    });\n\n    this.keyId = resource.ref;\n    this.keyArn = Stack.of(this).formatArn({\n      service: 'apigateway',\n      account: '',\n      resource: '/apikeys',\n      arnFormat: ArnFormat.SLASH_RESOURCE_NAME,\n      resourceName: this.keyId,\n    });\n  }\n\n  private renderStageKeys(resources: IRestApi[] | undefined): CfnApiKey.StageKeyProperty[] | undefined {\n    if (!resources) {\n      return undefined;\n    }\n\n    return resources.map((resource: IRestApi) => {\n      const restApi = resource;\n      const restApiId = restApi.restApiId;\n      const stageName = restApi.deploymentStage!.stageName.toString();\n      return { restApiId, stageName };\n    });\n  }\n}\n\n/**\n * RateLimitedApiKey properties.\n */\nexport interface RateLimitedApiKeyProps extends ApiKeyProps {\n  /**\n   * API Stages to be associated with the RateLimitedApiKey.\n   * @default none\n   */\n  readonly apiStages?: UsagePlanPerApiStage[];\n\n  /**\n   * Number of requests clients can make in a given time period.\n   * @default none\n   */\n  readonly quota?: QuotaSettings;\n\n  /**\n   * Overall throttle settings for the API.\n   * @default none\n   */\n  readonly throttle?: ThrottleSettings;\n}\n\n/**\n * An API Gateway ApiKey, for which a rate limiting configuration can be specified.\n *\n * @resource AWS::ApiGateway::ApiKey\n */\nexport class RateLimitedApiKey extends ApiKeyBase {\n  public readonly keyId: string;\n  public readonly keyArn: string;\n\n  constructor(scope: Construct, id: string, props: RateLimitedApiKeyProps = { }) {\n    super(scope, id, {\n      physicalName: props.apiKeyName,\n    });\n\n    const resource = new ApiKey(this, 'Resource', props);\n\n    if (props.apiStages || props.quota || props.throttle) {\n      const usageplan = new UsagePlan(this, 'UsagePlanResource', {\n        apiStages: props.apiStages,\n        quota: props.quota,\n        throttle: props.throttle,\n      });\n      usageplan.addApiKey(resource);\n    }\n\n    this.keyId = resource.keyId;\n    this.keyArn = resource.keyArn;\n  }\n}\n\nconst readPermissions = [\n  'apigateway:GET',\n];\n\nconst writePermissions = [\n  'apigateway:POST',\n  'apigateway:PUT',\n  'apigateway:PATCH',\n  'apigateway:DELETE',\n];"]}