UNPKG

24.6 kBJavaScriptView Raw
1"use strict";
2var _a;
3Object.defineProperty(exports, "__esModule", { value: true });
4exports.UsagePlan = exports.Period = void 0;
5const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
6const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
7const core_1 = require("@aws-cdk/core");
8const cx_api_1 = require("@aws-cdk/cx-api");
9const apigateway_generated_1 = require("./apigateway.generated");
10const util_1 = require("./util");
11/**
12 * Time period for which quota settings apply.
13 */
14var Period;
15(function (Period) {
16 Period["DAY"] = "DAY";
17 Period["WEEK"] = "WEEK";
18 Period["MONTH"] = "MONTH";
19})(Period = exports.Period || (exports.Period = {}));
20class UsagePlanBase extends core_1.Resource {
21 /**
22 * Adds an ApiKey.
23 *
24 * @param apiKey the api key to associate with this usage plan
25 * @param options options that control the behaviour of this method
26 */
27 addApiKey(apiKey, options) {
28 let id;
29 const prefix = 'UsagePlanKeyResource';
30 if (core_1.FeatureFlags.of(this).isEnabled(cx_api_1.APIGATEWAY_USAGEPLANKEY_ORDERINSENSITIVE_ID)) {
31 id = `${prefix}:${core_1.Names.nodeUniqueId(apiKey.node)}`;
32 }
33 else {
34 // Postfixing apikey id only from the 2nd child, to keep physicalIds of UsagePlanKey for existing CDK apps unmodified.
35 id = this.node.tryFindChild(prefix) ? `${prefix}:${core_1.Names.nodeUniqueId(apiKey.node)}` : prefix;
36 }
37 const resource = new apigateway_generated_1.CfnUsagePlanKey(this, id, {
38 keyId: apiKey.keyId,
39 keyType: "API_KEY" /* API_KEY */,
40 usagePlanId: this.usagePlanId,
41 });
42 if (options?.overrideLogicalId) {
43 resource.overrideLogicalId(options?.overrideLogicalId);
44 }
45 }
46}
47class UsagePlan extends UsagePlanBase {
48 constructor(scope, id, props = {}) {
49 super(scope, id);
50 this.apiStages = new Array();
51 try {
52 jsiiDeprecationWarnings._aws_cdk_aws_apigateway_UsagePlanProps(props);
53 }
54 catch (error) {
55 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
56 Error.captureStackTrace(error, UsagePlan);
57 }
58 throw error;
59 }
60 let resource;
61 resource = new apigateway_generated_1.CfnUsagePlan(this, 'Resource', {
62 apiStages: core_1.Lazy.any({ produce: () => this.renderApiStages(this.apiStages) }),
63 description: props.description,
64 quota: this.renderQuota(props),
65 throttle: this.renderThrottle(props.throttle),
66 usagePlanName: props.name,
67 });
68 this.apiStages.push(...(props.apiStages || []));
69 this.usagePlanId = resource.ref;
70 // Add ApiKey when
71 if (props.apiKey) {
72 this.addApiKey(props.apiKey);
73 }
74 }
75 /**
76 * Import an externally defined usage plan using its ARN.
77 *
78 * @param scope the construct that will "own" the imported usage plan.
79 * @param id the id of the imported usage plan in the construct tree.
80 * @param usagePlanId the id of an existing usage plan.
81 */
82 static fromUsagePlanId(scope, id, usagePlanId) {
83 class Import extends UsagePlanBase {
84 constructor() {
85 super(scope, id);
86 this.usagePlanId = usagePlanId;
87 }
88 }
89 return new Import();
90 }
91 /**
92 * Adds an apiStage.
93 * @param apiStage
94 */
95 addApiStage(apiStage) {
96 try {
97 jsiiDeprecationWarnings._aws_cdk_aws_apigateway_UsagePlanPerApiStage(apiStage);
98 }
99 catch (error) {
100 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
101 Error.captureStackTrace(error, this.addApiStage);
102 }
103 throw error;
104 }
105 this.apiStages.push(apiStage);
106 }
107 /**
108 *
109 * @param props
110 */
111 renderApiStages(apiStages) {
112 if (apiStages && apiStages.length > 0) {
113 const stages = [];
114 apiStages.forEach((apiStage) => {
115 stages.push(this.createStage(apiStage));
116 });
117 return stages;
118 }
119 return undefined;
120 }
121 createStage(apiStage) {
122 const stage = apiStage.stage ? apiStage.stage.stageName.toString() : undefined;
123 const apiId = apiStage.stage ? apiStage.stage.restApi.restApiId : undefined;
124 const throttle = this.renderThrottlePerMethod(apiStage.throttle);
125 return {
126 apiId,
127 stage,
128 throttle,
129 };
130 }
131 renderQuota(props) {
132 if (props.quota === undefined) {
133 return undefined;
134 }
135 else {
136 const limit = props.quota ? props.quota.limit : undefined;
137 util_1.validateInteger(limit, 'Throttle quota limit');
138 const ret = {
139 limit: limit ? limit : undefined,
140 offset: props.quota ? props.quota.offset : undefined,
141 period: props.quota ? props.quota.period : undefined,
142 };
143 return ret;
144 }
145 }
146 renderThrottle(props) {
147 let ret;
148 if (props !== undefined) {
149 const burstLimit = props.burstLimit;
150 util_1.validateInteger(burstLimit, 'Throttle burst limit');
151 const rateLimit = props.rateLimit;
152 util_1.validateDouble(rateLimit, 'Throttle rate limit');
153 ret = {
154 burstLimit: burstLimit,
155 rateLimit: rateLimit,
156 };
157 }
158 return ret;
159 }
160 renderThrottlePerMethod(throttlePerMethod) {
161 const ret = {};
162 if (throttlePerMethod && throttlePerMethod.length > 0) {
163 throttlePerMethod.forEach((value) => {
164 const method = value.method;
165 // this methodId is resource path and method for example /GET or /pets/GET
166 const methodId = `${method.resource.path}/${method.httpMethod}`;
167 ret[methodId] = this.renderThrottle(value.throttle);
168 });
169 }
170 return ret;
171 }
172}
173exports.UsagePlan = UsagePlan;
174_a = JSII_RTTI_SYMBOL_1;
175UsagePlan[_a] = { fqn: "@aws-cdk/aws-apigateway.UsagePlan", version: "1.173.0" };
176//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"usage-plan.js","sourceRoot":"","sources":["usage-plan.ts"],"names":[],"mappings":"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","sourcesContent":["import { FeatureFlags, IResource, Lazy, Names, Resource, Token } from '@aws-cdk/core';\nimport { APIGATEWAY_USAGEPLANKEY_ORDERINSENSITIVE_ID } from '@aws-cdk/cx-api';\nimport { Construct } from 'constructs';\nimport { IApiKey } from './api-key';\nimport { CfnUsagePlan, CfnUsagePlanKey } from './apigateway.generated';\nimport { Method } from './method';\nimport { IRestApi } from './restapi';\nimport { Stage } from './stage';\nimport { validateDouble, validateInteger } from './util';\n\n/**\n * Container for defining throttling parameters to API stages or methods.\n * @link https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-request-throttling.html\n */\nexport interface ThrottleSettings {\n  /**\n   * The API request steady-state rate limit (average requests per second over an extended period of time)\n   * @default none\n   */\n  readonly rateLimit?: number;\n\n  /**\n   * The maximum API request rate limit over a time ranging from one to a few seconds.\n   * @default none\n   */\n  readonly burstLimit?: number;\n}\n\n/**\n * Time period for which quota settings apply.\n */\nexport enum Period {\n  DAY = 'DAY',\n  WEEK = 'WEEK',\n  MONTH = 'MONTH'\n}\n\n/**\n * Specifies the maximum number of requests that clients can make to API Gateway APIs.\n */\nexport interface QuotaSettings {\n  /**\n   * The maximum number of requests that users can make within the specified time period.\n   * @default none\n   */\n  readonly limit?: number;\n\n  /**\n   * For the initial time period, the number of requests to subtract from the specified limit.\n   * @default none\n   */\n  readonly offset?: number;\n\n  /**\n   * The time period for which the maximum limit of requests applies.\n   * @default none\n   */\n  readonly period?: Period;\n}\n\n/**\n * Represents per-method throttling for a resource.\n */\nexport interface ThrottlingPerMethod {\n  /**\n   * [disable-awslint:ref-via-interface]\n   * The method for which you specify the throttling settings.\n   * @default none\n   */\n  readonly method: Method;\n\n  /**\n   * Specifies the overall request rate (average requests per second) and burst capacity.\n   * @default none\n   */\n  readonly throttle: ThrottleSettings;\n}\n\n/**\n * Type of Usage Plan Key. Currently the only supported type is 'ApiKey'\n */\nconst enum UsagePlanKeyType {\n  API_KEY = 'API_KEY'\n}\n\n/**\n * Represents the API stages that a usage plan applies to.\n */\nexport interface UsagePlanPerApiStage {\n\n  /**\n   * @default none\n   */\n  readonly api?: IRestApi;\n\n  /**\n   *\n   * [disable-awslint:ref-via-interface]\n   * @default none\n   */\n  readonly stage?: Stage;\n\n  /**\n   * @default none\n   */\n  readonly throttle?: ThrottlingPerMethod[];\n}\n\nexport interface UsagePlanProps {\n  /**\n   * API Stages to be associated with the usage plan.\n   * @default none\n   */\n  readonly apiStages?: UsagePlanPerApiStage[];\n\n  /**\n   * Represents usage plan purpose.\n   * @default none\n   */\n  readonly description?: string;\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   * Name for this usage plan.\n   * @default none\n   */\n  readonly name?: string;\n\n  /**\n   * ApiKey to be associated with the usage plan.\n   * @default none\n   * @deprecated use `addApiKey()`\n   */\n  readonly apiKey?: IApiKey;\n}\n\n/**\n * Options to the UsagePlan.addApiKey() method\n */\nexport interface AddApiKeyOptions {\n  /**\n   * Override the CloudFormation logical id of the AWS::ApiGateway::UsagePlanKey resource\n   * @default - autogenerated by the CDK\n   */\n  readonly overrideLogicalId?: string;\n}\n\n/**\n * A UsagePlan, either managed by this CDK app, or imported.\n */\nexport interface IUsagePlan extends IResource {\n  /**\n   * Id of the usage plan\n   * @attribute\n   */\n  readonly usagePlanId: string;\n\n  /**\n   * Adds an ApiKey.\n   *\n   * @param apiKey the api key to associate with this usage plan\n   * @param options options that control the behaviour of this method\n   */\n  addApiKey(apiKey: IApiKey, options?: AddApiKeyOptions): void;\n\n}\n\nabstract class UsagePlanBase extends Resource implements IUsagePlan {\n  /**\n   * Id of the usage plan\n   * @attribute\n   */\n  public abstract readonly usagePlanId: string;\n\n  /**\n   * Adds an ApiKey.\n   *\n   * @param apiKey the api key to associate with this usage plan\n   * @param options options that control the behaviour of this method\n   */\n  public addApiKey(apiKey: IApiKey, options?: AddApiKeyOptions): void {\n    let id: string;\n    const prefix = 'UsagePlanKeyResource';\n\n    if (FeatureFlags.of(this).isEnabled(APIGATEWAY_USAGEPLANKEY_ORDERINSENSITIVE_ID)) {\n      id = `${prefix}:${Names.nodeUniqueId(apiKey.node)}`;\n    } else {\n      // Postfixing apikey id only from the 2nd child, to keep physicalIds of UsagePlanKey for existing CDK apps unmodified.\n      id = this.node.tryFindChild(prefix) ? `${prefix}:${Names.nodeUniqueId(apiKey.node)}` : prefix;\n    }\n\n    const resource = new CfnUsagePlanKey(this, id, {\n      keyId: apiKey.keyId,\n      keyType: UsagePlanKeyType.API_KEY,\n      usagePlanId: this.usagePlanId,\n    });\n    if (options?.overrideLogicalId) {\n      resource.overrideLogicalId(options?.overrideLogicalId);\n    }\n  }\n\n}\n\nexport class UsagePlan extends UsagePlanBase {\n\n  /**\n   * Import an externally defined usage plan using its ARN.\n   *\n   * @param scope  the construct that will \"own\" the imported usage plan.\n   * @param id     the id of the imported usage plan in the construct tree.\n   * @param usagePlanId the id of an existing usage plan.\n   */\n  public static fromUsagePlanId(scope: Construct, id: string, usagePlanId: string): IUsagePlan {\n    class Import extends UsagePlanBase {\n      public readonly usagePlanId = usagePlanId;\n\n      constructor() {\n        super(scope, id);\n      }\n    }\n    return new Import();\n  }\n\n  /**\n   * @attribute\n   */\n  public readonly usagePlanId: string;\n\n  private readonly apiStages = new Array<UsagePlanPerApiStage>();\n\n  constructor(scope: Construct, id: string, props: UsagePlanProps = { }) {\n    super(scope, id);\n    let resource: CfnUsagePlan;\n\n    resource = new CfnUsagePlan(this, 'Resource', {\n      apiStages: Lazy.any({ produce: () => this.renderApiStages(this.apiStages) }),\n      description: props.description,\n      quota: this.renderQuota(props),\n      throttle: this.renderThrottle(props.throttle),\n      usagePlanName: props.name,\n    });\n\n    this.apiStages.push(...(props.apiStages || []));\n\n    this.usagePlanId = resource.ref;\n\n    // Add ApiKey when\n    if (props.apiKey) {\n      this.addApiKey(props.apiKey);\n    }\n  }\n\n  /**\n   * Adds an apiStage.\n   * @param apiStage\n   */\n  public addApiStage(apiStage: UsagePlanPerApiStage) {\n    this.apiStages.push(apiStage);\n  }\n\n  /**\n   *\n   * @param props\n   */\n  private renderApiStages(apiStages: UsagePlanPerApiStage[] | undefined): CfnUsagePlan.ApiStageProperty[] | undefined {\n    if (apiStages && apiStages.length > 0) {\n      const stages: CfnUsagePlan.ApiStageProperty[] = [];\n      apiStages.forEach((apiStage: UsagePlanPerApiStage) => {\n        stages.push(this.createStage(apiStage));\n      });\n      return stages;\n    }\n    return undefined;\n  }\n\n  private createStage(apiStage: UsagePlanPerApiStage): CfnUsagePlan.ApiStageProperty {\n    const stage = apiStage.stage ? apiStage.stage.stageName.toString() : undefined;\n    const apiId = apiStage.stage ? apiStage.stage.restApi.restApiId : undefined;\n    const throttle = this.renderThrottlePerMethod(apiStage.throttle);\n    return {\n      apiId,\n      stage,\n      throttle,\n    };\n  }\n\n  private renderQuota(props: UsagePlanProps) {\n    if (props.quota === undefined) {\n      return undefined;\n    } else {\n      const limit = props.quota ? props.quota.limit : undefined;\n      validateInteger(limit, 'Throttle quota limit');\n      const ret = {\n        limit: limit ? limit : undefined,\n        offset: props.quota ? props.quota.offset : undefined,\n        period: props.quota ? props.quota.period : undefined,\n      };\n      return ret;\n    }\n  }\n\n  private renderThrottle(props: ThrottleSettings | undefined): (CfnUsagePlan.ThrottleSettingsProperty | Token) {\n    let ret: CfnUsagePlan.ThrottleSettingsProperty | Token;\n    if (props !== undefined) {\n      const burstLimit = props.burstLimit;\n      validateInteger(burstLimit, 'Throttle burst limit');\n      const rateLimit = props.rateLimit;\n      validateDouble(rateLimit, 'Throttle rate limit');\n\n      ret = {\n        burstLimit: burstLimit,\n        rateLimit: rateLimit,\n      };\n    }\n    return ret!;\n  }\n\n  private renderThrottlePerMethod(throttlePerMethod?: ThrottlingPerMethod[]) {\n    const ret: { [key: string]: (CfnUsagePlan.ThrottleSettingsProperty | Token) } = {};\n    if (throttlePerMethod && throttlePerMethod.length > 0) {\n      throttlePerMethod.forEach((value: ThrottlingPerMethod) => {\n        const method: Method = value.method;\n        // this methodId is resource path and method for example /GET or /pets/GET\n        const methodId = `${method.resource.path}/${method.httpMethod}`;\n        ret[methodId] = this.renderThrottle(value.throttle);\n      });\n    }\n    return ret;\n  }\n}\n"]}
\No newline at end of file