1 | ;
|
2 | var _a;
|
3 | Object.defineProperty(exports, "__esModule", { value: true });
|
4 | exports.UsagePlan = exports.Period = void 0;
|
5 | const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
|
6 | const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
7 | const core_1 = require("@aws-cdk/core");
|
8 | const cx_api_1 = require("@aws-cdk/cx-api");
|
9 | const apigateway_generated_1 = require("./apigateway.generated");
|
10 | const util_1 = require("./util");
|
11 | /**
|
12 | * Time period for which quota settings apply.
|
13 | */
|
14 | var Period;
|
15 | (function (Period) {
|
16 | Period["DAY"] = "DAY";
|
17 | Period["WEEK"] = "WEEK";
|
18 | Period["MONTH"] = "MONTH";
|
19 | })(Period = exports.Period || (exports.Period = {}));
|
20 | class 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 | }
|
47 | class 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 | }
|
173 | exports.UsagePlan = UsagePlan;
|
174 | _a = JSII_RTTI_SYMBOL_1;
|
175 | UsagePlan[_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":";;;;;;AAAA,wCAAsF;AACtF,4CAA8E;AAG9E,iEAAuE;AAIvE,iCAAyD;AAoBzD;;GAEG;AACH,IAAY,MAIX;AAJD,WAAY,MAAM;IAChB,qBAAW,CAAA;IACX,uBAAa,CAAA;IACb,yBAAe,CAAA;AACjB,CAAC,EAJW,MAAM,GAAN,cAAM,KAAN,cAAM,QAIjB;AA+ID,MAAe,aAAc,SAAQ,eAAQ;IAO3C;;;;;OAKG;IACI,SAAS,CAAC,MAAe,EAAE,OAA0B;QAC1D,IAAI,EAAU,CAAC;QACf,MAAM,MAAM,GAAG,sBAAsB,CAAC;QAEtC,IAAI,mBAAY,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,oDAA2C,CAAC,EAAE;YAChF,EAAE,GAAG,GAAG,MAAM,IAAI,YAAK,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC;SACrD;aAAM;YACL,sHAAsH;YACtH,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,MAAM,IAAI,YAAK,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC;SAC/F;QAED,MAAM,QAAQ,GAAG,IAAI,sCAAe,CAAC,IAAI,EAAE,EAAE,EAAE;YAC7C,KAAK,EAAE,MAAM,CAAC,KAAK;YACnB,OAAO,yBAA0B;YACjC,WAAW,EAAE,IAAI,CAAC,WAAW;SAC9B,CAAC,CAAC;QACH,IAAI,OAAO,EAAE,iBAAiB,EAAE;YAC9B,QAAQ,CAAC,iBAAiB,CAAC,OAAO,EAAE,iBAAiB,CAAC,CAAC;SACxD;KACF;CAEF;AAED,MAAa,SAAU,SAAQ,aAAa;IA2B1C,YAAY,KAAgB,EAAE,EAAU,EAAE,QAAwB,EAAG;QACnE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAHF,cAAS,GAAG,IAAI,KAAK,EAAwB,CAAC;;;;;;+CAzBpD,SAAS;;;;QA6BlB,IAAI,QAAsB,CAAC;QAE3B,QAAQ,GAAG,IAAI,mCAAY,CAAC,IAAI,EAAE,UAAU,EAAE;YAC5C,SAAS,EAAE,WAAI,CAAC,GAAG,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC;YAC5E,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;YAC9B,QAAQ,EAAE,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,QAAQ,CAAC;YAC7C,aAAa,EAAE,KAAK,CAAC,IAAI;SAC1B,CAAC,CAAC;QAEH,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,SAAS,IAAI,EAAE,CAAC,CAAC,CAAC;QAEhD,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC,GAAG,CAAC;QAEhC,kBAAkB;QAClB,IAAI,KAAK,CAAC,MAAM,EAAE;YAChB,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;SAC9B;KACF;IA7CD;;;;;;OAMG;IACI,MAAM,CAAC,eAAe,CAAC,KAAgB,EAAE,EAAU,EAAE,WAAmB;QAC7E,MAAM,MAAO,SAAQ,aAAa;YAGhC;gBACE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;gBAHH,gBAAW,GAAG,WAAW,CAAC;YAI1C,CAAC;SACF;QACD,OAAO,IAAI,MAAM,EAAE,CAAC;KACrB;IA+BD;;;OAGG;IACI,WAAW,CAAC,QAA8B;;;;;;;;;;QAC/C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;KAC/B;IAED;;;OAGG;IACK,eAAe,CAAC,SAA6C;QACnE,IAAI,SAAS,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE;YACrC,MAAM,MAAM,GAAoC,EAAE,CAAC;YACnD,SAAS,CAAC,OAAO,CAAC,CAAC,QAA8B,EAAE,EAAE;gBACnD,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC,CAAC;YAC1C,CAAC,CAAC,CAAC;YACH,OAAO,MAAM,CAAC;SACf;QACD,OAAO,SAAS,CAAC;KAClB;IAEO,WAAW,CAAC,QAA8B;QAChD,MAAM,KAAK,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;QAC/E,MAAM,KAAK,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC;QAC5E,MAAM,QAAQ,GAAG,IAAI,CAAC,uBAAuB,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;QACjE,OAAO;YACL,KAAK;YACL,KAAK;YACL,QAAQ;SACT,CAAC;KACH;IAEO,WAAW,CAAC,KAAqB;QACvC,IAAI,KAAK,CAAC,KAAK,KAAK,SAAS,EAAE;YAC7B,OAAO,SAAS,CAAC;SAClB;aAAM;YACL,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC;YAC1D,sBAAe,CAAC,KAAK,EAAE,sBAAsB,CAAC,CAAC;YAC/C,MAAM,GAAG,GAAG;gBACV,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS;gBAChC,MAAM,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS;gBACpD,MAAM,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS;aACrD,CAAC;YACF,OAAO,GAAG,CAAC;SACZ;KACF;IAEO,cAAc,CAAC,KAAmC;QACxD,IAAI,GAAkD,CAAC;QACvD,IAAI,KAAK,KAAK,SAAS,EAAE;YACvB,MAAM,UAAU,GAAG,KAAK,CAAC,UAAU,CAAC;YACpC,sBAAe,CAAC,UAAU,EAAE,sBAAsB,CAAC,CAAC;YACpD,MAAM,SAAS,GAAG,KAAK,CAAC,SAAS,CAAC;YAClC,qBAAc,CAAC,SAAS,EAAE,qBAAqB,CAAC,CAAC;YAEjD,GAAG,GAAG;gBACJ,UAAU,EAAE,UAAU;gBACtB,SAAS,EAAE,SAAS;aACrB,CAAC;SACH;QACD,OAAO,GAAI,CAAC;KACb;IAEO,uBAAuB,CAAC,iBAAyC;QACvE,MAAM,GAAG,GAAuE,EAAE,CAAC;QACnF,IAAI,iBAAiB,IAAI,iBAAiB,CAAC,MAAM,GAAG,CAAC,EAAE;YACrD,iBAAiB,CAAC,OAAO,CAAC,CAAC,KAA0B,EAAE,EAAE;gBACvD,MAAM,MAAM,GAAW,KAAK,CAAC,MAAM,CAAC;gBACpC,0EAA0E;gBAC1E,MAAM,QAAQ,GAAG,GAAG,MAAM,CAAC,QAAQ,CAAC,IAAI,IAAI,MAAM,CAAC,UAAU,EAAE,CAAC;gBAChE,GAAG,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;YACtD,CAAC,CAAC,CAAC;SACJ;QACD,OAAO,GAAG,CAAC;KACZ;;AA7HH,8BA8HC","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 |