Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@aws-cdk/aws-apigateway

Package Overview
Dependencies
Maintainers
5
Versions
288
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@aws-cdk/aws-apigateway - npm Package Compare versions

Comparing version 0.36.0 to 0.36.1

lib/base-path-mapping.d.ts

4

lib/index.d.ts

@@ -14,4 +14,8 @@ export * from './restapi';

export * from './model';
export * from './requestvalidator';
export * from './authorizer';
export * from './json-schema';
export * from './domain-name';
export * from './base-path-mapping';
export * from './apigateway.generated';
export * from './apigatewayv2.generated';

@@ -18,2 +18,6 @@ "use strict";

__export(require("./model"));
__export(require("./requestvalidator"));
__export(require("./json-schema"));
__export(require("./domain-name"));
__export(require("./base-path-mapping"));
// AWS::ApiGateway CloudFormation Resources:

@@ -23,2 +27,2 @@ __export(require("./apigateway.generated"));

__export(require("./apigatewayv2.generated"));
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLCtCQUEwQjtBQUMxQixnQ0FBMkI7QUFDM0IsOEJBQXlCO0FBQ3pCLG1DQUE4QjtBQUM5QixrQ0FBNkI7QUFDN0IsNkJBQXdCO0FBQ3hCLG9DQUErQjtBQUMvQixrQ0FBNkI7QUFDN0IsK0JBQTBCO0FBQzFCLGtDQUE2QjtBQUM3QixnQ0FBMkI7QUFFM0IsNkJBQXdCO0FBR3hCLDRDQUE0QztBQUM1Qyw0Q0FBdUM7QUFDdkMsOENBQThDO0FBQzlDLDhDQUF5QyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vcmVzdGFwaSc7XG5leHBvcnQgKiBmcm9tICcuL3Jlc291cmNlJztcbmV4cG9ydCAqIGZyb20gJy4vbWV0aG9kJztcbmV4cG9ydCAqIGZyb20gJy4vaW50ZWdyYXRpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9kZXBsb3ltZW50JztcbmV4cG9ydCAqIGZyb20gJy4vc3RhZ2UnO1xuZXhwb3J0ICogZnJvbSAnLi9pbnRlZ3JhdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9sYW1iZGEtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vYXBpLWtleSc7XG5leHBvcnQgKiBmcm9tICcuL3VzYWdlLXBsYW4nO1xuZXhwb3J0ICogZnJvbSAnLi92cGMtbGluayc7XG5leHBvcnQgKiBmcm9tICcuL21ldGhvZHJlc3BvbnNlJztcbmV4cG9ydCAqIGZyb20gJy4vbW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9hdXRob3JpemVyJztcblxuLy8gQVdTOjpBcGlHYXRld2F5IENsb3VkRm9ybWF0aW9uIFJlc291cmNlczpcbmV4cG9ydCAqIGZyb20gJy4vYXBpZ2F0ZXdheS5nZW5lcmF0ZWQnO1xuLy8gQVdTOjpBcGlHYXRld2F5VjIgQ2xvdWRGb3JtYXRpb24gcmVzb3VyY2VzOlxuZXhwb3J0ICogZnJvbSAnLi9hcGlnYXRld2F5djIuZ2VuZXJhdGVkJztcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLCtCQUEwQjtBQUMxQixnQ0FBMkI7QUFDM0IsOEJBQXlCO0FBQ3pCLG1DQUE4QjtBQUM5QixrQ0FBNkI7QUFDN0IsNkJBQXdCO0FBQ3hCLG9DQUErQjtBQUMvQixrQ0FBNkI7QUFDN0IsK0JBQTBCO0FBQzFCLGtDQUE2QjtBQUM3QixnQ0FBMkI7QUFFM0IsNkJBQXdCO0FBQ3hCLHdDQUFtQztBQUVuQyxtQ0FBOEI7QUFDOUIsbUNBQThCO0FBQzlCLHlDQUFvQztBQUVwQyw0Q0FBNEM7QUFDNUMsNENBQXVDO0FBQ3ZDLDhDQUE4QztBQUM5Qyw4Q0FBeUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3Jlc3RhcGknO1xuZXhwb3J0ICogZnJvbSAnLi9yZXNvdXJjZSc7XG5leHBvcnQgKiBmcm9tICcuL21ldGhvZCc7XG5leHBvcnQgKiBmcm9tICcuL2ludGVncmF0aW9uJztcbmV4cG9ydCAqIGZyb20gJy4vZGVwbG95bWVudCc7XG5leHBvcnQgKiBmcm9tICcuL3N0YWdlJztcbmV4cG9ydCAqIGZyb20gJy4vaW50ZWdyYXRpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vbGFtYmRhLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL2FwaS1rZXknO1xuZXhwb3J0ICogZnJvbSAnLi91c2FnZS1wbGFuJztcbmV4cG9ydCAqIGZyb20gJy4vdnBjLWxpbmsnO1xuZXhwb3J0ICogZnJvbSAnLi9tZXRob2RyZXNwb25zZSc7XG5leHBvcnQgKiBmcm9tICcuL21vZGVsJztcbmV4cG9ydCAqIGZyb20gJy4vcmVxdWVzdHZhbGlkYXRvcic7XG5leHBvcnQgKiBmcm9tICcuL2F1dGhvcml6ZXInO1xuZXhwb3J0ICogZnJvbSAnLi9qc29uLXNjaGVtYSc7XG5leHBvcnQgKiBmcm9tICcuL2RvbWFpbi1uYW1lJztcbmV4cG9ydCAqIGZyb20gJy4vYmFzZS1wYXRoLW1hcHBpbmcnO1xuXG4vLyBBV1M6OkFwaUdhdGV3YXkgQ2xvdWRGb3JtYXRpb24gUmVzb3VyY2VzOlxuZXhwb3J0ICogZnJvbSAnLi9hcGlnYXRld2F5LmdlbmVyYXRlZCc7XG4vLyBBV1M6OkFwaUdhdGV3YXlWMiBDbG91ZEZvcm1hdGlvbiByZXNvdXJjZXM6XG5leHBvcnQgKiBmcm9tICcuL2FwaWdhdGV3YXl2Mi5nZW5lcmF0ZWQnO1xuIl19

8

lib/lambda-api.d.ts
import lambda = require('@aws-cdk/aws-lambda');
import cdk = require('@aws-cdk/core');
import { RestApi, RestApiProps } from './restapi';
export interface LambdaRestApiProps {
export interface LambdaRestApiProps extends RestApiProps {
/**

@@ -22,5 +22,7 @@ * The default Lambda function that handles all requests from this API.

/**
* Further customization of the REST API.
* @deprecated the `LambdaRestApiProps` now extends `RestApiProps`, so all
* options are just available here. Note that the options specified in
* `options` will be overridden by any props specified at the root level.
*
* @default defaults
* @default - no options.
*/

@@ -27,0 +29,0 @@ readonly options?: RestApiProps;

@@ -14,8 +14,9 @@ "use strict";

constructor(scope, id, props) {
if (props.options && props.options.defaultIntegration) {
throw new Error(`Cannot specify "options.defaultIntegration" since Lambda integration is automatically defined`);
if ((props.options && props.options.defaultIntegration) || props.defaultIntegration) {
throw new Error(`Cannot specify "defaultIntegration" since Lambda integration is automatically defined`);
}
super(scope, id, {
defaultIntegration: new integrations_1.LambdaIntegration(props.handler),
...props.options
...props.options,
...props,
});

@@ -41,2 +42,2 @@ if (props.proxy !== false) {

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFtYmRhLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImxhbWJkYS1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFFQSxpREFBbUQ7QUFHbkQsdUNBQWtEO0FBNkJsRDs7Ozs7O0dBTUc7QUFDSCxNQUFhLGFBQWMsU0FBUSxpQkFBTztJQUN4QyxZQUFZLEtBQW9CLEVBQUUsRUFBVSxFQUFFLEtBQXlCO1FBQ3JFLElBQUksS0FBSyxDQUFDLE9BQU8sSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLGtCQUFrQixFQUFFO1lBQ3JELE1BQU0sSUFBSSxLQUFLLENBQUMsK0ZBQStGLENBQUMsQ0FBQztTQUNsSDtRQUVELEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxFQUFFO1lBQ2Ysa0JBQWtCLEVBQUUsSUFBSSxnQ0FBaUIsQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDO1lBQ3hELEdBQUcsS0FBSyxDQUFDLE9BQU87U0FDakIsQ0FBQyxDQUFDO1FBRUgsSUFBSSxLQUFLLENBQUMsS0FBSyxLQUFLLEtBQUssRUFBRTtZQUN6QixJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO1lBRXJCLGlFQUFpRTtZQUNqRSxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsR0FBRyxpQkFBaUIsQ0FBQztZQUMxQyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsR0FBRyxlQUFlLENBQUM7WUFDdEMsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLEdBQUcsY0FBYyxDQUFDO1NBQ3JDO0lBQ0gsQ0FBQztDQUNGO0FBcEJELHNDQW9CQztBQUVELFNBQVMsaUJBQWlCO0lBQ3hCLE1BQU0sSUFBSSxLQUFLLENBQUMsNkVBQTZFLENBQUMsQ0FBQztBQUNqRyxDQUFDO0FBRUQsU0FBUyxlQUFlO0lBQ3RCLE1BQU0sSUFBSSxLQUFLLENBQUMsMkVBQTJFLENBQUMsQ0FBQztBQUMvRixDQUFDO0FBRUQsU0FBUyxjQUFjO0lBQ3JCLE1BQU0sSUFBSSxLQUFLLENBQUMsMEVBQTBFLENBQUMsQ0FBQztBQUM5RixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGxhbWJkYSA9IHJlcXVpcmUoJ0Bhd3MtY2RrL2F3cy1sYW1iZGEnKTtcbmltcG9ydCBjZGsgPSByZXF1aXJlKCdAYXdzLWNkay9jb3JlJyk7XG5pbXBvcnQgeyBMYW1iZGFJbnRlZ3JhdGlvbiB9IGZyb20gJy4vaW50ZWdyYXRpb25zJztcbmltcG9ydCB7IE1ldGhvZCB9IGZyb20gJy4vbWV0aG9kJztcbmltcG9ydCB7IFByb3h5UmVzb3VyY2UsIFJlc291cmNlIH0gZnJvbSAnLi9yZXNvdXJjZSc7XG5pbXBvcnQgeyBSZXN0QXBpLCBSZXN0QXBpUHJvcHMgfSBmcm9tICcuL3Jlc3RhcGknO1xuXG5leHBvcnQgaW50ZXJmYWNlIExhbWJkYVJlc3RBcGlQcm9wcyB7XG4gIC8qKlxuICAgKiBUaGUgZGVmYXVsdCBMYW1iZGEgZnVuY3Rpb24gdGhhdCBoYW5kbGVzIGFsbCByZXF1ZXN0cyBmcm9tIHRoaXMgQVBJLlxuICAgKlxuICAgKiBUaGlzIGhhbmRsZXIgd2lsbCBiZSB1c2VkIGFzIGEgdGhlIGRlZmF1bHQgaW50ZWdyYXRpb24gZm9yIGFsbCBtZXRob2RzIGluXG4gICAqIHRoaXMgQVBJLCB1bmxlc3Mgc3BlY2lmaWVkIG90aGVyd2lzZSBpbiBgYWRkTWV0aG9kYC5cbiAgICovXG4gIHJlYWRvbmx5IGhhbmRsZXI6IGxhbWJkYS5JRnVuY3Rpb247XG5cbiAgLyoqXG4gICAqIElmIHRydWUsIHJvdXRlIGFsbCByZXF1ZXN0cyB0byB0aGUgTGFtYmRhIEZ1bmN0aW9uXG4gICAqXG4gICAqIElmIHNldCB0byBmYWxzZSwgeW91IHdpbGwgbmVlZCB0byBleHBsaWNpdGx5IGRlZmluZSB0aGUgQVBJIG1vZGVsIHVzaW5nXG4gICAqIGBhZGRSZXNvdXJjZWAgYW5kIGBhZGRNZXRob2RgIChvciBgYWRkUHJveHlgKS5cbiAgICpcbiAgICogQGRlZmF1bHQgdHJ1ZVxuICAgKi9cbiAgcmVhZG9ubHkgcHJveHk/OiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBGdXJ0aGVyIGN1c3RvbWl6YXRpb24gb2YgdGhlIFJFU1QgQVBJLlxuICAgKlxuICAgKiBAZGVmYXVsdCBkZWZhdWx0c1xuICAgKi9cbiAgcmVhZG9ubHkgb3B0aW9ucz86IFJlc3RBcGlQcm9wcztcbn1cblxuLyoqXG4gKiBEZWZpbmVzIGFuIEFQSSBHYXRld2F5IFJFU1QgQVBJIHdpdGggQVdTIExhbWJkYSBwcm94eSBpbnRlZ3JhdGlvbi5cbiAqXG4gKiBVc2UgdGhlIGBwcm94eVBhdGhgIHByb3BlcnR5IHRvIGRlZmluZSBhIGdyZWVkeSBwcm94eSAoXCJ7cHJveHkrfVwiKSBhbmQgXCJBTllcIlxuICogbWV0aG9kIGZyb20gdGhlIHNwZWNpZmllZCBwYXRoLiBJZiBub3QgZGVmaW5lZCwgeW91IHdpbGwgbmVlZCB0byBleHBsaWNpdHlcbiAqIGFkZCByZXNvdXJjZXMgYW5kIG1ldGhvZHMgdG8gdGhlIEFQSS5cbiAqL1xuZXhwb3J0IGNsYXNzIExhbWJkYVJlc3RBcGkgZXh0ZW5kcyBSZXN0QXBpIHtcbiAgY29uc3RydWN0b3Ioc2NvcGU6IGNkay5Db25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBMYW1iZGFSZXN0QXBpUHJvcHMpIHtcbiAgICBpZiAocHJvcHMub3B0aW9ucyAmJiBwcm9wcy5vcHRpb25zLmRlZmF1bHRJbnRlZ3JhdGlvbikge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBDYW5ub3Qgc3BlY2lmeSBcIm9wdGlvbnMuZGVmYXVsdEludGVncmF0aW9uXCIgc2luY2UgTGFtYmRhIGludGVncmF0aW9uIGlzIGF1dG9tYXRpY2FsbHkgZGVmaW5lZGApO1xuICAgIH1cblxuICAgIHN1cGVyKHNjb3BlLCBpZCwge1xuICAgICAgZGVmYXVsdEludGVncmF0aW9uOiBuZXcgTGFtYmRhSW50ZWdyYXRpb24ocHJvcHMuaGFuZGxlciksXG4gICAgICAuLi5wcm9wcy5vcHRpb25zXG4gICAgfSk7XG5cbiAgICBpZiAocHJvcHMucHJveHkgIT09IGZhbHNlKSB7XG4gICAgICB0aGlzLnJvb3QuYWRkUHJveHkoKTtcblxuICAgICAgLy8gTWFrZSBzdXJlIHVzZXJzIGNhbm5vdCBjYWxsIGFueSBvdGhlciByZXNvdXJjZSBhZGRpbmcgZnVuY3Rpb25cbiAgICAgIHRoaXMucm9vdC5hZGRSZXNvdXJjZSA9IGFkZFJlc291cmNlVGhyb3dzO1xuICAgICAgdGhpcy5yb290LmFkZE1ldGhvZCA9IGFkZE1ldGhvZFRocm93cztcbiAgICAgIHRoaXMucm9vdC5hZGRQcm94eSA9IGFkZFByb3h5VGhyb3dzO1xuICAgIH1cbiAgfVxufVxuXG5mdW5jdGlvbiBhZGRSZXNvdXJjZVRocm93cygpOiBSZXNvdXJjZSB7XG4gIHRocm93IG5ldyBFcnJvcihgQ2Fubm90IGNhbGwgJ2FkZFJlc291cmNlJyBvbiBhIHByb3h5aW5nIExhbWJkYVJlc3RBcGk7IHNldCAncHJveHknIHRvIGZhbHNlYCk7XG59XG5cbmZ1bmN0aW9uIGFkZE1ldGhvZFRocm93cygpOiBNZXRob2Qge1xuICB0aHJvdyBuZXcgRXJyb3IoYENhbm5vdCBjYWxsICdhZGRNZXRob2QnIG9uIGEgcHJveHlpbmcgTGFtYmRhUmVzdEFwaTsgc2V0ICdwcm94eScgdG8gZmFsc2VgKTtcbn1cblxuZnVuY3Rpb24gYWRkUHJveHlUaHJvd3MoKTogUHJveHlSZXNvdXJjZSB7XG4gIHRocm93IG5ldyBFcnJvcihgQ2Fubm90IGNhbGwgJ2FkZFByb3h5JyBvbiBhIHByb3h5aW5nIExhbWJkYVJlc3RBcGk7IHNldCAncHJveHknIHRvIGZhbHNlYCk7XG59Il19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFtYmRhLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImxhbWJkYS1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFFQSxpREFBbUQ7QUFHbkQsdUNBQWtEO0FBK0JsRDs7Ozs7O0dBTUc7QUFDSCxNQUFhLGFBQWMsU0FBUSxpQkFBTztJQUN4QyxZQUFZLEtBQW9CLEVBQUUsRUFBVSxFQUFFLEtBQXlCO1FBQ3JFLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsa0JBQWtCLENBQUMsSUFBSSxLQUFLLENBQUMsa0JBQWtCLEVBQUU7WUFDbkYsTUFBTSxJQUFJLEtBQUssQ0FBQyx1RkFBdUYsQ0FBQyxDQUFDO1NBQzFHO1FBRUQsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUU7WUFDZixrQkFBa0IsRUFBRSxJQUFJLGdDQUFpQixDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUM7WUFDeEQsR0FBRyxLQUFLLENBQUMsT0FBTztZQUNoQixHQUFHLEtBQUs7U0FDVCxDQUFDLENBQUM7UUFFSCxJQUFJLEtBQUssQ0FBQyxLQUFLLEtBQUssS0FBSyxFQUFFO1lBQ3pCLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7WUFFckIsaUVBQWlFO1lBQ2pFLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxHQUFHLGlCQUFpQixDQUFDO1lBQzFDLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxHQUFHLGVBQWUsQ0FBQztZQUN0QyxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsR0FBRyxjQUFjLENBQUM7U0FDckM7SUFDSCxDQUFDO0NBQ0Y7QUFyQkQsc0NBcUJDO0FBRUQsU0FBUyxpQkFBaUI7SUFDeEIsTUFBTSxJQUFJLEtBQUssQ0FBQyw2RUFBNkUsQ0FBQyxDQUFDO0FBQ2pHLENBQUM7QUFFRCxTQUFTLGVBQWU7SUFDdEIsTUFBTSxJQUFJLEtBQUssQ0FBQywyRUFBMkUsQ0FBQyxDQUFDO0FBQy9GLENBQUM7QUFFRCxTQUFTLGNBQWM7SUFDckIsTUFBTSxJQUFJLEtBQUssQ0FBQywwRUFBMEUsQ0FBQyxDQUFDO0FBQzlGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgbGFtYmRhID0gcmVxdWlyZSgnQGF3cy1jZGsvYXdzLWxhbWJkYScpO1xuaW1wb3J0IGNkayA9IHJlcXVpcmUoJ0Bhd3MtY2RrL2NvcmUnKTtcbmltcG9ydCB7IExhbWJkYUludGVncmF0aW9uIH0gZnJvbSAnLi9pbnRlZ3JhdGlvbnMnO1xuaW1wb3J0IHsgTWV0aG9kIH0gZnJvbSAnLi9tZXRob2QnO1xuaW1wb3J0IHsgUHJveHlSZXNvdXJjZSwgUmVzb3VyY2UgfSBmcm9tICcuL3Jlc291cmNlJztcbmltcG9ydCB7IFJlc3RBcGksIFJlc3RBcGlQcm9wcyB9IGZyb20gJy4vcmVzdGFwaSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgTGFtYmRhUmVzdEFwaVByb3BzIGV4dGVuZHMgUmVzdEFwaVByb3BzIHtcbiAgLyoqXG4gICAqIFRoZSBkZWZhdWx0IExhbWJkYSBmdW5jdGlvbiB0aGF0IGhhbmRsZXMgYWxsIHJlcXVlc3RzIGZyb20gdGhpcyBBUEkuXG4gICAqXG4gICAqIFRoaXMgaGFuZGxlciB3aWxsIGJlIHVzZWQgYXMgYSB0aGUgZGVmYXVsdCBpbnRlZ3JhdGlvbiBmb3IgYWxsIG1ldGhvZHMgaW5cbiAgICogdGhpcyBBUEksIHVubGVzcyBzcGVjaWZpZWQgb3RoZXJ3aXNlIGluIGBhZGRNZXRob2RgLlxuICAgKi9cbiAgcmVhZG9ubHkgaGFuZGxlcjogbGFtYmRhLklGdW5jdGlvbjtcblxuICAvKipcbiAgICogSWYgdHJ1ZSwgcm91dGUgYWxsIHJlcXVlc3RzIHRvIHRoZSBMYW1iZGEgRnVuY3Rpb25cbiAgICpcbiAgICogSWYgc2V0IHRvIGZhbHNlLCB5b3Ugd2lsbCBuZWVkIHRvIGV4cGxpY2l0bHkgZGVmaW5lIHRoZSBBUEkgbW9kZWwgdXNpbmdcbiAgICogYGFkZFJlc291cmNlYCBhbmQgYGFkZE1ldGhvZGAgKG9yIGBhZGRQcm94eWApLlxuICAgKlxuICAgKiBAZGVmYXVsdCB0cnVlXG4gICAqL1xuICByZWFkb25seSBwcm94eT86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIEBkZXByZWNhdGVkIHRoZSBgTGFtYmRhUmVzdEFwaVByb3BzYCBub3cgZXh0ZW5kcyBgUmVzdEFwaVByb3BzYCwgc28gYWxsXG4gICAqIG9wdGlvbnMgYXJlIGp1c3QgYXZhaWxhYmxlIGhlcmUuIE5vdGUgdGhhdCB0aGUgb3B0aW9ucyBzcGVjaWZpZWQgaW5cbiAgICogYG9wdGlvbnNgIHdpbGwgYmUgb3ZlcnJpZGRlbiBieSBhbnkgcHJvcHMgc3BlY2lmaWVkIGF0IHRoZSByb290IGxldmVsLlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIG5vIG9wdGlvbnMuXG4gICAqL1xuICByZWFkb25seSBvcHRpb25zPzogUmVzdEFwaVByb3BzO1xufVxuXG4vKipcbiAqIERlZmluZXMgYW4gQVBJIEdhdGV3YXkgUkVTVCBBUEkgd2l0aCBBV1MgTGFtYmRhIHByb3h5IGludGVncmF0aW9uLlxuICpcbiAqIFVzZSB0aGUgYHByb3h5UGF0aGAgcHJvcGVydHkgdG8gZGVmaW5lIGEgZ3JlZWR5IHByb3h5IChcIntwcm94eSt9XCIpIGFuZCBcIkFOWVwiXG4gKiBtZXRob2QgZnJvbSB0aGUgc3BlY2lmaWVkIHBhdGguIElmIG5vdCBkZWZpbmVkLCB5b3Ugd2lsbCBuZWVkIHRvIGV4cGxpY2l0eVxuICogYWRkIHJlc291cmNlcyBhbmQgbWV0aG9kcyB0byB0aGUgQVBJLlxuICovXG5leHBvcnQgY2xhc3MgTGFtYmRhUmVzdEFwaSBleHRlbmRzIFJlc3RBcGkge1xuICBjb25zdHJ1Y3RvcihzY29wZTogY2RrLkNvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM6IExhbWJkYVJlc3RBcGlQcm9wcykge1xuICAgIGlmICgocHJvcHMub3B0aW9ucyAmJiBwcm9wcy5vcHRpb25zLmRlZmF1bHRJbnRlZ3JhdGlvbikgfHwgcHJvcHMuZGVmYXVsdEludGVncmF0aW9uKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYENhbm5vdCBzcGVjaWZ5IFwiZGVmYXVsdEludGVncmF0aW9uXCIgc2luY2UgTGFtYmRhIGludGVncmF0aW9uIGlzIGF1dG9tYXRpY2FsbHkgZGVmaW5lZGApO1xuICAgIH1cblxuICAgIHN1cGVyKHNjb3BlLCBpZCwge1xuICAgICAgZGVmYXVsdEludGVncmF0aW9uOiBuZXcgTGFtYmRhSW50ZWdyYXRpb24ocHJvcHMuaGFuZGxlciksXG4gICAgICAuLi5wcm9wcy5vcHRpb25zLCAvLyBkZXByZWNhdGVkLCBidXQgd2Ugc3RpbGwgc3VwcG9ydFxuICAgICAgLi4ucHJvcHMsXG4gICAgfSk7XG5cbiAgICBpZiAocHJvcHMucHJveHkgIT09IGZhbHNlKSB7XG4gICAgICB0aGlzLnJvb3QuYWRkUHJveHkoKTtcblxuICAgICAgLy8gTWFrZSBzdXJlIHVzZXJzIGNhbm5vdCBjYWxsIGFueSBvdGhlciByZXNvdXJjZSBhZGRpbmcgZnVuY3Rpb25cbiAgICAgIHRoaXMucm9vdC5hZGRSZXNvdXJjZSA9IGFkZFJlc291cmNlVGhyb3dzO1xuICAgICAgdGhpcy5yb290LmFkZE1ldGhvZCA9IGFkZE1ldGhvZFRocm93cztcbiAgICAgIHRoaXMucm9vdC5hZGRQcm94eSA9IGFkZFByb3h5VGhyb3dzO1xuICAgIH1cbiAgfVxufVxuXG5mdW5jdGlvbiBhZGRSZXNvdXJjZVRocm93cygpOiBSZXNvdXJjZSB7XG4gIHRocm93IG5ldyBFcnJvcihgQ2Fubm90IGNhbGwgJ2FkZFJlc291cmNlJyBvbiBhIHByb3h5aW5nIExhbWJkYVJlc3RBcGk7IHNldCAncHJveHknIHRvIGZhbHNlYCk7XG59XG5cbmZ1bmN0aW9uIGFkZE1ldGhvZFRocm93cygpOiBNZXRob2Qge1xuICB0aHJvdyBuZXcgRXJyb3IoYENhbm5vdCBjYWxsICdhZGRNZXRob2QnIG9uIGEgcHJveHlpbmcgTGFtYmRhUmVzdEFwaTsgc2V0ICdwcm94eScgdG8gZmFsc2VgKTtcbn1cblxuZnVuY3Rpb24gYWRkUHJveHlUaHJvd3MoKTogUHJveHlSZXNvdXJjZSB7XG4gIHRocm93IG5ldyBFcnJvcihgQ2Fubm90IGNhbGwgJ2FkZFByb3h5JyBvbiBhIHByb3h5aW5nIExhbWJkYVJlc3RBcGk7IHNldCAncHJveHknIHRvIGZhbHNlYCk7XG59Il19

@@ -5,2 +5,4 @@ import { Construct, Resource } from '@aws-cdk/core';

import { MethodResponse } from './methodresponse';
import { IModel } from './model';
import { IRequestValidator } from './requestvalidator';
import { IResource } from './resource';

@@ -50,2 +52,14 @@ import { RestApi } from './restapi';

};
/**
* The resources that are used for the response's content type. Specify request
* models as key-value pairs (string-to-string mapping), with a content type
* as the key and a Model resource name as the value
*/
readonly requestModels?: {
[param: string]: IModel;
};
/**
* The ID of the associated request validator.
*/
readonly requestValidator?: IRequestValidator;
}

@@ -100,2 +114,3 @@ export interface MethodProps {

private renderMethodResponses;
private renderRequestModels;
}

@@ -102,0 +117,0 @@ export declare enum AuthorizationType {

@@ -29,2 +29,4 @@ "use strict";

methodResponses: this.renderMethodResponses(options.methodResponses),
requestModels: this.renderRequestModels(options.requestModels),
requestValidatorId: options.requestValidator ? options.requestValidator.requestValidatorId : undefined
};

@@ -133,2 +135,15 @@ const resource = new apigateway_generated_1.CfnMethod(this, 'Resource', methodProps);

}
renderRequestModels(requestModels) {
if (!requestModels) {
// Fall back to nothing
return undefined;
}
const models = {};
for (const contentType in requestModels) {
if (requestModels.hasOwnProperty(contentType)) {
models[contentType] = requestModels[contentType].modelId;
}
}
return models;
}
}

@@ -155,2 +170,2 @@ exports.Method = Method;

})(AuthorizationType = exports.AuthorizationType || (exports.AuthorizationType = {}));
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"method.js","sourceRoot":"","sources":["method.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct, Resource, Stack } from '@aws-cdk/core';\nimport { CfnMethod, CfnMethodProps } from './apigateway.generated';\nimport { IAuthorizer } from './authorizer';\nimport { ConnectionType, Integration } from './integration';\nimport { MockIntegration } from './integrations/mock';\nimport { MethodResponse } from './methodresponse';\nimport { IResource } from './resource';\nimport { RestApi } from './restapi';\nimport { validateHttpMethod } from './util';\n\nexport interface MethodOptions {\n  /**\n   * A friendly operation name for the method. For example, you can assign the\n   * OperationName of ListPets for the GET /pets method.\n   */\n  readonly operationName?: string;\n\n  /**\n   * Method authorization.\n   * @default None open access\n   */\n  readonly authorizationType?: AuthorizationType;\n\n  /**\n   * If `authorizationType` is `Custom`, this specifies the ID of the method\n   * authorizer resource.\n   */\n  readonly authorizer?: IAuthorizer;\n\n  /**\n   * Indicates whether the method requires clients to submit a valid API key.\n   * @default false\n   */\n  readonly apiKeyRequired?: boolean;\n\n  /**\n   * The responses that can be sent to the client who calls the method.\n   * @default None\n   *\n   * This property is not required, but if these are not supplied for a Lambda\n   * proxy integration, the Lambda function must return a value of the correct format,\n   * for the integration response to be correctly mapped to a response to the client.\n   * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-method-settings-method-response.html\n   */\n  readonly methodResponses?: MethodResponse[]\n\n  /**\n   * The request parameters that API Gateway accepts. Specify request parameters\n   * as key-value pairs (string-to-Boolean mapping), with a source as the key and\n   * a Boolean as the value. The Boolean specifies whether a parameter is required.\n   * A source must match the format method.request.location.name, where the location\n   * is querystring, path, or header, and name is a valid, unique parameter name.\n   * @default None\n   */\n  readonly requestParameters?: { [param: string]: boolean };\n\n  // TODO:\n  // - RequestValidatorId\n  // - RequestModels\n}\n\nexport interface MethodProps {\n  /**\n   * The resource this method is associated with. For root resource methods,\n   * specify the `RestApi` object.\n   */\n  readonly resource: IResource;\n\n  /**\n   * The HTTP method (\"GET\", \"POST\", \"PUT\", ...) that clients use to call this method.\n   */\n  readonly httpMethod: string;\n\n  /**\n   * The backend system that the method calls when it receives a request.\n   *\n   * @default - a new `MockIntegration`.\n   */\n  readonly integration?: Integration;\n\n  /**\n   * Method options.\n   *\n   * @default - No options.\n   */\n  readonly options?: MethodOptions;\n}\n\nexport class Method extends Resource {\n  /** @attribute */\n  public readonly methodId: string;\n\n  public readonly httpMethod: string;\n  public readonly resource: IResource;\n  public readonly restApi: RestApi;\n\n  constructor(scope: Construct, id: string, props: MethodProps) {\n    super(scope, id);\n\n    this.resource = props.resource;\n    this.restApi = props.resource.restApi;\n    this.httpMethod = props.httpMethod.toUpperCase();\n\n    validateHttpMethod(this.httpMethod);\n\n    const options = props.options || {};\n\n    const defaultMethodOptions = props.resource.defaultMethodOptions || {};\n    const authorizer = options.authorizer || defaultMethodOptions.authorizer;\n\n    const methodProps: CfnMethodProps = {\n      resourceId: props.resource.resourceId,\n      restApiId: this.restApi.restApiId,\n      httpMethod: this.httpMethod,\n      operationName: options.operationName || defaultMethodOptions.operationName,\n      apiKeyRequired: options.apiKeyRequired || defaultMethodOptions.apiKeyRequired,\n      authorizationType: options.authorizationType || defaultMethodOptions.authorizationType || AuthorizationType.NONE,\n      authorizerId: authorizer && authorizer.authorizerId,\n      requestParameters: options.requestParameters,\n      integration: this.renderIntegration(props.integration),\n      methodResponses: this.renderMethodResponses(options.methodResponses),\n    };\n\n    const resource = new CfnMethod(this, 'Resource', methodProps);\n\n    this.methodId = resource.ref;\n\n    props.resource.restApi._attachMethod(this);\n\n    const deployment = props.resource.restApi.latestDeployment;\n    if (deployment) {\n      deployment.node.addDependency(resource);\n      deployment.addToLogicalId({ method: methodProps });\n    }\n  }\n\n  /**\n   * Returns an execute-api ARN for this method:\n   *\n   *   arn:aws:execute-api:{region}:{account}:{restApiId}/{stage}/{method}/{path}\n   *\n   * NOTE: {stage} will refer to the `restApi.deploymentStage`, which will\n   * automatically set if auto-deploy is enabled.\n   *\n   * @attribute\n   */\n  public get methodArn(): string {\n    if (!this.restApi.deploymentStage) {\n      throw new Error(\n        `Unable to determine ARN for method \"${this.node.id}\" since there is no stage associated with this API.\\n` +\n        'Either use the `deploy` prop or explicitly assign `deploymentStage` on the RestApi');\n    }\n\n    const stage = this.restApi.deploymentStage.stageName.toString();\n    return this.restApi.arnForExecuteApi(this.httpMethod, this.resource.path, stage);\n  }\n\n  /**\n   * Returns an execute-api ARN for this method's \"test-invoke-stage\" stage.\n   * This stage is used by the AWS Console UI when testing the method.\n   */\n  public get testMethodArn(): string {\n    return this.restApi.arnForExecuteApi(this.httpMethod, this.resource.path, 'test-invoke-stage');\n  }\n\n  private renderIntegration(integration?: Integration): CfnMethod.IntegrationProperty {\n    if (!integration) {\n      // use defaultIntegration from API if defined\n      if (this.resource.defaultIntegration) {\n        return this.renderIntegration(this.resource.defaultIntegration);\n      }\n\n      // fallback to mock\n      return this.renderIntegration(new MockIntegration());\n    }\n\n    integration.bind(this);\n\n    const options = integration.props.options || { };\n\n    let credentials;\n    if (options.credentialsPassthrough !== undefined && options.credentialsRole !== undefined) {\n      throw new Error(`'credentialsPassthrough' and 'credentialsRole' are mutually exclusive`);\n    }\n\n    if (options.connectionType === ConnectionType.VPC_LINK && options.vpcLink === undefined) {\n      throw new Error(`'connectionType' of VPC_LINK requires 'vpcLink' prop to be set`);\n    }\n\n    if (options.connectionType === ConnectionType.INTERNET && options.vpcLink !== undefined) {\n      throw new Error(`cannot set 'vpcLink' where 'connectionType' is INTERNET`);\n    }\n\n    if (options.credentialsRole) {\n      credentials = options.credentialsRole.roleArn;\n    } else if (options.credentialsPassthrough) {\n      // arn:aws:iam::*:user/*\n      // tslint:disable-next-line:max-line-length\n      credentials = Stack.of(this).formatArn({ service: 'iam', region: '', account: '*', resource: 'user', sep: '/', resourceName: '*' });\n    }\n\n    return {\n      type: integration.props.type,\n      uri: integration.props.uri,\n      cacheKeyParameters: options.cacheKeyParameters,\n      cacheNamespace: options.cacheNamespace,\n      contentHandling: options.contentHandling,\n      integrationHttpMethod: integration.props.integrationHttpMethod,\n      requestParameters: options.requestParameters,\n      requestTemplates: options.requestTemplates,\n      passthroughBehavior: options.passthroughBehavior,\n      integrationResponses: options.integrationResponses,\n      connectionType: options.connectionType,\n      connectionId: options.vpcLink ? options.vpcLink.vpcLinkId : undefined,\n      credentials,\n    };\n  }\n\n  private renderMethodResponses(methodResponses: MethodResponse[] | undefined): CfnMethod.MethodResponseProperty[] | undefined {\n    if (!methodResponses) {\n      // Fall back to nothing\n      return undefined;\n    }\n\n    return methodResponses.map(mr => {\n      let responseModels: {[contentType: string]: string} | undefined;\n\n      if (mr.responseModels) {\n        responseModels = {};\n        for (const contentType in mr.responseModels) {\n          if (mr.responseModels.hasOwnProperty(contentType)) {\n            responseModels[contentType] = mr.responseModels[contentType].modelId;\n          }\n        }\n      }\n\n      const methodResponseProp = {\n        statusCode: mr.statusCode,\n        responseParameters: mr.responseParameters,\n        responseModels,\n      };\n\n      return methodResponseProp;\n    });\n  }\n}\n\nexport enum AuthorizationType {\n  /**\n   * Open access.\n   */\n  NONE = 'NONE',\n\n  /**\n   * Use AWS IAM permissions.\n   */\n  IAM = 'AWS_IAM',\n\n  /**\n   * Use a custom authorizer.\n   */\n  CUSTOM = 'CUSTOM',\n\n  /**\n   * Use an AWS Cognito user pool.\n   */\n  COGNITO = 'COGNITO_USER_POOLS',\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"method.js","sourceRoot":"","sources":["method.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct, Resource, Stack } from '@aws-cdk/core';\nimport { CfnMethod, CfnMethodProps } from './apigateway.generated';\nimport { IAuthorizer } from './authorizer';\nimport { ConnectionType, Integration } from './integration';\nimport { MockIntegration } from './integrations/mock';\nimport { MethodResponse } from './methodresponse';\nimport { IModel } from './model';\nimport { IRequestValidator } from './requestvalidator';\nimport { IResource } from './resource';\nimport { RestApi } from './restapi';\nimport { validateHttpMethod } from './util';\n\nexport interface MethodOptions {\n  /**\n   * A friendly operation name for the method. For example, you can assign the\n   * OperationName of ListPets for the GET /pets method.\n   */\n  readonly operationName?: string;\n\n  /**\n   * Method authorization.\n   * @default None open access\n   */\n  readonly authorizationType?: AuthorizationType;\n\n  /**\n   * If `authorizationType` is `Custom`, this specifies the ID of the method\n   * authorizer resource.\n   */\n  readonly authorizer?: IAuthorizer;\n\n  /**\n   * Indicates whether the method requires clients to submit a valid API key.\n   * @default false\n   */\n  readonly apiKeyRequired?: boolean;\n\n  /**\n   * The responses that can be sent to the client who calls the method.\n   * @default None\n   *\n   * This property is not required, but if these are not supplied for a Lambda\n   * proxy integration, the Lambda function must return a value of the correct format,\n   * for the integration response to be correctly mapped to a response to the client.\n   * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-method-settings-method-response.html\n   */\n  readonly methodResponses?: MethodResponse[]\n\n  /**\n   * The request parameters that API Gateway accepts. Specify request parameters\n   * as key-value pairs (string-to-Boolean mapping), with a source as the key and\n   * a Boolean as the value. The Boolean specifies whether a parameter is required.\n   * A source must match the format method.request.location.name, where the location\n   * is querystring, path, or header, and name is a valid, unique parameter name.\n   * @default None\n   */\n  readonly requestParameters?: { [param: string]: boolean };\n\n  /**\n   * The resources that are used for the response's content type. Specify request\n   * models as key-value pairs (string-to-string mapping), with a content type\n   * as the key and a Model resource name as the value\n   */\n  readonly requestModels?: { [param: string]: IModel };\n\n  /**\n   * The ID of the associated request validator.\n   */\n  readonly requestValidator?: IRequestValidator;\n}\n\nexport interface MethodProps {\n  /**\n   * The resource this method is associated with. For root resource methods,\n   * specify the `RestApi` object.\n   */\n  readonly resource: IResource;\n\n  /**\n   * The HTTP method (\"GET\", \"POST\", \"PUT\", ...) that clients use to call this method.\n   */\n  readonly httpMethod: string;\n\n  /**\n   * The backend system that the method calls when it receives a request.\n   *\n   * @default - a new `MockIntegration`.\n   */\n  readonly integration?: Integration;\n\n  /**\n   * Method options.\n   *\n   * @default - No options.\n   */\n  readonly options?: MethodOptions;\n}\n\nexport class Method extends Resource {\n  /** @attribute */\n  public readonly methodId: string;\n\n  public readonly httpMethod: string;\n  public readonly resource: IResource;\n  public readonly restApi: RestApi;\n\n  constructor(scope: Construct, id: string, props: MethodProps) {\n    super(scope, id);\n\n    this.resource = props.resource;\n    this.restApi = props.resource.restApi;\n    this.httpMethod = props.httpMethod.toUpperCase();\n\n    validateHttpMethod(this.httpMethod);\n\n    const options = props.options || {};\n\n    const defaultMethodOptions = props.resource.defaultMethodOptions || {};\n    const authorizer = options.authorizer || defaultMethodOptions.authorizer;\n\n    const methodProps: CfnMethodProps = {\n      resourceId: props.resource.resourceId,\n      restApiId: this.restApi.restApiId,\n      httpMethod: this.httpMethod,\n      operationName: options.operationName || defaultMethodOptions.operationName,\n      apiKeyRequired: options.apiKeyRequired || defaultMethodOptions.apiKeyRequired,\n      authorizationType: options.authorizationType || defaultMethodOptions.authorizationType || AuthorizationType.NONE,\n      authorizerId: authorizer && authorizer.authorizerId,\n      requestParameters: options.requestParameters,\n      integration: this.renderIntegration(props.integration),\n      methodResponses: this.renderMethodResponses(options.methodResponses),\n      requestModels: this.renderRequestModels(options.requestModels),\n      requestValidatorId: options.requestValidator ? options.requestValidator.requestValidatorId : undefined\n    };\n\n    const resource = new CfnMethod(this, 'Resource', methodProps);\n\n    this.methodId = resource.ref;\n\n    props.resource.restApi._attachMethod(this);\n\n    const deployment = props.resource.restApi.latestDeployment;\n    if (deployment) {\n      deployment.node.addDependency(resource);\n      deployment.addToLogicalId({ method: methodProps });\n    }\n  }\n\n  /**\n   * Returns an execute-api ARN for this method:\n   *\n   *   arn:aws:execute-api:{region}:{account}:{restApiId}/{stage}/{method}/{path}\n   *\n   * NOTE: {stage} will refer to the `restApi.deploymentStage`, which will\n   * automatically set if auto-deploy is enabled.\n   *\n   * @attribute\n   */\n  public get methodArn(): string {\n    if (!this.restApi.deploymentStage) {\n      throw new Error(\n        `Unable to determine ARN for method \"${this.node.id}\" since there is no stage associated with this API.\\n` +\n        'Either use the `deploy` prop or explicitly assign `deploymentStage` on the RestApi');\n    }\n\n    const stage = this.restApi.deploymentStage.stageName.toString();\n    return this.restApi.arnForExecuteApi(this.httpMethod, this.resource.path, stage);\n  }\n\n  /**\n   * Returns an execute-api ARN for this method's \"test-invoke-stage\" stage.\n   * This stage is used by the AWS Console UI when testing the method.\n   */\n  public get testMethodArn(): string {\n    return this.restApi.arnForExecuteApi(this.httpMethod, this.resource.path, 'test-invoke-stage');\n  }\n\n  private renderIntegration(integration?: Integration): CfnMethod.IntegrationProperty {\n    if (!integration) {\n      // use defaultIntegration from API if defined\n      if (this.resource.defaultIntegration) {\n        return this.renderIntegration(this.resource.defaultIntegration);\n      }\n\n      // fallback to mock\n      return this.renderIntegration(new MockIntegration());\n    }\n\n    integration.bind(this);\n\n    const options = integration.props.options || { };\n\n    let credentials;\n    if (options.credentialsPassthrough !== undefined && options.credentialsRole !== undefined) {\n      throw new Error(`'credentialsPassthrough' and 'credentialsRole' are mutually exclusive`);\n    }\n\n    if (options.connectionType === ConnectionType.VPC_LINK && options.vpcLink === undefined) {\n      throw new Error(`'connectionType' of VPC_LINK requires 'vpcLink' prop to be set`);\n    }\n\n    if (options.connectionType === ConnectionType.INTERNET && options.vpcLink !== undefined) {\n      throw new Error(`cannot set 'vpcLink' where 'connectionType' is INTERNET`);\n    }\n\n    if (options.credentialsRole) {\n      credentials = options.credentialsRole.roleArn;\n    } else if (options.credentialsPassthrough) {\n      // arn:aws:iam::*:user/*\n      // tslint:disable-next-line:max-line-length\n      credentials = Stack.of(this).formatArn({ service: 'iam', region: '', account: '*', resource: 'user', sep: '/', resourceName: '*' });\n    }\n\n    return {\n      type: integration.props.type,\n      uri: integration.props.uri,\n      cacheKeyParameters: options.cacheKeyParameters,\n      cacheNamespace: options.cacheNamespace,\n      contentHandling: options.contentHandling,\n      integrationHttpMethod: integration.props.integrationHttpMethod,\n      requestParameters: options.requestParameters,\n      requestTemplates: options.requestTemplates,\n      passthroughBehavior: options.passthroughBehavior,\n      integrationResponses: options.integrationResponses,\n      connectionType: options.connectionType,\n      connectionId: options.vpcLink ? options.vpcLink.vpcLinkId : undefined,\n      credentials,\n    };\n  }\n\n  private renderMethodResponses(methodResponses: MethodResponse[] | undefined): CfnMethod.MethodResponseProperty[] | undefined {\n    if (!methodResponses) {\n      // Fall back to nothing\n      return undefined;\n    }\n\n    return methodResponses.map(mr => {\n      let responseModels: {[contentType: string]: string} | undefined;\n\n      if (mr.responseModels) {\n        responseModels = {};\n        for (const contentType in mr.responseModels) {\n          if (mr.responseModels.hasOwnProperty(contentType)) {\n            responseModels[contentType] = mr.responseModels[contentType].modelId;\n          }\n        }\n      }\n\n      const methodResponseProp = {\n        statusCode: mr.statusCode,\n        responseParameters: mr.responseParameters,\n        responseModels,\n      };\n\n      return methodResponseProp;\n    });\n  }\n\n  private renderRequestModels(requestModels: { [param: string]: IModel } | undefined): { [param: string]: string } | undefined {\n    if (!requestModels) {\n      // Fall back to nothing\n      return undefined;\n    }\n\n    const models: {[param: string]: string} = {};\n    for (const contentType in requestModels) {\n      if (requestModels.hasOwnProperty(contentType)) {\n          models[contentType] = requestModels[contentType].modelId;\n      }\n    }\n\n    return models;\n  }\n}\n\nexport enum AuthorizationType {\n  /**\n   * Open access.\n   */\n  NONE = 'NONE',\n\n  /**\n   * Use AWS IAM permissions.\n   */\n  IAM = 'AWS_IAM',\n\n  /**\n   * Use a custom authorizer.\n   */\n  CUSTOM = 'CUSTOM',\n\n  /**\n   * Use an AWS Cognito user pool.\n   */\n  COGNITO = 'COGNITO_USER_POOLS',\n}\n"]}

@@ -0,2 +1,10 @@

import { Construct, Resource } from '@aws-cdk/core';
import jsonSchema = require('./json-schema');
import { IRestApi } from './restapi';
export interface IModel {
/**
* Returns the model name, such as 'myModel'
*
* @attribute
*/
readonly modelId: string;

@@ -20,2 +28,3 @@ }

* @see https://docs.amazonaws.cn/en_us/apigateway/latest/developerguide/models-mappings.html#models-mappings-models
* @deprecated You should use @see Model.EMPTY_MODEL
*/

@@ -40,2 +49,3 @@ export declare class EmptyModel implements IModel {

* }
* @deprecated You should use @see Model.ERROR_MODEL
*/

@@ -45,1 +55,91 @@ export declare class ErrorModel implements IModel {

}
export interface ModelOptions {
/**
* The content type for the model. You can also force a
* content type in the request or response model mapping.
*
* @default -
*/
readonly contentType?: string;
/**
* A description that identifies this model.
* @default None
*/
readonly description?: string;
/**
* A name for the model.
*
* Important
* If you specify a name, you cannot perform updates that
* require replacement of this resource. You can perform
* updates that require no or some interruption. If you
* must replace the resource, specify a new name.
*
* @default <auto> If you don't specify a name,
* AWS CloudFormation generates a unique physical ID and
* uses that ID for the model name. For more information,
* see Name Type.
*/
readonly modelName?: string;
/**
* The schema to use to transform data to one or more output formats.
* Specify null ({}) if you don't want to specify a schema.
*/
readonly schema: jsonSchema.JsonSchema;
}
export interface ModelProps extends ModelOptions {
/**
* The rest API that this model is part of.
*
* The reason we need the RestApi object itself and not just the ID is because the model
* is being tracked by the top-level RestApi object for the purpose of calculating it's
* hash to determine the ID of the deployment. This allows us to automatically update
* the deployment when the model of the REST API changes.
*/
readonly restApi: IRestApi;
}
export declare class Model extends Resource implements IModel {
/**
* Represents a reference to a REST API's Error model, which is available
* as part of the model collection by default. This can be used for mapping
* error JSON responses from an integration to a client, where a simple
* generic message field is sufficient to map and return an error payload.
*
* Definition
* {
* "$schema" : "http://json-schema.org/draft-04/schema#",
* "title" : "Error Schema",
* "type" : "object",
* "properties" : {
* "message" : { "type" : "string" }
* }
* }
*/
static readonly ERROR_MODEL: IModel;
/**
* Represents a reference to a REST API's Empty model, which is available
* as part of the model collection by default. This can be used for mapping
* JSON responses from an integration to what is returned to a client,
* where strong typing is not required. In the absence of any defined
* model, the Empty model will be used to return the response payload
* unmapped.
*
* Definition
* {
* "$schema" : "http://json-schema.org/draft-04/schema#",
* "title" : "Empty Schema",
* "type" : "object"
* }
*
* @see https://docs.amazonaws.cn/en_us/apigateway/latest/developerguide/models-mappings.html#models-mappings-models
*/
static readonly EMPTY_MODEL: IModel;
static fromModelName(scope: Construct, id: string, modelName: string): IModel;
/**
* Returns the model name, such as 'myModel'
*
* @attribute
*/
readonly modelId: string;
constructor(scope: Construct, id: string, props: ModelProps);
}
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const core_1 = require("@aws-cdk/core");
const apigateway_generated_1 = require("./apigateway.generated");
const restapi_1 = require("./restapi");
const util = require("./util");
/**

@@ -19,2 +23,3 @@ * Represents a reference to a REST API's Empty model, which is available

* @see https://docs.amazonaws.cn/en_us/apigateway/latest/developerguide/models-mappings.html#models-mappings-models
* @deprecated You should use @see Model.EMPTY_MODEL
*/

@@ -42,2 +47,3 @@ class EmptyModel {

* }
* @deprecated You should use @see Model.ERROR_MODEL
*/

@@ -50,3 +56,68 @@ class ErrorModel {

exports.ErrorModel = ErrorModel;
// TODO: Implement Model, enabling management of custom models.
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJtb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUlBOzs7Ozs7Ozs7Ozs7Ozs7O0dBZ0JHO0FBQ0gsTUFBYSxVQUFVO0lBQXZCO1FBQ29CLFlBQU8sR0FBRyxPQUFPLENBQUM7SUFDdEMsQ0FBQztDQUFBO0FBRkQsZ0NBRUM7QUFFRDs7Ozs7Ozs7Ozs7Ozs7O0dBZUc7QUFDSCxNQUFhLFVBQVU7SUFBdkI7UUFDb0IsWUFBTyxHQUFHLE9BQU8sQ0FBQztJQUN0QyxDQUFDO0NBQUE7QUFGRCxnQ0FFQztBQUVELCtEQUErRCIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgSU1vZGVsIHtcbiAgICByZWFkb25seSBtb2RlbElkOiBzdHJpbmc7XG59XG5cbi8qKlxuICogUmVwcmVzZW50cyBhIHJlZmVyZW5jZSB0byBhIFJFU1QgQVBJJ3MgRW1wdHkgbW9kZWwsIHdoaWNoIGlzIGF2YWlsYWJsZVxuICogYXMgcGFydCBvZiB0aGUgbW9kZWwgY29sbGVjdGlvbiBieSBkZWZhdWx0LiBUaGlzIGNhbiBiZSB1c2VkIGZvciBtYXBwaW5nXG4gKiBKU09OIHJlc3BvbnNlcyBmcm9tIGFuIGludGVncmF0aW9uIHRvIHdoYXQgaXMgcmV0dXJuZWQgdG8gYSBjbGllbnQsXG4gKiB3aGVyZSBzdHJvbmcgdHlwaW5nIGlzIG5vdCByZXF1aXJlZC4gSW4gdGhlIGFic2VuY2Ugb2YgYW55IGRlZmluZWRcbiAqIG1vZGVsLCB0aGUgRW1wdHkgbW9kZWwgd2lsbCBiZSB1c2VkIHRvIHJldHVybiB0aGUgcmVzcG9uc2UgcGF5bG9hZFxuICogdW5tYXBwZWQuXG4gKlxuICogRGVmaW5pdGlvblxuICoge1xuICogICBcIiRzY2hlbWFcIiA6IFwiaHR0cDovL2pzb24tc2NoZW1hLm9yZy9kcmFmdC0wNC9zY2hlbWEjXCIsXG4gKiAgIFwidGl0bGVcIiA6IFwiRW1wdHkgU2NoZW1hXCIsXG4gKiAgIFwidHlwZVwiIDogXCJvYmplY3RcIlxuICogfVxuICpcbiAqIEBzZWUgaHR0cHM6Ly9kb2NzLmFtYXpvbmF3cy5jbi9lbl91cy9hcGlnYXRld2F5L2xhdGVzdC9kZXZlbG9wZXJndWlkZS9tb2RlbHMtbWFwcGluZ3MuaHRtbCNtb2RlbHMtbWFwcGluZ3MtbW9kZWxzXG4gKi9cbmV4cG9ydCBjbGFzcyBFbXB0eU1vZGVsIGltcGxlbWVudHMgSU1vZGVsIHtcbiAgICBwdWJsaWMgcmVhZG9ubHkgbW9kZWxJZCA9ICdFbXB0eSc7XG59XG5cbi8qKlxuICogUmVwcmVzZW50cyBhIHJlZmVyZW5jZSB0byBhIFJFU1QgQVBJJ3MgRXJyb3IgbW9kZWwsIHdoaWNoIGlzIGF2YWlsYWJsZVxuICogYXMgcGFydCBvZiB0aGUgbW9kZWwgY29sbGVjdGlvbiBieSBkZWZhdWx0LiBUaGlzIGNhbiBiZSB1c2VkIGZvciBtYXBwaW5nXG4gKiBlcnJvciBKU09OIHJlc3BvbnNlcyBmcm9tIGFuIGludGVncmF0aW9uIHRvIGEgY2xpZW50LCB3aGVyZSBhIHNpbXBsZVxuICogZ2VuZXJpYyBtZXNzYWdlIGZpZWxkIGlzIHN1ZmZpY2llbnQgdG8gbWFwIGFuZCByZXR1cm4gYW4gZXJyb3IgcGF5bG9hZC5cbiAqXG4gKiBEZWZpbml0aW9uXG4gKiB7XG4gKiAgIFwiJHNjaGVtYVwiIDogXCJodHRwOi8vanNvbi1zY2hlbWEub3JnL2RyYWZ0LTA0L3NjaGVtYSNcIixcbiAqICAgXCJ0aXRsZVwiIDogXCJFcnJvciBTY2hlbWFcIixcbiAqICAgXCJ0eXBlXCIgOiBcIm9iamVjdFwiLFxuICogICBcInByb3BlcnRpZXNcIiA6IHtcbiAqICAgICBcIm1lc3NhZ2VcIiA6IHsgXCJ0eXBlXCIgOiBcInN0cmluZ1wiIH1cbiAqICAgfVxuICogfVxuICovXG5leHBvcnQgY2xhc3MgRXJyb3JNb2RlbCBpbXBsZW1lbnRzIElNb2RlbCB7XG4gICAgcHVibGljIHJlYWRvbmx5IG1vZGVsSWQgPSAnRXJyb3InO1xufVxuXG4vLyBUT0RPOiBJbXBsZW1lbnQgTW9kZWwsIGVuYWJsaW5nIG1hbmFnZW1lbnQgb2YgY3VzdG9tIG1vZGVscy4iXX0=
class Model extends core_1.Resource {
constructor(scope, id, props) {
super(scope, id, {
physicalName: props.modelName,
});
const modelProps = {
name: this.physicalName,
restApiId: props.restApi.restApiId,
contentType: props.contentType,
description: props.description,
schema: util.JsonSchemaMapper.toCfnJsonSchema(props.schema)
};
const resource = new apigateway_generated_1.CfnModel(this, 'Resource', modelProps);
this.modelId = this.getResourceNameAttribute(resource.ref);
const deployment = (props.restApi instanceof restapi_1.RestApi) ? props.restApi.latestDeployment : undefined;
if (deployment) {
deployment.node.addDependency(resource);
deployment.addToLogicalId({ model: modelProps });
}
}
static fromModelName(scope, id, modelName) {
class Import extends core_1.Resource {
constructor() {
super(...arguments);
this.modelId = modelName;
}
}
return new Import(scope, id);
}
}
/**
* Represents a reference to a REST API's Error model, which is available
* as part of the model collection by default. This can be used for mapping
* error JSON responses from an integration to a client, where a simple
* generic message field is sufficient to map and return an error payload.
*
* Definition
* {
* "$schema" : "http://json-schema.org/draft-04/schema#",
* "title" : "Error Schema",
* "type" : "object",
* "properties" : {
* "message" : { "type" : "string" }
* }
* }
*/
Model.ERROR_MODEL = new ErrorModel();
/**
* Represents a reference to a REST API's Empty model, which is available
* as part of the model collection by default. This can be used for mapping
* JSON responses from an integration to what is returned to a client,
* where strong typing is not required. In the absence of any defined
* model, the Empty model will be used to return the response payload
* unmapped.
*
* Definition
* {
* "$schema" : "http://json-schema.org/draft-04/schema#",
* "title" : "Empty Schema",
* "type" : "object"
* }
*
* @see https://docs.amazonaws.cn/en_us/apigateway/latest/developerguide/models-mappings.html#models-mappings-models
*/
Model.EMPTY_MODEL = new EmptyModel();
exports.Model = Model;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"model.js","sourceRoot":"","sources":["model.ts"],"names":[],"mappings":";;AAAA,wCAAoD;AACpD,iEAAiE;AAEjE,uCAA8C;AAC9C,+BAAgC;AAWhC;;;;;;;;;;;;;;;;;GAiBG;AACH,MAAa,UAAU;IAAvB;QACkB,YAAO,GAAG,OAAO,CAAC;IACpC,CAAC;CAAA;AAFD,gCAEC;AAED;;;;;;;;;;;;;;;;GAgBG;AACH,MAAa,UAAU;IAAvB;QACkB,YAAO,GAAG,OAAO,CAAC;IACpC,CAAC;CAAA;AAFD,gCAEC;AAoDD,MAAa,KAAM,SAAQ,eAAQ;IAqDjC,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAiB;QACzD,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,YAAY,EAAE,KAAK,CAAC,SAAS;SAC9B,CAAC,CAAC;QAEH,MAAM,UAAU,GAAkB;YAChC,IAAI,EAAE,IAAI,CAAC,YAAY;YACvB,SAAS,EAAE,KAAK,CAAC,OAAO,CAAC,SAAS;YAClC,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,MAAM,EAAE,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,KAAK,CAAC,MAAM,CAAC;SAC5D,CAAC;QAEF,MAAM,QAAQ,GAAG,IAAI,+BAAQ,CAAC,IAAI,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC;QAE5D,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,wBAAwB,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;QAE3D,MAAM,UAAU,GAAG,CAAC,KAAK,CAAC,OAAO,YAAY,iBAAO,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC,CAAC,SAAS,CAAC;QACnG,IAAI,UAAU,EAAE;YACd,UAAU,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;YACxC,UAAU,CAAC,cAAc,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,CAAC,CAAC;SAClD;IACH,CAAC;IArCM,MAAM,CAAC,aAAa,CAAC,KAAgB,EAAE,EAAU,EAAE,SAAiB;QACzE,MAAM,MAAO,SAAQ,eAAQ;YAA7B;;gBACkB,YAAO,GAAG,SAAS,CAAC;YACtC,CAAC;SAAA;QAED,OAAO,IAAI,MAAM,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;IAC/B,CAAC;;AA3CD;;;;;;;;;;;;;;;GAeG;AACoB,iBAAW,GAAW,IAAI,UAAU,EAAE,CAAC;AAE9D;;;;;;;;;;;;;;;;GAgBG;AACoB,iBAAW,GAAW,IAAI,UAAU,EAAE,CAAC;AApChE,sBA4EC","sourcesContent":["import { Construct, Resource } from '@aws-cdk/core';\nimport { CfnModel, CfnModelProps } from './apigateway.generated';\nimport jsonSchema = require('./json-schema');\nimport { IRestApi, RestApi } from './restapi';\nimport util = require('./util');\n\nexport interface IModel {\n  /**\n   * Returns the model name, such as 'myModel'\n   *\n   * @attribute\n   */\n  readonly modelId: string;\n}\n\n/**\n * Represents a reference to a REST API's Empty model, which is available\n * as part of the model collection by default. This can be used for mapping\n * JSON responses from an integration to what is returned to a client,\n * where strong typing is not required. In the absence of any defined\n * model, the Empty model will be used to return the response payload\n * unmapped.\n *\n * Definition\n * {\n *   \"$schema\" : \"http://json-schema.org/draft-04/schema#\",\n *   \"title\" : \"Empty Schema\",\n *   \"type\" : \"object\"\n * }\n *\n * @see https://docs.amazonaws.cn/en_us/apigateway/latest/developerguide/models-mappings.html#models-mappings-models\n * @deprecated You should use @see Model.EMPTY_MODEL\n */\nexport class EmptyModel implements IModel {\n  public readonly modelId = 'Empty';\n}\n\n/**\n * Represents a reference to a REST API's Error model, which is available\n * as part of the model collection by default. This can be used for mapping\n * error JSON responses from an integration to a client, where a simple\n * generic message field is sufficient to map and return an error payload.\n *\n * Definition\n * {\n *   \"$schema\" : \"http://json-schema.org/draft-04/schema#\",\n *   \"title\" : \"Error Schema\",\n *   \"type\" : \"object\",\n *   \"properties\" : {\n *     \"message\" : { \"type\" : \"string\" }\n *   }\n * }\n * @deprecated You should use @see Model.ERROR_MODEL\n */\nexport class ErrorModel implements IModel {\n  public readonly modelId = 'Error';\n}\n\nexport interface ModelOptions {\n  /**\n   * The content type for the model. You can also force a\n   * content type in the request or response model mapping.\n   *\n   * @default -\n   */\n  readonly contentType?: string;\n\n  /**\n   * A description that identifies this model.\n   * @default None\n   */\n  readonly description?: string;\n\n  /**\n   * A name for the model.\n   *\n   * Important\n   *  If you specify a name, you cannot perform updates that\n   *  require replacement of this resource. You can perform\n   *  updates that require no or some interruption. If you\n   *  must replace the resource, specify a new name.\n   *\n   * @default <auto> If you don't specify a name,\n   *  AWS CloudFormation generates a unique physical ID and\n   *  uses that ID for the model name. For more information,\n   *  see Name Type.\n   */\n  readonly modelName?: string;\n\n  /**\n   * The schema to use to transform data to one or more output formats.\n   * Specify null ({}) if you don't want to specify a schema.\n   */\n  readonly schema: jsonSchema.JsonSchema;\n}\n\nexport interface ModelProps extends ModelOptions {\n  /**\n   * The rest API that this model is part of.\n   *\n   * The reason we need the RestApi object itself and not just the ID is because the model\n   * is being tracked by the top-level RestApi object for the purpose of calculating it's\n   * hash to determine the ID of the deployment. This allows us to automatically update\n   * the deployment when the model of the REST API changes.\n   */\n  readonly restApi: IRestApi;\n}\n\nexport class Model extends Resource implements IModel {\n  /**\n   * Represents a reference to a REST API's Error model, which is available\n   * as part of the model collection by default. This can be used for mapping\n   * error JSON responses from an integration to a client, where a simple\n   * generic message field is sufficient to map and return an error payload.\n   *\n   * Definition\n   * {\n   *   \"$schema\" : \"http://json-schema.org/draft-04/schema#\",\n   *   \"title\" : \"Error Schema\",\n   *   \"type\" : \"object\",\n   *   \"properties\" : {\n   *     \"message\" : { \"type\" : \"string\" }\n   *   }\n   * }\n   */\n  public static readonly ERROR_MODEL: IModel = new ErrorModel();\n\n  /**\n   * Represents a reference to a REST API's Empty model, which is available\n   * as part of the model collection by default. This can be used for mapping\n   * JSON responses from an integration to what is returned to a client,\n   * where strong typing is not required. In the absence of any defined\n   * model, the Empty model will be used to return the response payload\n   * unmapped.\n   *\n   * Definition\n   * {\n   *   \"$schema\" : \"http://json-schema.org/draft-04/schema#\",\n   *   \"title\" : \"Empty Schema\",\n   *   \"type\" : \"object\"\n   * }\n   *\n   * @see https://docs.amazonaws.cn/en_us/apigateway/latest/developerguide/models-mappings.html#models-mappings-models\n   */\n  public static readonly EMPTY_MODEL: IModel = new EmptyModel();\n\n  public static fromModelName(scope: Construct, id: string, modelName: string): IModel {\n    class Import extends Resource implements IModel {\n      public readonly modelId = modelName;\n    }\n\n    return new Import(scope, id);\n  }\n\n  /**\n   * Returns the model name, such as 'myModel'\n   *\n   * @attribute\n   */\n  public readonly modelId: string;\n\n  constructor(scope: Construct, id: string, props: ModelProps) {\n    super(scope, id, {\n      physicalName: props.modelName,\n    });\n\n    const modelProps: CfnModelProps = {\n      name: this.physicalName,\n      restApiId: props.restApi.restApiId,\n      contentType: props.contentType,\n      description: props.description,\n      schema: util.JsonSchemaMapper.toCfnJsonSchema(props.schema)\n    };\n\n    const resource = new CfnModel(this, 'Resource', modelProps);\n\n    this.modelId = this.getResourceNameAttribute(resource.ref);\n\n    const deployment = (props.restApi instanceof RestApi) ? props.restApi.latestDeployment : undefined;\n    if (deployment) {\n      deployment.node.addDependency(resource);\n      deployment.addToLogicalId({ model: modelProps });\n    }\n  }\n}"]}

@@ -5,2 +5,5 @@ import iam = require('@aws-cdk/aws-iam');

import { Deployment } from './deployment';
import { DomainName, DomainNameOptions } from './domain-name';
import { Model, ModelOptions } from './model';
import { RequestValidator, RequestValidatorOptions } from './requestvalidator';
import { IResource, ResourceOptions } from './resource';

@@ -133,2 +136,8 @@ import { Stage, StageOptions } from './stage';

readonly cloudWatchRole?: boolean;
/**
* Configure a custom domain name and map it to this API.
*
* @default - no domain name is defined, use `addDomainName` or directly define a `DomainName`.
*/
readonly domainName?: DomainNameOptions;
}

@@ -170,2 +179,7 @@ /**

deploymentStage: Stage;
/**
* The domain name mapped to this API, if defined through the `domainName`
* configuration prop.
*/
readonly domainName?: DomainName;
private readonly methods;

@@ -191,2 +205,8 @@ private _latestDeployment;

/**
* Defines an API Gateway domain name and maps it to this API.
* @param id The construct id
* @param options custom domain options
*/
addDomainName(id: string, options: DomainNameOptions): DomainName;
/**
* Adds a usage plan.

@@ -200,2 +220,10 @@ */

/**
* Adds a new model.
*/
addModel(id: string, props: ModelOptions): Model;
/**
* Adds a new model.
*/
addRequestValidator(id: string, props: RequestValidatorOptions): RequestValidator;
/**
* @returns The "execute-api" ARN.

@@ -202,0 +230,0 @@ * @default "*" returns the execute API ARN for all methods/resources in

@@ -8,2 +8,5 @@ "use strict";

const deployment_1 = require("./deployment");
const domain_name_1 = require("./domain-name");
const model_1 = require("./model");
const requestvalidator_1 = require("./requestvalidator");
const resource_1 = require("./resource");

@@ -36,3 +39,3 @@ const stage_1 = require("./stage");

cloneFrom: props.cloneFrom ? props.cloneFrom.restApiId : undefined,
parameters: props.parameters,
parameters: props.parameters
});

@@ -46,2 +49,5 @@ this.restApiId = resource.ref;

this.root = new RootResource(this, props, resource.attrRootResourceId);
if (props.domainName) {
this.domainName = this.addDomainName('CustomDomain', props.domainName);
}
}

@@ -83,2 +89,13 @@ static fromRestApiId(scope, id, restApiId) {

/**
* Defines an API Gateway domain name and maps it to this API.
* @param id The construct id
* @param options custom domain options
*/
addDomainName(id, options) {
return new domain_name_1.DomainName(this, id, {
...options,
mapping: this
});
}
/**
* Adds a usage plan.

@@ -98,2 +115,20 @@ */

/**
* Adds a new model.
*/
addModel(id, props) {
return new model_1.Model(this, id, {
...props,
restApi: this
});
}
/**
* Adds a new model.
*/
addRequestValidator(id, props) {
return new requestvalidator_1.RequestValidator(this, id, {
...props,
restApi: this
});
}
/**
* @returns The "execute-api" ARN.

@@ -210,2 +245,2 @@ * @default "*" returns the execute API ARN for all methods/resources in

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restapi.js","sourceRoot":"","sources":["restapi.ts"],"names":[],"mappings":"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","sourcesContent":["import iam = require('@aws-cdk/aws-iam');\nimport { CfnOutput, Construct, IResource as IResourceBase, Resource, Stack } from '@aws-cdk/core';\nimport { ApiKey, IApiKey } from './api-key';\nimport { CfnAccount, CfnRestApi } from './apigateway.generated';\nimport { Deployment } from './deployment';\nimport { Integration } from './integration';\nimport { Method, MethodOptions } from './method';\nimport { IResource, ResourceBase, ResourceOptions } from './resource';\nimport { Stage, StageOptions } from './stage';\nimport { UsagePlan, UsagePlanProps } from './usage-plan';\n\nexport interface IRestApi extends IResourceBase {\n  /**\n   * The ID of this API Gateway RestApi.\n   * @attribute\n   */\n  readonly restApiId: string;\n}\n\nexport interface RestApiProps extends ResourceOptions {\n  /**\n   * Indicates if a Deployment should be automatically created for this API,\n   * and recreated when the API model (resources, methods) changes.\n   *\n   * Since API Gateway deployments are immutable, When this option is enabled\n   * (by default), an AWS::ApiGateway::Deployment resource will automatically\n   * created with a logical ID that hashes the API model (methods, resources\n   * and options). This means that when the model changes, the logical ID of\n   * this CloudFormation resource will change, and a new deployment will be\n   * created.\n   *\n   * If this is set, `latestDeployment` will refer to the `Deployment` object\n   * and `deploymentStage` will refer to a `Stage` that points to this\n   * deployment. To customize the stage options, use the `deployStageOptions`\n   * property.\n   *\n   * A CloudFormation Output will also be defined with the root URL endpoint\n   * of this REST API.\n   *\n   * @default true\n   */\n  readonly deploy?: boolean;\n\n  /**\n   * Options for the API Gateway stage that will always point to the latest\n   * deployment when `deploy` is enabled. If `deploy` is disabled,\n   * this value cannot be set.\n   *\n   * @default - Based on defaults of `StageOptions`.\n   */\n  readonly deployOptions?: StageOptions;\n\n  /**\n   * Retains old deployment resources when the API changes. This allows\n   * manually reverting stages to point to old deployments via the AWS\n   * Console.\n   *\n   * @default false\n   */\n  readonly retainDeployments?: boolean;\n\n  /**\n   * A name for the API Gateway RestApi resource.\n   *\n   * @default - ID of the RestApi construct.\n   */\n  readonly restApiName?: string;\n\n  /**\n   * Custom header parameters for the request.\n   * @see https://docs.aws.amazon.com/cli/latest/reference/apigateway/import-rest-api.html\n   *\n   * @default - No parameters.\n   */\n  readonly parameters?: { [key: string]: string };\n\n  /**\n   * A policy document that contains the permissions for this RestApi\n   *\n   * @default - No policy.\n   */\n  readonly policy?: iam.PolicyDocument;\n\n  /**\n   * A description of the purpose of this API Gateway RestApi resource.\n   *\n   * @default - No description.\n   */\n  readonly description?: string;\n\n  /**\n   * The source of the API key for metering requests according to a usage\n   * plan.\n   *\n   * @default - Metering is disabled.\n   */\n  readonly apiKeySourceType?: ApiKeySourceType;\n\n  /**\n   * The list of binary media mine-types that are supported by the RestApi\n   * resource, such as \"image/png\" or \"application/octet-stream\"\n   *\n   * @default - RestApi supports only UTF-8-encoded text payloads.\n   */\n  readonly binaryMediaTypes?: string[];\n\n  /**\n   * A list of the endpoint types of the API. Use this property when creating\n   * an API.\n   *\n   * @default - No endpoint types.\n   */\n  readonly endpointTypes?: EndpointType[];\n\n  /**\n   * Indicates whether to roll back the resource if a warning occurs while API\n   * Gateway is creating the RestApi resource.\n   *\n   * @default false\n   */\n  readonly failOnWarnings?: boolean;\n\n  /**\n   * A nullable integer that is used to enable compression (with non-negative\n   * between 0 and 10485760 (10M) bytes, inclusive) or disable compression\n   * (when undefined) on an API. When compression is enabled, compression or\n   * decompression is not applied on the payload if the payload size is\n   * smaller than this value. Setting it to zero allows compression for any\n   * payload size.\n   *\n   * @default - Compression is disabled.\n   */\n  readonly minimumCompressionSize?: number;\n\n  /**\n   * The ID of the API Gateway RestApi resource that you want to clone.\n   *\n   * @default - None.\n   */\n  readonly cloneFrom?: IRestApi;\n\n  /**\n   * Automatically configure an AWS CloudWatch role for API Gateway.\n   *\n   * @default true\n   */\n  readonly cloudWatchRole?: boolean;\n}\n\n/**\n * Represents a REST API in Amazon API Gateway.\n *\n * Use `addResource` and `addMethod` to configure the API model.\n *\n * By default, the API will automatically be deployed and accessible from a\n * public endpoint.\n */\nexport class RestApi extends Resource implements IRestApi {\n\n  public static fromRestApiId(scope: Construct, id: string, restApiId: string): IRestApi {\n    class Import extends Resource implements IRestApi {\n      public readonly restApiId = restApiId;\n    }\n\n    return new Import(scope, id);\n  }\n\n  /**\n   * The ID of this API Gateway RestApi.\n   */\n  public readonly restApiId: string;\n\n  /**\n   * The resource ID of the root resource.\n   *\n   * @attribute\n   */\n  public readonly restApiRootResourceId: string;\n\n  /**\n   * Represents the root resource (\"/\") of this API. Use it to define the API model:\n   *\n   *    api.root.addMethod('ANY', redirectToHomePage); // \"ANY /\"\n   *    api.root.addResource('friends').addMethod('GET', getFriendsHandler); // \"GET /friends\"\n   *\n   */\n  public readonly root: IResource;\n\n  /**\n   * API Gateway stage that points to the latest deployment (if defined).\n   *\n   * If `deploy` is disabled, you will need to explicitly assign this value in order to\n   * set up integrations.\n   */\n  public deploymentStage: Stage;\n\n  private readonly methods = new Array<Method>();\n  private _latestDeployment: Deployment | undefined;\n\n  constructor(scope: Construct, id: string, props: RestApiProps = { }) {\n    super(scope, id, {\n      physicalName: props.restApiName || id,\n    });\n\n    const resource = new CfnRestApi(this, 'Resource', {\n      name: this.physicalName,\n      description: props.description,\n      policy: props.policy,\n      failOnWarnings: props.failOnWarnings,\n      minimumCompressionSize: props.minimumCompressionSize,\n      binaryMediaTypes: props.binaryMediaTypes,\n      endpointConfiguration: props.endpointTypes ? { types: props.endpointTypes } : undefined,\n      apiKeySourceType: props.apiKeySourceType,\n      cloneFrom: props.cloneFrom ? props.cloneFrom.restApiId : undefined,\n      parameters: props.parameters,\n    });\n\n    this.restApiId = resource.ref;\n\n    this.configureDeployment(props);\n\n    const cloudWatchRole = props.cloudWatchRole !== undefined ? props.cloudWatchRole : true;\n    if (cloudWatchRole) {\n      this.configureCloudWatchRole(resource);\n    }\n\n    this.root = new RootResource(this, props, resource.attrRootResourceId);\n  }\n\n  /**\n   * API Gateway deployment that represents the latest changes of the API.\n   * This resource will be automatically updated every time the REST API model changes.\n   * This will be undefined if `deploy` is false.\n   */\n  public get latestDeployment() {\n    return this._latestDeployment;\n  }\n\n  /**\n   * The deployed root URL of this REST API.\n   */\n  public get url() {\n    return this.urlForPath();\n  }\n\n  /**\n   * Returns the URL for an HTTP path.\n   *\n   * Fails if `deploymentStage` is not set either by `deploy` or explicitly.\n   */\n  public urlForPath(path: string = '/'): string {\n    if (!this.deploymentStage) {\n      throw new Error('Cannot determine deployment stage for API from \"deploymentStage\". Use \"deploy\" or explicitly set \"deploymentStage\"');\n    }\n\n    return this.deploymentStage.urlForPath(path);\n  }\n\n  /**\n   * Adds a usage plan.\n   */\n  public addUsagePlan(id: string, props: UsagePlanProps): UsagePlan {\n    return new UsagePlan(this, id, props);\n  }\n\n  /**\n   * Add an ApiKey\n   */\n  public addApiKey(id: string): IApiKey {\n    return new ApiKey(this, id, {\n      resources: [this]\n    });\n  }\n\n  /**\n   * @returns The \"execute-api\" ARN.\n   * @default \"*\" returns the execute API ARN for all methods/resources in\n   * this API.\n   * @param method The method (default `*`)\n   * @param path The resource path. Must start with '/' (default `*`)\n   * @param stage The stage (default `*`)\n   */\n  public arnForExecuteApi(method: string = '*', path: string = '/*', stage: string = '*') {\n    if (!path.startsWith('/')) {\n      throw new Error(`\"path\" must begin with a \"/\": '${path}'`);\n    }\n\n    if (method.toUpperCase() === 'ANY') {\n      method = '*';\n    }\n\n    return Stack.of(this).formatArn({\n      service: 'execute-api',\n      resource: this.restApiId,\n      sep: '/',\n      resourceName: `${stage}/${method}${path}`\n    });\n  }\n\n  /**\n   * Internal API used by `Method` to keep an inventory of methods at the API\n   * level for validation purposes.\n   *\n   * @internal\n   */\n  public _attachMethod(method: Method) {\n    this.methods.push(method);\n  }\n\n  /**\n   * Performs validation of the REST API.\n   */\n  protected validate() {\n    if (this.methods.length === 0) {\n      return [ `The REST API doesn't contain any methods` ];\n    }\n\n    return [];\n  }\n\n  private configureDeployment(props: RestApiProps) {\n    const deploy = props.deploy === undefined ? true : props.deploy;\n    if (deploy) {\n\n      this._latestDeployment = new Deployment(this, 'Deployment', {\n        description: 'Automatically created by the RestApi construct',\n        api: this,\n        retainDeployments: props.retainDeployments\n      });\n\n      // encode the stage name into the construct id, so if we change the stage name, it will recreate a new stage.\n      // stage name is part of the endpoint, so that makes sense.\n      const stageName = (props.deployOptions && props.deployOptions.stageName) || 'prod';\n\n      this.deploymentStage = new Stage(this, `DeploymentStage.${stageName}`, {\n        deployment: this._latestDeployment,\n        ...props.deployOptions\n      });\n\n      new CfnOutput(this, 'Endpoint', { value: this.urlForPath() });\n    } else {\n      if (props.deployOptions) {\n        throw new Error(`Cannot set 'deployOptions' if 'deploy' is disabled`);\n      }\n    }\n  }\n\n  private configureCloudWatchRole(apiResource: CfnRestApi) {\n    const role = new iam.Role(this, 'CloudWatchRole', {\n      assumedBy: new iam.ServicePrincipal('apigateway.amazonaws.com'),\n      managedPolicies: [iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AmazonAPIGatewayPushToCloudWatchLogs')],\n    });\n\n    const resource = new CfnAccount(this, 'Account', {\n      cloudWatchRoleArn: role.roleArn\n    });\n\n    resource.node.addDependency(apiResource);\n  }\n}\n\nexport enum ApiKeySourceType {\n  /**\n   * To read the API key from the `X-API-Key` header of a request.\n   */\n  HEADER = 'HEADER',\n\n  /**\n   * To read the API key from the `UsageIdentifierKey` from a custom authorizer.\n   */\n  AUTHORIZER = 'AUTHORIZER',\n}\n\nexport enum EndpointType {\n  /**\n   * For an edge-optimized API and its custom domain name.\n   */\n  EDGE = 'EDGE',\n\n  /**\n   * For a regional API and its custom domain name.\n   */\n  REGIONAL = 'REGIONAL',\n\n  /**\n   * For a private API and its custom domain name.\n   */\n  PRIVATE = 'PRIVATE'\n}\n\nclass RootResource extends ResourceBase {\n  public readonly parentResource?: IResource;\n  public readonly restApi: RestApi;\n  public readonly resourceId: string;\n  public readonly path: string;\n  public readonly defaultIntegration?: Integration | undefined;\n  public readonly defaultMethodOptions?: MethodOptions | undefined;\n\n  constructor(api: RestApi, props: RestApiProps, resourceId: string) {\n    super(api, 'Default');\n\n    this.parentResource = undefined;\n    this.defaultIntegration = props.defaultIntegration;\n    this.defaultMethodOptions = props.defaultMethodOptions;\n    this.restApi = api;\n    this.resourceId = resourceId;\n    this.path = '/';\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restapi.js","sourceRoot":"","sources":["restapi.ts"],"names":[],"mappings":"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","sourcesContent":["import iam = require('@aws-cdk/aws-iam');\nimport { CfnOutput, Construct, IResource as IResourceBase, Resource, Stack } from '@aws-cdk/core';\nimport { ApiKey, IApiKey } from './api-key';\nimport { CfnAccount, CfnRestApi } from './apigateway.generated';\nimport { Deployment } from './deployment';\nimport { DomainName, DomainNameOptions } from './domain-name';\nimport { Integration } from './integration';\nimport { Method, MethodOptions } from './method';\nimport { Model, ModelOptions } from './model';\nimport { RequestValidator, RequestValidatorOptions } from './requestvalidator';\nimport { IResource, ResourceBase, ResourceOptions } from './resource';\nimport { Stage, StageOptions } from './stage';\nimport { UsagePlan, UsagePlanProps } from './usage-plan';\n\nexport interface IRestApi extends IResourceBase {\n  /**\n   * The ID of this API Gateway RestApi.\n   * @attribute\n   */\n  readonly restApiId: string;\n}\n\nexport interface RestApiProps extends ResourceOptions {\n  /**\n   * Indicates if a Deployment should be automatically created for this API,\n   * and recreated when the API model (resources, methods) changes.\n   *\n   * Since API Gateway deployments are immutable, When this option is enabled\n   * (by default), an AWS::ApiGateway::Deployment resource will automatically\n   * created with a logical ID that hashes the API model (methods, resources\n   * and options). This means that when the model changes, the logical ID of\n   * this CloudFormation resource will change, and a new deployment will be\n   * created.\n   *\n   * If this is set, `latestDeployment` will refer to the `Deployment` object\n   * and `deploymentStage` will refer to a `Stage` that points to this\n   * deployment. To customize the stage options, use the `deployStageOptions`\n   * property.\n   *\n   * A CloudFormation Output will also be defined with the root URL endpoint\n   * of this REST API.\n   *\n   * @default true\n   */\n  readonly deploy?: boolean;\n\n  /**\n   * Options for the API Gateway stage that will always point to the latest\n   * deployment when `deploy` is enabled. If `deploy` is disabled,\n   * this value cannot be set.\n   *\n   * @default - Based on defaults of `StageOptions`.\n   */\n  readonly deployOptions?: StageOptions;\n\n  /**\n   * Retains old deployment resources when the API changes. This allows\n   * manually reverting stages to point to old deployments via the AWS\n   * Console.\n   *\n   * @default false\n   */\n  readonly retainDeployments?: boolean;\n\n  /**\n   * A name for the API Gateway RestApi resource.\n   *\n   * @default - ID of the RestApi construct.\n   */\n  readonly restApiName?: string;\n\n  /**\n   * Custom header parameters for the request.\n   * @see https://docs.aws.amazon.com/cli/latest/reference/apigateway/import-rest-api.html\n   *\n   * @default - No parameters.\n   */\n  readonly parameters?: { [key: string]: string };\n\n  /**\n   * A policy document that contains the permissions for this RestApi\n   *\n   * @default - No policy.\n   */\n  readonly policy?: iam.PolicyDocument;\n\n  /**\n   * A description of the purpose of this API Gateway RestApi resource.\n   *\n   * @default - No description.\n   */\n  readonly description?: string;\n\n  /**\n   * The source of the API key for metering requests according to a usage\n   * plan.\n   *\n   * @default - Metering is disabled.\n   */\n  readonly apiKeySourceType?: ApiKeySourceType;\n\n  /**\n   * The list of binary media mine-types that are supported by the RestApi\n   * resource, such as \"image/png\" or \"application/octet-stream\"\n   *\n   * @default - RestApi supports only UTF-8-encoded text payloads.\n   */\n  readonly binaryMediaTypes?: string[];\n\n  /**\n   * A list of the endpoint types of the API. Use this property when creating\n   * an API.\n   *\n   * @default - No endpoint types.\n   */\n  readonly endpointTypes?: EndpointType[];\n\n  /**\n   * Indicates whether to roll back the resource if a warning occurs while API\n   * Gateway is creating the RestApi resource.\n   *\n   * @default false\n   */\n  readonly failOnWarnings?: boolean;\n\n  /**\n   * A nullable integer that is used to enable compression (with non-negative\n   * between 0 and 10485760 (10M) bytes, inclusive) or disable compression\n   * (when undefined) on an API. When compression is enabled, compression or\n   * decompression is not applied on the payload if the payload size is\n   * smaller than this value. Setting it to zero allows compression for any\n   * payload size.\n   *\n   * @default - Compression is disabled.\n   */\n  readonly minimumCompressionSize?: number;\n\n  /**\n   * The ID of the API Gateway RestApi resource that you want to clone.\n   *\n   * @default - None.\n   */\n  readonly cloneFrom?: IRestApi;\n\n  /**\n   * Automatically configure an AWS CloudWatch role for API Gateway.\n   *\n   * @default true\n   */\n  readonly cloudWatchRole?: boolean;\n\n  /**\n   * Configure a custom domain name and map it to this API.\n   *\n   * @default - no domain name is defined, use `addDomainName` or directly define a `DomainName`.\n   */\n  readonly domainName?: DomainNameOptions;\n}\n\n/**\n * Represents a REST API in Amazon API Gateway.\n *\n * Use `addResource` and `addMethod` to configure the API model.\n *\n * By default, the API will automatically be deployed and accessible from a\n * public endpoint.\n */\nexport class RestApi extends Resource implements IRestApi {\n\n  public static fromRestApiId(scope: Construct, id: string, restApiId: string): IRestApi {\n    class Import extends Resource implements IRestApi {\n      public readonly restApiId = restApiId;\n    }\n\n    return new Import(scope, id);\n  }\n\n  /**\n   * The ID of this API Gateway RestApi.\n   */\n  public readonly restApiId: string;\n\n  /**\n   * The resource ID of the root resource.\n   *\n   * @attribute\n   */\n  public readonly restApiRootResourceId: string;\n\n  /**\n   * Represents the root resource (\"/\") of this API. Use it to define the API model:\n   *\n   *    api.root.addMethod('ANY', redirectToHomePage); // \"ANY /\"\n   *    api.root.addResource('friends').addMethod('GET', getFriendsHandler); // \"GET /friends\"\n   *\n   */\n  public readonly root: IResource;\n\n  /**\n   * API Gateway stage that points to the latest deployment (if defined).\n   *\n   * If `deploy` is disabled, you will need to explicitly assign this value in order to\n   * set up integrations.\n   */\n  public deploymentStage: Stage;\n\n  /**\n   * The domain name mapped to this API, if defined through the `domainName`\n   * configuration prop.\n   */\n  public readonly domainName?: DomainName;\n\n  private readonly methods = new Array<Method>();\n  private _latestDeployment: Deployment | undefined;\n\n  constructor(scope: Construct, id: string, props: RestApiProps = { }) {\n    super(scope, id, {\n      physicalName: props.restApiName || id,\n    });\n\n    const resource = new CfnRestApi(this, 'Resource', {\n      name: this.physicalName,\n      description: props.description,\n      policy: props.policy,\n      failOnWarnings: props.failOnWarnings,\n      minimumCompressionSize: props.minimumCompressionSize,\n      binaryMediaTypes: props.binaryMediaTypes,\n      endpointConfiguration: props.endpointTypes ? { types: props.endpointTypes } : undefined,\n      apiKeySourceType: props.apiKeySourceType,\n      cloneFrom: props.cloneFrom ? props.cloneFrom.restApiId : undefined,\n      parameters: props.parameters\n    });\n\n    this.restApiId = resource.ref;\n\n    this.configureDeployment(props);\n\n    const cloudWatchRole = props.cloudWatchRole !== undefined ? props.cloudWatchRole : true;\n    if (cloudWatchRole) {\n      this.configureCloudWatchRole(resource);\n    }\n\n    this.root = new RootResource(this, props, resource.attrRootResourceId);\n\n    if (props.domainName) {\n      this.domainName = this.addDomainName('CustomDomain', props.domainName);\n    }\n  }\n\n  /**\n   * API Gateway deployment that represents the latest changes of the API.\n   * This resource will be automatically updated every time the REST API model changes.\n   * This will be undefined if `deploy` is false.\n   */\n  public get latestDeployment() {\n    return this._latestDeployment;\n  }\n\n  /**\n   * The deployed root URL of this REST API.\n   */\n  public get url() {\n    return this.urlForPath();\n  }\n\n  /**\n   * Returns the URL for an HTTP path.\n   *\n   * Fails if `deploymentStage` is not set either by `deploy` or explicitly.\n   */\n  public urlForPath(path: string = '/'): string {\n    if (!this.deploymentStage) {\n      throw new Error('Cannot determine deployment stage for API from \"deploymentStage\". Use \"deploy\" or explicitly set \"deploymentStage\"');\n    }\n\n    return this.deploymentStage.urlForPath(path);\n  }\n\n  /**\n   * Defines an API Gateway domain name and maps it to this API.\n   * @param id The construct id\n   * @param options custom domain options\n   */\n  public addDomainName(id: string, options: DomainNameOptions): DomainName {\n    return new DomainName(this, id, {\n      ...options,\n      mapping: this\n    });\n  }\n\n  /**\n   * Adds a usage plan.\n   */\n  public addUsagePlan(id: string, props: UsagePlanProps): UsagePlan {\n    return new UsagePlan(this, id, props);\n  }\n\n  /**\n   * Add an ApiKey\n   */\n  public addApiKey(id: string): IApiKey {\n    return new ApiKey(this, id, {\n      resources: [this]\n    });\n  }\n\n  /**\n   * Adds a new model.\n   */\n  public addModel(id: string, props: ModelOptions): Model {\n    return new Model(this, id, {\n      ...props,\n      restApi: this\n    });\n  }\n\n  /**\n   * Adds a new model.\n   */\n  public addRequestValidator(id: string, props: RequestValidatorOptions): RequestValidator {\n    return new RequestValidator(this, id, {\n      ...props,\n      restApi: this\n    });\n  }\n\n  /**\n   * @returns The \"execute-api\" ARN.\n   * @default \"*\" returns the execute API ARN for all methods/resources in\n   * this API.\n   * @param method The method (default `*`)\n   * @param path The resource path. Must start with '/' (default `*`)\n   * @param stage The stage (default `*`)\n   */\n  public arnForExecuteApi(method: string = '*', path: string = '/*', stage: string = '*') {\n    if (!path.startsWith('/')) {\n      throw new Error(`\"path\" must begin with a \"/\": '${path}'`);\n    }\n\n    if (method.toUpperCase() === 'ANY') {\n      method = '*';\n    }\n\n    return Stack.of(this).formatArn({\n      service: 'execute-api',\n      resource: this.restApiId,\n      sep: '/',\n      resourceName: `${stage}/${method}${path}`\n    });\n  }\n\n  /**\n   * Internal API used by `Method` to keep an inventory of methods at the API\n   * level for validation purposes.\n   *\n   * @internal\n   */\n  public _attachMethod(method: Method) {\n    this.methods.push(method);\n  }\n\n  /**\n   * Performs validation of the REST API.\n   */\n  protected validate() {\n    if (this.methods.length === 0) {\n      return [ `The REST API doesn't contain any methods` ];\n    }\n\n    return [];\n  }\n\n  private configureDeployment(props: RestApiProps) {\n    const deploy = props.deploy === undefined ? true : props.deploy;\n    if (deploy) {\n\n      this._latestDeployment = new Deployment(this, 'Deployment', {\n        description: 'Automatically created by the RestApi construct',\n        api: this,\n        retainDeployments: props.retainDeployments\n      });\n\n      // encode the stage name into the construct id, so if we change the stage name, it will recreate a new stage.\n      // stage name is part of the endpoint, so that makes sense.\n      const stageName = (props.deployOptions && props.deployOptions.stageName) || 'prod';\n\n      this.deploymentStage = new Stage(this, `DeploymentStage.${stageName}`, {\n        deployment: this._latestDeployment,\n        ...props.deployOptions\n      });\n\n      new CfnOutput(this, 'Endpoint', { value: this.urlForPath() });\n    } else {\n      if (props.deployOptions) {\n        throw new Error(`Cannot set 'deployOptions' if 'deploy' is disabled`);\n      }\n    }\n  }\n\n  private configureCloudWatchRole(apiResource: CfnRestApi) {\n    const role = new iam.Role(this, 'CloudWatchRole', {\n      assumedBy: new iam.ServicePrincipal('apigateway.amazonaws.com'),\n      managedPolicies: [iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AmazonAPIGatewayPushToCloudWatchLogs')],\n    });\n\n    const resource = new CfnAccount(this, 'Account', {\n      cloudWatchRoleArn: role.roleArn\n    });\n\n    resource.node.addDependency(apiResource);\n  }\n}\n\nexport enum ApiKeySourceType {\n  /**\n   * To read the API key from the `X-API-Key` header of a request.\n   */\n  HEADER = 'HEADER',\n\n  /**\n   * To read the API key from the `UsageIdentifierKey` from a custom authorizer.\n   */\n  AUTHORIZER = 'AUTHORIZER',\n}\n\nexport enum EndpointType {\n  /**\n   * For an edge-optimized API and its custom domain name.\n   */\n  EDGE = 'EDGE',\n\n  /**\n   * For a regional API and its custom domain name.\n   */\n  REGIONAL = 'REGIONAL',\n\n  /**\n   * For a private API and its custom domain name.\n   */\n  PRIVATE = 'PRIVATE'\n}\n\nclass RootResource extends ResourceBase {\n  public readonly parentResource?: IResource;\n  public readonly restApi: RestApi;\n  public readonly resourceId: string;\n  public readonly path: string;\n  public readonly defaultIntegration?: Integration | undefined;\n  public readonly defaultMethodOptions?: MethodOptions | undefined;\n\n  constructor(api: RestApi, props: RestApiProps, resourceId: string) {\n    super(api, 'Default');\n\n    this.parentResource = undefined;\n    this.defaultIntegration = props.defaultIntegration;\n    this.defaultMethodOptions = props.defaultMethodOptions;\n    this.restApi = api;\n    this.resourceId = resourceId;\n    this.path = '/';\n  }\n}\n"]}

@@ -0,1 +1,2 @@

import jsonSchema = require('./json-schema');
export declare function validateHttpMethod(method: string, messagePrefix?: string): void;

@@ -13,1 +14,12 @@ export declare function parseMethodOptionsPath(originalPath: string): {

export declare function validateInteger(property: number | undefined, messagePrefix: string): void;
export declare class JsonSchemaMapper {
/**
* Transforms naming of some properties to prefix with a $, where needed
* according to the JSON schema spec
* @param schema The JsonSchema object to transform for CloudFormation output
*/
static toCfnJsonSchema(schema: jsonSchema.JsonSchema): any;
private static readonly SchemaPropsWithPrefix;
private static readonly SubSchemaProps;
private static _toCfnJsonSchema;
}
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const url_1 = require("url");
const jsonSchema = require("./json-schema");
const ALLOWED_METHODS = ['ANY', 'DELETE', 'GET', 'HEAD', 'OPTIONS', 'PATCH', 'POST', 'PUT'];

@@ -68,2 +69,53 @@ function validateHttpMethod(method, messagePrefix = '') {

exports.validateInteger = validateInteger;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInV0aWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSw2QkFBMEM7QUFDMUMsTUFBTSxlQUFlLEdBQUcsQ0FBRSxLQUFLLEVBQUUsUUFBUSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsU0FBUyxFQUFFLE9BQU8sRUFBRSxNQUFNLEVBQUUsS0FBSyxDQUFFLENBQUM7QUFFOUYsU0FBZ0Isa0JBQWtCLENBQUMsTUFBYyxFQUFFLGdCQUF3QixFQUFFO0lBQzNFLElBQUksQ0FBQyxlQUFlLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxFQUFFO1FBQ3JDLE1BQU0sSUFBSSxLQUFLLENBQUMsR0FBRyxhQUFhLHdCQUF3QixNQUFNLHVCQUF1QixlQUFlLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQztLQUNuSDtBQUNILENBQUM7QUFKRCxnREFJQztBQUVELFNBQWdCLHNCQUFzQixDQUFDLFlBQW9CO0lBQ3pELElBQUksQ0FBQyxZQUFZLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQyxFQUFFO1FBQ2pDLE1BQU0sSUFBSSxLQUFLLENBQUMsNENBQTRDLFlBQVksRUFBRSxDQUFDLENBQUM7S0FDN0U7SUFFRCxNQUFNLElBQUksR0FBRyxZQUFZLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsb0JBQW9CO0lBRXpELE1BQU0sVUFBVSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7SUFFbkMsSUFBSSxVQUFVLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtRQUN6QixNQUFNLElBQUksS0FBSyxDQUFDLHVHQUF1RyxJQUFJLEVBQUUsQ0FBQyxDQUFDO0tBQ2hJO0lBRUQsTUFBTSxVQUFVLEdBQUcsVUFBVSxDQUFDLEdBQUcsRUFBRyxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUMsbUNBQW1DO0lBQ3ZGLElBQUksVUFBVSxLQUFLLEdBQUcsRUFBRTtRQUN0QixrQkFBa0IsQ0FBQyxVQUFVLEVBQUUsR0FBRyxZQUFZLElBQUksQ0FBQyxDQUFDO0tBQ3JEO0lBRUQsSUFBSSxZQUFZLEdBQUcsS0FBSyxHQUFHLFVBQVUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDakQsSUFBSSxVQUFVLENBQUMsTUFBTSxLQUFLLENBQUMsSUFBSSxVQUFVLENBQUMsQ0FBQyxDQUFDLEtBQUssR0FBRyxFQUFFO1FBQ3BELFlBQVksR0FBRyxJQUFJLENBQUM7S0FDckI7U0FBTSxJQUFJLFVBQVUsQ0FBQyxNQUFNLEtBQUssQ0FBQyxJQUFJLFVBQVUsQ0FBQyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUU7UUFDMUQsWUFBWSxHQUFHLEdBQUcsQ0FBQztLQUNwQjtJQUVELE9BQU87UUFDTCxVQUFVO1FBQ1YsWUFBWTtLQUNiLENBQUM7QUFDSixDQUFDO0FBN0JELHdEQTZCQztBQUVELFNBQWdCLGVBQWUsQ0FBQyxJQUFhLEVBQUUsTUFBZSxFQUFFLFlBQXdDO0lBQ3RHLElBQUksWUFBWSxJQUFJLENBQUMsTUFBTSxFQUFFO1FBQzNCLE1BQU0sSUFBSSxLQUFLLENBQUMsbURBQW1ELENBQUMsQ0FBQztLQUN0RTtJQUVELElBQUksSUFBSSxJQUFJLE1BQU0sRUFBRTtRQUNsQixNQUFNLElBQUksS0FBSyxDQUFDLHFEQUFxRCxJQUFJLGNBQWMsTUFBTSxJQUFJLENBQUMsQ0FBQztLQUNwRztJQUVELElBQUksSUFBSSxFQUFFO1FBQ1IsT0FBTztZQUNMLE9BQU8sRUFBRSxNQUFNO1lBQ2YsUUFBUSxFQUFFLElBQUk7U0FDZixDQUFDO0tBQ0g7SUFFRCxJQUFJLE1BQU0sRUFBRTtRQUNWLElBQUksWUFBWSxFQUFFO1lBQ2hCLE1BQU0sSUFBSSxHQUFHLEdBQUcsWUFBUyxDQUFDLEVBQUUsS0FBSyxFQUFFLFlBQVksRUFBRSxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO1NBQzlEO1FBRUQsT0FBTztZQUNMLE9BQU8sRUFBRSxRQUFRO1lBQ2pCLFFBQVEsRUFBRSxNQUFNO1NBQ2pCLENBQUM7S0FDSDtJQUVELE1BQU0sSUFBSSxLQUFLLENBQUMsd0NBQXdDLENBQUMsQ0FBQztBQUM1RCxDQUFDO0FBNUJELDBDQTRCQztBQUVELFNBQWdCLGVBQWUsQ0FBQyxRQUE0QixFQUFFLGFBQXFCO0lBQ2pGLElBQUksUUFBUSxJQUFJLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsRUFBRTtRQUMzQyxNQUFNLElBQUksS0FBSyxDQUFDLEdBQUcsYUFBYSx1QkFBdUIsQ0FBQyxDQUFDO0tBQzFEO0FBQ0gsQ0FBQztBQUpELDBDQUlDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZm9ybWF0IGFzIGZvcm1hdFVybCB9IGZyb20gJ3VybCc7XG5jb25zdCBBTExPV0VEX01FVEhPRFMgPSBbICdBTlknLCAnREVMRVRFJywgJ0dFVCcsICdIRUFEJywgJ09QVElPTlMnLCAnUEFUQ0gnLCAnUE9TVCcsICdQVVQnIF07XG5cbmV4cG9ydCBmdW5jdGlvbiB2YWxpZGF0ZUh0dHBNZXRob2QobWV0aG9kOiBzdHJpbmcsIG1lc3NhZ2VQcmVmaXg6IHN0cmluZyA9ICcnKSB7XG4gIGlmICghQUxMT1dFRF9NRVRIT0RTLmluY2x1ZGVzKG1ldGhvZCkpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoYCR7bWVzc2FnZVByZWZpeH1JbnZhbGlkIEhUVFAgbWV0aG9kIFwiJHttZXRob2R9XCIuIEFsbG93ZWQgbWV0aG9kczogJHtBTExPV0VEX01FVEhPRFMuam9pbignLCcpfWApO1xuICB9XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBwYXJzZU1ldGhvZE9wdGlvbnNQYXRoKG9yaWdpbmFsUGF0aDogc3RyaW5nKTogeyByZXNvdXJjZVBhdGg6IHN0cmluZywgaHR0cE1ldGhvZDogc3RyaW5nIH0ge1xuICBpZiAoIW9yaWdpbmFsUGF0aC5zdGFydHNXaXRoKCcvJykpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoYE1ldGhvZCBvcHRpb25zIHBhdGggbXVzdCBzdGFydCB3aXRoICcvJzogJHtvcmlnaW5hbFBhdGh9YCk7XG4gIH1cblxuICBjb25zdCBwYXRoID0gb3JpZ2luYWxQYXRoLnN1YnN0cigxKTsgLy8gdHJpbSB0cmFpbGluZyAnLydcblxuICBjb25zdCBjb21wb25lbnRzID0gcGF0aC5zcGxpdCgnLycpO1xuXG4gIGlmIChjb21wb25lbnRzLmxlbmd0aCA8IDIpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoYE1ldGhvZCBvcHRpb25zIHBhdGggbXVzdCBpbmNsdWRlIGF0IGxlYXN0IHR3byBjb21wb25lbnRzOiAve3Jlc291cmNlfS97bWV0aG9kfSAoaS5lLiAvZm9vL2Jhci9HRVQpOiAke3BhdGh9YCk7XG4gIH1cblxuICBjb25zdCBodHRwTWV0aG9kID0gY29tcG9uZW50cy5wb3AoKSEudG9VcHBlckNhc2UoKTsgLy8gbGFzdCBjb21wb25lbnQgaXMgYW4gSFRUUCBtZXRob2RcbiAgaWYgKGh0dHBNZXRob2QgIT09ICcqJykge1xuICAgIHZhbGlkYXRlSHR0cE1ldGhvZChodHRwTWV0aG9kLCBgJHtvcmlnaW5hbFBhdGh9OiBgKTtcbiAgfVxuXG4gIGxldCByZXNvdXJjZVBhdGggPSAnL34xJyArIGNvbXBvbmVudHMuam9pbignfjEnKTtcbiAgaWYgKGNvbXBvbmVudHMubGVuZ3RoID09PSAxICYmIGNvbXBvbmVudHNbMF0gPT09ICcqJykge1xuICAgIHJlc291cmNlUGF0aCA9ICcvKic7XG4gIH0gZWxzZSBpZiAoY29tcG9uZW50cy5sZW5ndGggPT09IDEgJiYgY29tcG9uZW50c1swXSA9PT0gJycpIHtcbiAgICByZXNvdXJjZVBhdGggPSAnLyc7XG4gIH1cblxuICByZXR1cm4ge1xuICAgIGh0dHBNZXRob2QsXG4gICAgcmVzb3VyY2VQYXRoXG4gIH07XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBwYXJzZUF3c0FwaUNhbGwocGF0aD86IHN0cmluZywgYWN0aW9uPzogc3RyaW5nLCBhY3Rpb25QYXJhbXM/OiB7IFtrZXk6IHN0cmluZ106IHN0cmluZyB9KTogeyBhcGlUeXBlOiBzdHJpbmcsIGFwaVZhbHVlOiBzdHJpbmcgfSB7XG4gIGlmIChhY3Rpb25QYXJhbXMgJiYgIWFjdGlvbikge1xuICAgIHRocm93IG5ldyBFcnJvcihgXCJhY3Rpb25QYXJhbXNcIiByZXF1aXJlcyB0aGF0IFwiYWN0aW9uXCIgd2lsbCBiZSBzZXRgKTtcbiAgfVxuXG4gIGlmIChwYXRoICYmIGFjdGlvbikge1xuICAgIHRocm93IG5ldyBFcnJvcihgXCJwYXRoXCIgYW5kIFwiYWN0aW9uXCIgYXJlIG11dHVhbGx5IGV4Y2x1c2l2ZSAocGF0aD1cIiR7cGF0aH1cIiwgYWN0aW9uPVwiJHthY3Rpb259XCIpYCk7XG4gIH1cblxuICBpZiAocGF0aCkge1xuICAgIHJldHVybiB7XG4gICAgICBhcGlUeXBlOiAncGF0aCcsXG4gICAgICBhcGlWYWx1ZTogcGF0aFxuICAgIH07XG4gIH1cblxuICBpZiAoYWN0aW9uKSB7XG4gICAgaWYgKGFjdGlvblBhcmFtcykge1xuICAgICAgYWN0aW9uICs9ICcmJyArIGZvcm1hdFVybCh7IHF1ZXJ5OiBhY3Rpb25QYXJhbXMgfSkuc3Vic3RyKDEpO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICBhcGlUeXBlOiAnYWN0aW9uJyxcbiAgICAgIGFwaVZhbHVlOiBhY3Rpb25cbiAgICB9O1xuICB9XG5cbiAgdGhyb3cgbmV3IEVycm9yKGBFaXRoZXIgXCJwYXRoXCIgb3IgXCJhY3Rpb25cIiBhcmUgcmVxdWlyZWRgKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHZhbGlkYXRlSW50ZWdlcihwcm9wZXJ0eTogbnVtYmVyIHwgdW5kZWZpbmVkLCBtZXNzYWdlUHJlZml4OiBzdHJpbmcpIHtcbiAgaWYgKHByb3BlcnR5ICYmICFOdW1iZXIuaXNJbnRlZ2VyKHByb3BlcnR5KSkge1xuICAgIHRocm93IG5ldyBFcnJvcihgJHttZXNzYWdlUHJlZml4fSBzaG91bGQgYmUgYW4gaW50ZWdlcmApO1xuICB9XG59XG4iXX0=
class JsonSchemaMapper {
/**
* Transforms naming of some properties to prefix with a $, where needed
* according to the JSON schema spec
* @param schema The JsonSchema object to transform for CloudFormation output
*/
static toCfnJsonSchema(schema) {
const result = JsonSchemaMapper._toCfnJsonSchema(schema);
if (!("$schema" in result)) {
result.$schema = jsonSchema.JsonSchemaVersion.DRAFT4;
}
return result;
}
static _toCfnJsonSchema(schema) {
if (schema === null || schema === undefined) {
return schema;
}
if ((typeof (schema) === "string") || (typeof (schema) === "boolean") || (typeof (schema) === "number")) {
return schema;
}
if (Array.isArray(schema)) {
return schema.map((entry) => JsonSchemaMapper._toCfnJsonSchema(entry));
}
if (typeof (schema) === "object") {
return Object.assign({}, ...Object.entries(schema).map((entry) => {
const key = entry[0];
const newKey = (key in JsonSchemaMapper.SchemaPropsWithPrefix) ? JsonSchemaMapper.SchemaPropsWithPrefix[key] : key;
const value = (key in JsonSchemaMapper.SubSchemaProps) ? JsonSchemaMapper._toCfnJsonSchema(entry[1]) : entry[1];
return { [newKey]: value };
}));
}
return schema;
}
}
JsonSchemaMapper.SchemaPropsWithPrefix = {
schema: '$schema',
ref: '$ref',
id: '$id'
};
JsonSchemaMapper.SubSchemaProps = {
definitions: true,
items: true,
additionalItems: true,
contains: true,
properties: true,
additionalProperties: true,
patternProperties: true,
dependencies: true,
propertyNames: true
};
exports.JsonSchemaMapper = JsonSchemaMapper;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"util.js","sourceRoot":"","sources":["util.ts"],"names":[],"mappings":";;AAAA,6BAA0C;AAC1C,4CAA6C;AAE7C,MAAM,eAAe,GAAG,CAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,EAAE,KAAK,CAAE,CAAC;AAE9F,SAAgB,kBAAkB,CAAC,MAAc,EAAE,gBAAwB,EAAE;IAC3E,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE;QACrC,MAAM,IAAI,KAAK,CAAC,GAAG,aAAa,wBAAwB,MAAM,uBAAuB,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;KACnH;AACH,CAAC;AAJD,gDAIC;AAED,SAAgB,sBAAsB,CAAC,YAAoB;IACzD,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE;QACjC,MAAM,IAAI,KAAK,CAAC,4CAA4C,YAAY,EAAE,CAAC,CAAC;KAC7E;IAED,MAAM,IAAI,GAAG,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,oBAAoB;IAEzD,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAEnC,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE;QACzB,MAAM,IAAI,KAAK,CAAC,uGAAuG,IAAI,EAAE,CAAC,CAAC;KAChI;IAED,MAAM,UAAU,GAAG,UAAU,CAAC,GAAG,EAAG,CAAC,WAAW,EAAE,CAAC,CAAC,mCAAmC;IACvF,IAAI,UAAU,KAAK,GAAG,EAAE;QACtB,kBAAkB,CAAC,UAAU,EAAE,GAAG,YAAY,IAAI,CAAC,CAAC;KACrD;IAED,IAAI,YAAY,GAAG,KAAK,GAAG,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACjD,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,IAAI,UAAU,CAAC,CAAC,CAAC,KAAK,GAAG,EAAE;QACpD,YAAY,GAAG,IAAI,CAAC;KACrB;SAAM,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,IAAI,UAAU,CAAC,CAAC,CAAC,KAAK,EAAE,EAAE;QAC1D,YAAY,GAAG,GAAG,CAAC;KACpB;IAED,OAAO;QACL,UAAU;QACV,YAAY;KACb,CAAC;AACJ,CAAC;AA7BD,wDA6BC;AAED,SAAgB,eAAe,CAAC,IAAa,EAAE,MAAe,EAAE,YAAwC;IACtG,IAAI,YAAY,IAAI,CAAC,MAAM,EAAE;QAC3B,MAAM,IAAI,KAAK,CAAC,mDAAmD,CAAC,CAAC;KACtE;IAED,IAAI,IAAI,IAAI,MAAM,EAAE;QAClB,MAAM,IAAI,KAAK,CAAC,qDAAqD,IAAI,cAAc,MAAM,IAAI,CAAC,CAAC;KACpG;IAED,IAAI,IAAI,EAAE;QACR,OAAO;YACL,OAAO,EAAE,MAAM;YACf,QAAQ,EAAE,IAAI;SACf,CAAC;KACH;IAED,IAAI,MAAM,EAAE;QACV,IAAI,YAAY,EAAE;YAChB,MAAM,IAAI,GAAG,GAAG,YAAS,CAAC,EAAE,KAAK,EAAE,YAAY,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;SAC9D;QAED,OAAO;YACL,OAAO,EAAE,QAAQ;YACjB,QAAQ,EAAE,MAAM;SACjB,CAAC;KACH;IAED,MAAM,IAAI,KAAK,CAAC,wCAAwC,CAAC,CAAC;AAC5D,CAAC;AA5BD,0CA4BC;AAED,SAAgB,eAAe,CAAC,QAA4B,EAAE,aAAqB;IACjF,IAAI,QAAQ,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE;QAC3C,MAAM,IAAI,KAAK,CAAC,GAAG,aAAa,uBAAuB,CAAC,CAAC;KAC1D;AACH,CAAC;AAJD,0CAIC;AAED,MAAa,gBAAgB;IAC3B;;;;OAIG;IACI,MAAM,CAAC,eAAe,CAAC,MAA6B;QACzD,MAAM,MAAM,GAAG,gBAAgB,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;QACzD,IAAI,CAAE,CAAC,SAAS,IAAI,MAAM,CAAC,EAAE;YAC3B,MAAM,CAAC,OAAO,GAAG,UAAU,CAAC,iBAAiB,CAAC,MAAM,CAAC;SACtD;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;IAmBO,MAAM,CAAC,gBAAgB,CAAC,MAAW;QACzC,IAAI,MAAM,KAAK,IAAI,IAAI,MAAM,KAAK,SAAS,EAAE;YAC3C,OAAO,MAAM,CAAC;SACf;QACD,IAAI,CAAC,OAAM,CAAC,MAAM,CAAC,KAAK,QAAQ,CAAC,IAAI,CAAC,OAAM,CAAC,MAAM,CAAC,KAAK,SAAS,CAAC,IAAI,CAAC,OAAM,CAAC,MAAM,CAAC,KAAK,QAAQ,CAAC,EAAE;YACpG,OAAO,MAAM,CAAC;SACf;QACD,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YACzB,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,gBAAgB,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC,CAAC;SACxE;QACD,IAAI,OAAM,CAAC,MAAM,CAAC,KAAK,QAAQ,EAAE;YAC/B,OAAO,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,GAAG,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;gBAC/D,MAAM,GAAG,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;gBACrB,MAAM,MAAM,GAAG,CAAC,GAAG,IAAI,gBAAgB,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC,gBAAgB,CAAC,qBAAqB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;gBACnH,MAAM,KAAK,GAAG,CAAC,GAAG,IAAI,gBAAgB,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,gBAAgB,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;gBAChH,OAAO,EAAE,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,CAAC;YAC7B,CAAC,CAAC,CAAC,CAAC;SACL;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;;AApCuB,sCAAqB,GAA8B;IACzE,MAAM,EAAE,SAAS;IACjB,GAAG,EAAE,MAAM;IACX,EAAE,EAAE,KAAK;CACV,CAAC;AACsB,+BAAc,GAA+B;IACnE,WAAW,EAAE,IAAI;IACjB,KAAK,EAAE,IAAI;IACX,eAAe,EAAE,IAAI;IACrB,QAAQ,EAAE,IAAI;IACd,UAAU,EAAE,IAAI;IAChB,oBAAoB,EAAE,IAAI;IAC1B,iBAAiB,EAAE,IAAI;IACvB,YAAY,EAAE,IAAI;IAClB,aAAa,EAAE,IAAI;CACpB,CAAC;AA7BJ,4CAmDC","sourcesContent":["import { format as formatUrl } from 'url';\nimport jsonSchema = require('./json-schema');\n\nconst ALLOWED_METHODS = [ 'ANY', 'DELETE', 'GET', 'HEAD', 'OPTIONS', 'PATCH', 'POST', 'PUT' ];\n\nexport function validateHttpMethod(method: string, messagePrefix: string = '') {\n  if (!ALLOWED_METHODS.includes(method)) {\n    throw new Error(`${messagePrefix}Invalid HTTP method \"${method}\". Allowed methods: ${ALLOWED_METHODS.join(',')}`);\n  }\n}\n\nexport function parseMethodOptionsPath(originalPath: string): { resourcePath: string, httpMethod: string } {\n  if (!originalPath.startsWith('/')) {\n    throw new Error(`Method options path must start with '/': ${originalPath}`);\n  }\n\n  const path = originalPath.substr(1); // trim trailing '/'\n\n  const components = path.split('/');\n\n  if (components.length < 2) {\n    throw new Error(`Method options path must include at least two components: /{resource}/{method} (i.e. /foo/bar/GET): ${path}`);\n  }\n\n  const httpMethod = components.pop()!.toUpperCase(); // last component is an HTTP method\n  if (httpMethod !== '*') {\n    validateHttpMethod(httpMethod, `${originalPath}: `);\n  }\n\n  let resourcePath = '/~1' + components.join('~1');\n  if (components.length === 1 && components[0] === '*') {\n    resourcePath = '/*';\n  } else if (components.length === 1 && components[0] === '') {\n    resourcePath = '/';\n  }\n\n  return {\n    httpMethod,\n    resourcePath\n  };\n}\n\nexport function parseAwsApiCall(path?: string, action?: string, actionParams?: { [key: string]: string }): { apiType: string, apiValue: string } {\n  if (actionParams && !action) {\n    throw new Error(`\"actionParams\" requires that \"action\" will be set`);\n  }\n\n  if (path && action) {\n    throw new Error(`\"path\" and \"action\" are mutually exclusive (path=\"${path}\", action=\"${action}\")`);\n  }\n\n  if (path) {\n    return {\n      apiType: 'path',\n      apiValue: path\n    };\n  }\n\n  if (action) {\n    if (actionParams) {\n      action += '&' + formatUrl({ query: actionParams }).substr(1);\n    }\n\n    return {\n      apiType: 'action',\n      apiValue: action\n    };\n  }\n\n  throw new Error(`Either \"path\" or \"action\" are required`);\n}\n\nexport function validateInteger(property: number | undefined, messagePrefix: string) {\n  if (property && !Number.isInteger(property)) {\n    throw new Error(`${messagePrefix} should be an integer`);\n  }\n}\n\nexport class JsonSchemaMapper {\n  /**\n   * Transforms naming of some properties to prefix with a $, where needed\n   * according to the JSON schema spec\n   * @param schema The JsonSchema object to transform for CloudFormation output\n   */\n  public static toCfnJsonSchema(schema: jsonSchema.JsonSchema): any {\n    const result = JsonSchemaMapper._toCfnJsonSchema(schema);\n    if (! (\"$schema\" in result)) {\n      result.$schema = jsonSchema.JsonSchemaVersion.DRAFT4;\n    }\n    return result;\n  }\n\n  private static readonly SchemaPropsWithPrefix: { [key: string]: string } = {\n    schema: '$schema',\n    ref: '$ref',\n    id: '$id'\n  };\n  private static readonly SubSchemaProps: { [key: string]: boolean } = {\n    definitions: true,\n    items: true,\n    additionalItems: true,\n    contains: true,\n    properties: true,\n    additionalProperties: true,\n    patternProperties: true,\n    dependencies: true,\n    propertyNames: true\n  };\n\n  private static _toCfnJsonSchema(schema: any): any {\n    if (schema === null || schema === undefined) {\n      return schema;\n    }\n    if ((typeof(schema) === \"string\") || (typeof(schema) === \"boolean\") || (typeof(schema) === \"number\")) {\n      return schema;\n    }\n    if (Array.isArray(schema)) {\n      return schema.map((entry) => JsonSchemaMapper._toCfnJsonSchema(entry));\n    }\n    if (typeof(schema) === \"object\") {\n      return Object.assign({}, ...Object.entries(schema).map((entry) => {\n        const key = entry[0];\n        const newKey = (key in JsonSchemaMapper.SchemaPropsWithPrefix) ? JsonSchemaMapper.SchemaPropsWithPrefix[key] : key;\n        const value = (key in JsonSchemaMapper.SubSchemaProps) ? JsonSchemaMapper._toCfnJsonSchema(entry[1]) : entry[1];\n        return { [newKey]: value };\n      }));\n    }\n    return schema;\n  }\n}\n"]}
{
"name": "@aws-cdk/aws-apigateway",
"version": "0.36.0",
"version": "0.36.1",
"description": "The CDK Construct Library for AWS::ApiGateway",

@@ -69,21 +69,23 @@ "main": "lib/index.js",

"devDependencies": {
"@aws-cdk/assert": "^0.36.0",
"@aws-cdk/aws-ec2": "^0.36.0",
"cdk-build-tools": "^0.36.0",
"cdk-integ-tools": "^0.36.0",
"cfn2ts": "^0.36.0",
"pkglint": "^0.36.0"
"@aws-cdk/assert": "^0.36.1",
"@aws-cdk/aws-ec2": "^0.36.1",
"cdk-build-tools": "^0.36.1",
"cdk-integ-tools": "^0.36.1",
"cfn2ts": "^0.36.1",
"pkglint": "^0.36.1"
},
"dependencies": {
"@aws-cdk/aws-elasticloadbalancingv2": "^0.36.0",
"@aws-cdk/aws-iam": "^0.36.0",
"@aws-cdk/aws-lambda": "^0.36.0",
"@aws-cdk/core": "^0.36.0"
"@aws-cdk/aws-certificatemanager": "^0.36.1",
"@aws-cdk/aws-elasticloadbalancingv2": "^0.36.1",
"@aws-cdk/aws-iam": "^0.36.1",
"@aws-cdk/aws-lambda": "^0.36.1",
"@aws-cdk/core": "^0.36.1"
},
"homepage": "https://github.com/awslabs/aws-cdk",
"peerDependencies": {
"@aws-cdk/aws-elasticloadbalancingv2": "^0.36.0",
"@aws-cdk/aws-iam": "^0.36.0",
"@aws-cdk/aws-lambda": "^0.36.0",
"@aws-cdk/core": "^0.36.0"
"@aws-cdk/aws-certificatemanager": "^0.36.1",
"@aws-cdk/aws-elasticloadbalancingv2": "^0.36.1",
"@aws-cdk/aws-iam": "^0.36.1",
"@aws-cdk/aws-lambda": "^0.36.1",
"@aws-cdk/core": "^0.36.1"
},

@@ -105,3 +107,6 @@ "engines": {

"props-physical-name-type:@aws-cdk/aws-apigateway.StageProps.stageName",
"props-physical-name:@aws-cdk/aws-apigateway.LambdaRestApiProps"
"props-physical-name:@aws-cdk/aws-apigateway.BasePathMappingProps",
"props-physical-name:@aws-cdk/aws-apigateway.LambdaRestApiProps",
"construct-interface-extends-iconstruct:@aws-cdk/aws-apigateway.IModel",
"resource-interface-extends-resource:@aws-cdk/aws-apigateway.IModel"
]

@@ -108,0 +113,0 @@ },

@@ -158,2 +158,143 @@ ## Amazon API Gateway Construct Library

### Working with models
When you work with Lambda integrations that are not Proxy integrations, you
have to define your models and mappings for the request, response, and integration.
```ts
const hello = new lambda.Function(this, 'hello', {
runtime: lambda.Runtime.Nodejs10x,
handler: 'hello.handler',
code: lambda.Code.asset('lambda')
});
const api = new apigateway.RestApi(this, 'hello-api', { });
const resource = api.root.addResource('v1');
```
You can define more parameters on the integration to tune the behavior of API Gateway
```ts
const integration = new LambdaIntegration(hello, {
proxy: false,
requestParameters: {
// You can define mapping parameters from your method to your integration
// - Destination parameters (the key) are the integration parameters (used in mappings)
// - Source parameters (the value) are the source request parameters or expressions
// @see: https://docs.aws.amazon.com/apigateway/latest/developerguide/request-response-data-mappings.html
"integration.request.querystring.who": "method.request.querystring.who"
},
allowTestInvoke: true,
requestTemplates: {
// You can define a mapping that will build a payload for your integration, based
// on the integration parameters that you have specified
// Check: https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-mapping-template-reference.html
"application/json": '{ "action": "sayHello", "pollId": "$util.escapeJavaScript($input.params(\'who\'))" }'
},
// This parameter defines the behavior of the engine is no suitable response template is found
passthroughBehavior: PassthroughBehavior.Never,
integrationResponses: [
{
// Successful response from the Lambda function, no filter defined
// - the selectionPattern filter only tests the error message
// We will set the response status code to 200
statusCode: "200",
responseTemplates: {
// This template takes the "message" result from the Lambda function, adn embeds it in a JSON response
// Check https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-mapping-template-reference.html
"application/json": '{ "state": "ok", "greeting": "$util.escapeJavaScript($input.body)" }'
},
responseParameters: {
// We can map response parameters
// - Destination parameters (the key) are the response parameters (used in mappings)
// - Source parameters (the value) are the integration response parameters or expressions
'method.response.header.Content-Type': "'application/json'",
'method.response.header.Access-Control-Allow-Origin': "'*'",
'method.response.header.Access-Control-Allow-Credentials': "'true'"
}
},
{
// For errors, we check if the error message is not empty, get the error data
selectionPattern: '(\n|.)+',
// We will set the response status code to 200
statusCode: "400",
responseTemplates: {
"application/json": '{ "state": "error", "message": "$util.escapeJavaScript($input.path(\'$.errorMessage\'))" }'
},
responseParameters: {
'method.response.header.Content-Type': "'application/json'",
'method.response.header.Access-Control-Allow-Origin': "'*'",
'method.response.header.Access-Control-Allow-Credentials': "'true'"
}
}
]
});
```
You can define validation models for your responses (and requests)
```ts
// We define the JSON Schema for the transformed valid response
const responseModel = api.addModel('ResponseModel', {
contentType: "application/json",
modelName: 'ResponseModel',
schema: { "$schema": "http://json-schema.org/draft-04/schema#", "title": "pollResponse", "type": "object", "properties": { "state": { "type": "string" }, "greeting": { "type": "string" } } }
});
// We define the JSON Schema for the transformed error response
const errorResponseModel = api.addModel('ErrorResponseModel', {
contentType: "application/json",
modelName: 'ErrorResponseModel',
schema: { "$schema": "http://json-schema.org/draft-04/schema#", "title": "errorResponse", "type": "object", "properties": { "state": { "type": "string" }, "message": { "type": "string" } } }
});
```
And reference all on your method definition.
```ts
// If you want to define parameter mappings for the request, you need a validator
const validator = api.addRequestValidator('DefaultValidator', {
validateRequestBody: false,
validateRequestParameters: true
});
resource.addMethod('GET', integration, {
// We can mark the parameters as required
requestParameters: {
"method.request.querystring.who": true
},
// We need to set the validator for ensuring they are passed
requestValidator: validator,
methodResponses: [
{
// Successful response from the integration
statusCode: "200",
// Define what parameters are allowed or not
responseParameters: {
'method.response.header.Content-Type': true,
'method.response.header.Access-Control-Allow-Origin': true,
'method.response.header.Access-Control-Allow-Credentials': true
},
// Validate the schema on the response
responseModels: {
"application/json": responseModel
}
},
{
// Same thing for the error responses
statusCode: "400",
responseParameters: {
'method.response.header.Content-Type': true,
'method.response.header.Access-Control-Allow-Origin': true,
'method.response.header.Access-Control-Allow-Credentials': true
},
responseModels: {
"application/json": errorResponseModel
}
}
]
});
```
#### Default Integration and Method Options

@@ -261,13 +402,74 @@

### Missing Features
### Custom Domains
See [awslabs/aws-cdk#723](https://github.com/awslabs/aws-cdk/issues/723) for a
list of missing features.
To associate an API with a custom domain, use the `domainName` configuration when
you define your API:
### Roadmap
```ts
const api = new apigw.RestApi(this, 'MyDomain', {
domainName: {
domainName: 'example.com',
certificate: acmCertificateForExampleCom,
},
});
```
- [ ] Support defining REST API Models [#1695](https://github.com/awslabs/aws-cdk/issues/1695)
This will define a `DomainName` resource for you, along with a `BasePathMapping`
from the root of the domain to the deployment stage of the API. This is a common
set up.
To route domain traffic to an API Gateway API, use Amazon Route 53 to create an alias record. An alias record is a Route 53 extension to DNS. It's similar to a CNAME record, but you can create an alias record both for the root domain, such as example.com, and for subdomains, such as www.example.com. (You can create CNAME records only for subdomains.)
```ts
new route53.ARecord(this, 'CustomDomainAliasRecord', {
zone: hostedZoneForExampleCom,
target: route53.AddressRecordTarget.fromAlias(new route53_targets.ApiGateway(api))
});
```
You can also define a `DomainName` resource directly in order to customize the default behavior:
```ts
new apigw.DomainName(this, 'custom-domain', {
domainName: 'example.com',
certificate: acmCertificateForExampleCom,
endpointType: apigw.EndpointType.EDGE // default is REGIONAL
});
```
Once you have a domain, you can map base paths of the domain to APIs.
The following example will map the URL https://example.com/go-to-api1
to the `api1` API and https://example.com/boom to the `api2` API.
```ts
domain.addBasePathMapping(api1, { basePath: 'go-to-api1' });
domain.addBasePathMapping(api2, { basePath: 'boom' });
```
NOTE: currently, the mapping will always be assigned to the APIs
`deploymentStage`, which will automatically assigned to the latest API
deployment. Raise a GitHub issue if you require more granular control over
mapping base paths to stages.
If you don't specify `basePath`, all URLs under this domain will be mapped
to the API, and you won't be able to map another API to the same domain:
```ts
domain.addBasePathMapping(api);
```
This can also be achieved through the `mapping` configuration when defining the
domain as demonstrated above.
If you wish to setup this domain with an Amazon Route53 alias, use the `route53_targets.ApiGatewayDomain`:
```ts
new route53.ARecord(this, 'CustomDomainAliasRecord', {
zone: hostedZoneForExampleCom,
target: route53.AddressRecordTarget.fromAlias(new route53_targets.ApiGatewayDomain(domainName))
});
```
----
This module is part of the [AWS Cloud Development Kit](https://github.com/awslabs/aws-cdk) project.

@@ -165,6 +165,10 @@ "use strict";

options: { defaultIntegration: new apigw.HttpIntegration('https://foo/bar') }
}), /Cannot specify \"options\.defaultIntegration\" since Lambda integration is automatically defined/);
}), /Cannot specify \"defaultIntegration\" since Lambda integration is automatically defined/);
test.throws(() => new apigw.LambdaRestApi(stack, 'lambda-rest-api', {
handler,
defaultIntegration: new apigw.HttpIntegration('https://foo/bar')
}), /Cannot specify \"defaultIntegration\" since Lambda integration is automatically defined/);
test.done();
},
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.lambda-api.js","sourceRoot":"","sources":["test.lambda-api.ts"],"names":[],"mappings":";AAAA,4CAAuD;AACvD,8CAA+C;AAC/C,qCAAsC;AAEtC,gCAAiC;AAIjC,iBAAS;IACP,gEAAgE,CAAC,IAAU;QACzE,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;QAE9B,MAAM,OAAO,GAAG,IAAI,MAAM,CAAC,QAAQ,CAAC,KAAK,EAAE,SAAS,EAAE;YACpD,OAAO,EAAE,eAAe;YACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC;YAChC,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;SACpC,CAAC,CAAC;QAEH,OAAO;QACP,MAAM,GAAG,GAAG,IAAI,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,iBAAiB,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC;QAE3E,kCAAkC;QAClC,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE;YACf,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,iBAAiB,CAAC,CAAC;QAC1C,CAAC,CAAC,CAAC;QAEH,sCAAsC;QACtC,eAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,qBAAY,CAAC,2BAA2B,EAAE;YACzD,UAAU,EAAE,UAAU;SACvB,CAAC,CAAC,CAAC;QAEJ,eAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,qBAAY,CAAC,yBAAyB,EAAE;YACvD,YAAY,EAAE,KAAK;YACnB,YAAY,EAAE;gBACZ,KAAK,EAAE,4BAA4B;aACpC;YACD,WAAW,EAAE;gBACX,KAAK,EAAE,uBAAuB;aAC/B;YACD,mBAAmB,EAAE,MAAM;YAC3B,aAAa,EAAE;gBACb,uBAAuB,EAAE,MAAM;gBAC/B,MAAM,EAAE,WAAW;gBACnB,KAAK,EAAE;oBACL,UAAU,EAAE;wBACV,EAAE;wBACF;4BACE,MAAM;4BACN;gCACE,KAAK,EAAE,gBAAgB;6BACxB;4BACD,cAAc;4BACd;gCACE,KAAK,EAAE,aAAa;6BACrB;4BACD,oCAAoC;4BACpC;gCACE,YAAY,EAAE;oCACZ,iBAAiB;oCACjB,KAAK;iCACN;6BACF;4BACD,cAAc;yBACf;qBACF;iBACF;aACF;SACF,CAAC,CAAC,CAAC;QAEJ,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,uCAAuC,CAAC,IAAU;QAChD,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;QAE9B,MAAM,OAAO,GAAG,IAAI,MAAM,CAAC,QAAQ,CAAC,KAAK,EAAE,SAAS,EAAE;YACpD,OAAO,EAAE,eAAe;YACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC;YAChC,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;SACpC,CAAC,CAAC;QACH,MAAM,KAAK,GAAG,IAAI,MAAM,CAAC,KAAK,CAAC,KAAK,EAAE,OAAO,EAAE;YAC7C,SAAS,EAAE,UAAU;YACrB,OAAO,EAAE,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,EAAE,SAAS,EAAE;gBAC5C,MAAM,EAAE,OAAO;aAChB,CAAC;SACH,CAAC,CAAC;QAEH,OAAO;QACP,MAAM,GAAG,GAAG,IAAI,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,iBAAiB,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;QAElF,kCAAkC;QAClC,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE;YACf,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,iBAAiB,CAAC,CAAC;QAC1C,CAAC,CAAC,CAAC;QAEH,sCAAsC;QACtC,eAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,qBAAY,CAAC,2BAA2B,EAAE;YACzD,UAAU,EAAE,UAAU;SACvB,CAAC,CAAC,CAAC;QAEJ,eAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,qBAAY,CAAC,yBAAyB,EAAE;YACvD,YAAY,EAAE,KAAK;YACnB,YAAY,EAAE;gBACZ,KAAK,EAAE,4BAA4B;aACpC;YACD,WAAW,EAAE;gBACX,KAAK,EAAE,uBAAuB;aAC/B;YACD,mBAAmB,EAAE,MAAM;YAC3B,aAAa,EAAE;gBACb,uBAAuB,EAAE,MAAM;gBAC/B,MAAM,EAAE,WAAW;gBACnB,KAAK,EAAE;oBACL,UAAU,EAAE;wBACV,EAAE;wBACF;4BACE,MAAM;4BACN;gCACE,KAAK,EAAE,gBAAgB;6BACxB;4BACD,cAAc;4BACd;gCACE,KAAK,EAAE,aAAa;6BACrB;4BACD,oCAAoC;4BACpC;gCACE,KAAK,EAAE,eAAe;6BACvB;4BACD,cAAc;yBACf;qBACF;iBACF;aACF;SACF,CAAC,CAAC,CAAC;QAEJ,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,8DAA8D,CAAC,IAAU;QACvE,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;QAE9B,MAAM,OAAO,GAAG,IAAI,MAAM,CAAC,QAAQ,CAAC,KAAK,EAAE,SAAS,EAAE;YACpD,OAAO,EAAE,eAAe;YACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC;YAChC,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;SACpC,CAAC,CAAC;QAEH,OAAO;QACP,MAAM,GAAG,GAAG,IAAI,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,iBAAiB,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC;QAEzF,MAAM,KAAK,GAAG,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;QAC5C,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QACvB,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QAExB,OAAO;QACP,eAAM,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,qBAAY,CAAC,2BAA2B,EAAE;YAC5D,UAAU,EAAE,UAAU;SACvB,CAAC,CAAC,CAAC;QAEJ,eAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,qBAAY,CAAC,2BAA2B,EAAE;YACzD,QAAQ,EAAE,OAAO;SAClB,CAAC,CAAC,CAAC;QAEJ,eAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,qBAAY,CAAC,yBAAyB,EAAE;YACvD,UAAU,EAAE,KAAK;YACjB,UAAU,EAAE,EAAE,GAAG,EAAE,4BAA4B,EAAE;SAClD,CAAC,CAAC,CAAC;QAEJ,eAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,qBAAY,CAAC,yBAAyB,EAAE;YACvD,UAAU,EAAE,MAAM;YAClB,UAAU,EAAE,EAAE,GAAG,EAAE,4BAA4B,EAAE;SAClD,CAAC,CAAC,CAAC;QAEJ,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,iDAAiD,CAAC,IAAU;QAC1D,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;QAE9B,MAAM,OAAO,GAAG,IAAI,MAAM,CAAC,QAAQ,CAAC,KAAK,EAAE,SAAS,EAAE;YACpD,OAAO,EAAE,eAAe;YACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC;YAChC,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;SACpC,CAAC,CAAC;QAEH,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,IAAI,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,iBAAiB,EAAE;YAClE,OAAO;YACP,OAAO,EAAE,EAAE,kBAAkB,EAAE,IAAI,KAAK,CAAC,eAAe,CAAC,iBAAiB,CAAC,EAAE;SAC9E,CAAC,EAAE,kGAAkG,CAAC,CAAC;QAExG,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;CACF,CAAC","sourcesContent":["import { expect, haveResource } from '@aws-cdk/assert';\nimport lambda = require('@aws-cdk/aws-lambda');\nimport cdk = require('@aws-cdk/core');\nimport { Test } from 'nodeunit';\nimport apigw = require('../lib');\n\n// tslint:disable:object-literal-key-quotes\n\nexport = {\n  'LambdaRestApi defines a REST API with Lambda proxy integration'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n\n    const handler = new lambda.Function(stack, 'handler', {\n      handler: 'index.handler',\n      code: lambda.Code.inline('boom'),\n      runtime: lambda.Runtime.NODEJS_8_10,\n    });\n\n    // WHEN\n    const api = new apigw.LambdaRestApi(stack, 'lambda-rest-api', { handler });\n\n    // THEN -- can't customize further\n    test.throws(() => {\n      api.root.addResource('cant-touch-this');\n    });\n\n    // THEN -- template proxies everything\n    expect(stack).to(haveResource('AWS::ApiGateway::Resource', {\n      \"PathPart\": \"{proxy+}\"\n    }));\n\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', {\n      \"HttpMethod\": \"ANY\",\n      \"ResourceId\": {\n        \"Ref\": \"lambdarestapiproxyE3AE07E3\"\n      },\n      \"RestApiId\": {\n        \"Ref\": \"lambdarestapiAAD10924\"\n      },\n      \"AuthorizationType\": \"NONE\",\n      \"Integration\": {\n        \"IntegrationHttpMethod\": \"POST\",\n        \"Type\": \"AWS_PROXY\",\n        \"Uri\": {\n          \"Fn::Join\": [\n            \"\",\n            [\n              \"arn:\",\n              {\n                \"Ref\": \"AWS::Partition\"\n              },\n              \":apigateway:\",\n              {\n                \"Ref\": \"AWS::Region\"\n              },\n              \":lambda:path/2015-03-31/functions/\",\n              {\n                \"Fn::GetAtt\": [\n                  \"handlerE1533BD5\",\n                  \"Arn\"\n                ]\n              },\n              \"/invocations\"\n            ]\n          ]\n        }\n      }\n    }));\n\n    test.done();\n  },\n\n  'LambdaRestApi supports function Alias'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n\n    const handler = new lambda.Function(stack, 'handler', {\n      handler: 'index.handler',\n      code: lambda.Code.inline('boom'),\n      runtime: lambda.Runtime.NODEJS_8_10,\n    });\n    const alias = new lambda.Alias(stack, 'alias', {\n      aliasName: 'my-alias',\n      version: new lambda.Version(stack, 'version', {\n        lambda: handler\n      })\n    });\n\n    // WHEN\n    const api = new apigw.LambdaRestApi(stack, 'lambda-rest-api', { handler: alias });\n\n    // THEN -- can't customize further\n    test.throws(() => {\n      api.root.addResource('cant-touch-this');\n    });\n\n    // THEN -- template proxies everything\n    expect(stack).to(haveResource('AWS::ApiGateway::Resource', {\n      \"PathPart\": \"{proxy+}\"\n    }));\n\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', {\n      \"HttpMethod\": \"ANY\",\n      \"ResourceId\": {\n        \"Ref\": \"lambdarestapiproxyE3AE07E3\"\n      },\n      \"RestApiId\": {\n        \"Ref\": \"lambdarestapiAAD10924\"\n      },\n      \"AuthorizationType\": \"NONE\",\n      \"Integration\": {\n        \"IntegrationHttpMethod\": \"POST\",\n        \"Type\": \"AWS_PROXY\",\n        \"Uri\": {\n          \"Fn::Join\": [\n            \"\",\n            [\n              \"arn:\",\n              {\n                \"Ref\": \"AWS::Partition\"\n              },\n              \":apigateway:\",\n              {\n                \"Ref\": \"AWS::Region\"\n              },\n              \":lambda:path/2015-03-31/functions/\",\n              {\n                \"Ref\": \"alias68BF17F5\"\n              },\n              \"/invocations\"\n            ]\n          ]\n        }\n      }\n    }));\n\n    test.done();\n  },\n\n  'when \"proxy\" is set to false, users need to define the model'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n\n    const handler = new lambda.Function(stack, 'handler', {\n      handler: 'index.handler',\n      code: lambda.Code.inline('boom'),\n      runtime: lambda.Runtime.NODEJS_8_10,\n    });\n\n    // WHEN\n    const api = new apigw.LambdaRestApi(stack, 'lambda-rest-api', { handler, proxy: false });\n\n    const tasks = api.root.addResource('tasks');\n    tasks.addMethod('GET');\n    tasks.addMethod('POST');\n\n    // THEN\n    expect(stack).notTo(haveResource('AWS::ApiGateway::Resource', {\n      \"PathPart\": \"{proxy+}\"\n    }));\n\n    expect(stack).to(haveResource('AWS::ApiGateway::Resource', {\n      PathPart: 'tasks'\n    }));\n\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', {\n      HttpMethod: 'GET',\n      ResourceId: { Ref: 'lambdarestapitasks224418C8' }\n    }));\n\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', {\n      HttpMethod: 'POST',\n      ResourceId: { Ref: 'lambdarestapitasks224418C8' }\n    }));\n\n    test.done();\n  },\n\n  'fails if options.defaultIntegration is also set'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n\n    const handler = new lambda.Function(stack, 'handler', {\n      handler: 'index.handler',\n      code: lambda.Code.inline('boom'),\n      runtime: lambda.Runtime.NODEJS_8_10,\n    });\n\n    test.throws(() => new apigw.LambdaRestApi(stack, 'lambda-rest-api', {\n      handler,\n      options: { defaultIntegration: new apigw.HttpIntegration('https://foo/bar') }\n    }), /Cannot specify \\\"options\\.defaultIntegration\\\" since Lambda integration is automatically defined/);\n\n    test.done();\n  },\n};\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.lambda-api.js","sourceRoot":"","sources":["test.lambda-api.ts"],"names":[],"mappings":"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","sourcesContent":["import { expect, haveResource } from '@aws-cdk/assert';\nimport lambda = require('@aws-cdk/aws-lambda');\nimport cdk = require('@aws-cdk/core');\nimport { Test } from 'nodeunit';\nimport apigw = require('../lib');\n\n// tslint:disable:object-literal-key-quotes\n\nexport = {\n  'LambdaRestApi defines a REST API with Lambda proxy integration'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n\n    const handler = new lambda.Function(stack, 'handler', {\n      handler: 'index.handler',\n      code: lambda.Code.inline('boom'),\n      runtime: lambda.Runtime.NODEJS_8_10,\n    });\n\n    // WHEN\n    const api = new apigw.LambdaRestApi(stack, 'lambda-rest-api', { handler });\n\n    // THEN -- can't customize further\n    test.throws(() => {\n      api.root.addResource('cant-touch-this');\n    });\n\n    // THEN -- template proxies everything\n    expect(stack).to(haveResource('AWS::ApiGateway::Resource', {\n      \"PathPart\": \"{proxy+}\"\n    }));\n\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', {\n      \"HttpMethod\": \"ANY\",\n      \"ResourceId\": {\n        \"Ref\": \"lambdarestapiproxyE3AE07E3\"\n      },\n      \"RestApiId\": {\n        \"Ref\": \"lambdarestapiAAD10924\"\n      },\n      \"AuthorizationType\": \"NONE\",\n      \"Integration\": {\n        \"IntegrationHttpMethod\": \"POST\",\n        \"Type\": \"AWS_PROXY\",\n        \"Uri\": {\n          \"Fn::Join\": [\n            \"\",\n            [\n              \"arn:\",\n              {\n                \"Ref\": \"AWS::Partition\"\n              },\n              \":apigateway:\",\n              {\n                \"Ref\": \"AWS::Region\"\n              },\n              \":lambda:path/2015-03-31/functions/\",\n              {\n                \"Fn::GetAtt\": [\n                  \"handlerE1533BD5\",\n                  \"Arn\"\n                ]\n              },\n              \"/invocations\"\n            ]\n          ]\n        }\n      }\n    }));\n\n    test.done();\n  },\n\n  'LambdaRestApi supports function Alias'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n\n    const handler = new lambda.Function(stack, 'handler', {\n      handler: 'index.handler',\n      code: lambda.Code.inline('boom'),\n      runtime: lambda.Runtime.NODEJS_8_10,\n    });\n    const alias = new lambda.Alias(stack, 'alias', {\n      aliasName: 'my-alias',\n      version: new lambda.Version(stack, 'version', {\n        lambda: handler\n      })\n    });\n\n    // WHEN\n    const api = new apigw.LambdaRestApi(stack, 'lambda-rest-api', { handler: alias });\n\n    // THEN -- can't customize further\n    test.throws(() => {\n      api.root.addResource('cant-touch-this');\n    });\n\n    // THEN -- template proxies everything\n    expect(stack).to(haveResource('AWS::ApiGateway::Resource', {\n      \"PathPart\": \"{proxy+}\"\n    }));\n\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', {\n      \"HttpMethod\": \"ANY\",\n      \"ResourceId\": {\n        \"Ref\": \"lambdarestapiproxyE3AE07E3\"\n      },\n      \"RestApiId\": {\n        \"Ref\": \"lambdarestapiAAD10924\"\n      },\n      \"AuthorizationType\": \"NONE\",\n      \"Integration\": {\n        \"IntegrationHttpMethod\": \"POST\",\n        \"Type\": \"AWS_PROXY\",\n        \"Uri\": {\n          \"Fn::Join\": [\n            \"\",\n            [\n              \"arn:\",\n              {\n                \"Ref\": \"AWS::Partition\"\n              },\n              \":apigateway:\",\n              {\n                \"Ref\": \"AWS::Region\"\n              },\n              \":lambda:path/2015-03-31/functions/\",\n              {\n                \"Ref\": \"alias68BF17F5\"\n              },\n              \"/invocations\"\n            ]\n          ]\n        }\n      }\n    }));\n\n    test.done();\n  },\n\n  'when \"proxy\" is set to false, users need to define the model'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n\n    const handler = new lambda.Function(stack, 'handler', {\n      handler: 'index.handler',\n      code: lambda.Code.inline('boom'),\n      runtime: lambda.Runtime.NODEJS_8_10,\n    });\n\n    // WHEN\n    const api = new apigw.LambdaRestApi(stack, 'lambda-rest-api', { handler, proxy: false });\n\n    const tasks = api.root.addResource('tasks');\n    tasks.addMethod('GET');\n    tasks.addMethod('POST');\n\n    // THEN\n    expect(stack).notTo(haveResource('AWS::ApiGateway::Resource', {\n      \"PathPart\": \"{proxy+}\"\n    }));\n\n    expect(stack).to(haveResource('AWS::ApiGateway::Resource', {\n      PathPart: 'tasks'\n    }));\n\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', {\n      HttpMethod: 'GET',\n      ResourceId: { Ref: 'lambdarestapitasks224418C8' }\n    }));\n\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', {\n      HttpMethod: 'POST',\n      ResourceId: { Ref: 'lambdarestapitasks224418C8' }\n    }));\n\n    test.done();\n  },\n\n  'fails if options.defaultIntegration is also set'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n\n    const handler = new lambda.Function(stack, 'handler', {\n      handler: 'index.handler',\n      code: lambda.Code.inline('boom'),\n      runtime: lambda.Runtime.NODEJS_8_10,\n    });\n\n    test.throws(() => new apigw.LambdaRestApi(stack, 'lambda-rest-api', {\n      handler,\n      options: { defaultIntegration: new apigw.HttpIntegration('https://foo/bar') }\n    }), /Cannot specify \\\"defaultIntegration\\\" since Lambda integration is automatically defined/);\n\n    test.throws(() => new apigw.LambdaRestApi(stack, 'lambda-rest-api', {\n      handler,\n      defaultIntegration: new apigw.HttpIntegration('https://foo/bar')\n    }), /Cannot specify \\\"defaultIntegration\\\" since Lambda integration is automatically defined/);\n\n    test.done();\n  },\n};\n"]}

@@ -19,3 +19,6 @@ import { Test } from 'nodeunit';

'method is always set as uppercase'(test: Test): void;
'requestModel can be set'(test: Test): void;
'methodResponse has a mix of response modes'(test: Test): void;
'method has a request validator'(test: Test): void;
};
export = _default;

@@ -303,4 +303,4 @@ "use strict";

responseModels: {
'application/json': new lib_1.EmptyModel(),
'text/plain': new lib_1.ErrorModel()
'application/json': apigateway.Model.EMPTY_MODEL,
'text/plain': apigateway.Model.ERROR_MODEL
}

@@ -391,4 +391,126 @@ }

test.done();
},
'requestModel can be set'(test) {
// GIVEN
const stack = new cdk.Stack();
const api = new apigateway.RestApi(stack, 'test-api', { deploy: false });
const model = api.addModel('test-model', {
contentType: "application/json",
modelName: 'test-model',
schema: {
title: "test",
type: lib_1.JsonSchemaType.OBJECT,
properties: { message: { type: lib_1.JsonSchemaType.STRING } }
}
});
// WHEN
new apigateway.Method(stack, 'method-man', {
httpMethod: 'GET',
resource: api.root,
options: {
requestModels: {
"application/json": model
}
}
});
// THEN
assert_1.expect(stack).to(assert_1.haveResource('AWS::ApiGateway::Method', {
HttpMethod: 'GET',
RequestModels: {
"application/json": { Ref: stack.getLogicalId(model.node.findChild('Resource')) }
}
}));
test.done();
},
'methodResponse has a mix of response modes'(test) {
// GIVEN
const stack = new cdk.Stack();
const api = new apigateway.RestApi(stack, 'test-api', { deploy: false });
const htmlModel = api.addModel('my-model', {
schema: {
schema: lib_1.JsonSchemaVersion.DRAFT4,
title: "test",
type: lib_1.JsonSchemaType.OBJECT,
properties: { message: { type: lib_1.JsonSchemaType.STRING } }
}
});
// WHEN
new apigateway.Method(stack, 'method-man', {
httpMethod: 'GET',
resource: api.root,
options: {
methodResponses: [{
statusCode: '200'
}, {
statusCode: "400",
responseParameters: {
'method.response.header.killerbees': false
}
}, {
statusCode: "500",
responseParameters: {
'method.response.header.errthing': true
},
responseModels: {
'application/json': apigateway.Model.EMPTY_MODEL,
'text/plain': apigateway.Model.ERROR_MODEL,
'text/html': htmlModel
}
}
]
}
});
// THEN
assert_1.expect(stack).to(assert_1.haveResource('AWS::ApiGateway::Method', {
HttpMethod: 'GET',
MethodResponses: [{
StatusCode: "200"
}, {
StatusCode: "400",
ResponseParameters: {
'method.response.header.killerbees': false
}
}, {
StatusCode: "500",
ResponseParameters: {
'method.response.header.errthing': true
},
ResponseModels: {
'application/json': 'Empty',
'text/plain': 'Error',
'text/html': { Ref: stack.getLogicalId(htmlModel.node.findChild('Resource')) }
}
}
]
}));
test.done();
},
'method has a request validator'(test) {
// GIVEN
const stack = new cdk.Stack();
const api = new apigateway.RestApi(stack, 'test-api', { deploy: false });
const validator = api.addRequestValidator('validator', {
validateRequestBody: true,
validateRequestParameters: false
});
// WHEN
new apigateway.Method(stack, 'method-man', {
httpMethod: 'GET',
resource: api.root,
options: {
requestValidator: validator
}
});
// THEN
assert_1.expect(stack).to(assert_1.haveResource('AWS::ApiGateway::Method', {
RequestValidatorId: { Ref: stack.getLogicalId(validator.node.findChild('Resource')) }
}));
assert_1.expect(stack).to(assert_1.haveResource('AWS::ApiGateway::RequestValidator', {
RestApiId: { Ref: stack.getLogicalId(api.node.findChild('Resource')) },
ValidateRequestBody: true,
ValidateRequestParameters: false
}));
test.done();
}
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.method.js","sourceRoot":"","sources":["test.method.ts"],"names":[],"mappings":";AAAA,4CAAyE;AACzE,wCAAyC;AACzC,6DAA8D;AAC9D,wCAAyC;AACzC,qCAAsC;AAEtC,qCAAsC;AACtC,gCAAgE;AAEhE,iBAAS;IACP,eAAe,CAAC,IAAU;QACxB,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;QAC9B,MAAM,GAAG,GAAG,IAAI,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE,cAAc,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;QAEhG,OAAO;QACP,IAAI,UAAU,CAAC,MAAM,CAAC,KAAK,EAAE,WAAW,EAAE;YACxC,UAAU,EAAE,MAAM;YAClB,QAAQ,EAAE,GAAG,CAAC,IAAI;SACnB,CAAC,CAAC;QAEH,OAAO;QACP,eAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,qBAAY,CAAC,yBAAyB,EAAE;YACvD,UAAU,EAAE,MAAM;YAClB,iBAAiB,EAAE,MAAM;YACzB,WAAW,EAAE;gBACX,IAAI,EAAE,MAAM;aACb;SACF,CAAC,CAAC,CAAC;QAEJ,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,iCAAiC,CAAC,IAAU;QAC1C,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;QAC9B,MAAM,GAAG,GAAG,IAAI,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE,cAAc,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;QAEhG,OAAO;QACP,IAAI,UAAU,CAAC,MAAM,CAAC,KAAK,EAAE,WAAW,EAAE;YACxC,UAAU,EAAE,MAAM;YAClB,QAAQ,EAAE,GAAG,CAAC,IAAI;YAClB,OAAO,EAAE;gBACP,cAAc,EAAE,IAAI;gBACpB,aAAa,EAAE,aAAa;aAC7B;SACF,CAAC,CAAC;QAEH,OAAO;QACP,eAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,qBAAY,CAAC,yBAAyB,EAAE;YACvD,cAAc,EAAE,IAAI;YACpB,aAAa,EAAE,aAAa;SAC7B,CAAC,CAAC,CAAC;QAEJ,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,uCAAuC,CAAC,IAAU;QAChD,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;QAC9B,MAAM,GAAG,GAAG,IAAI,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE,cAAc,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;QAEhG,OAAO;QACP,IAAI,UAAU,CAAC,MAAM,CAAC,KAAK,EAAE,WAAW,EAAE;YACxC,UAAU,EAAE,MAAM;YAClB,QAAQ,EAAE,GAAG,CAAC,IAAI;YAClB,WAAW,EAAE,IAAI,UAAU,CAAC,cAAc,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC;SAClF,CAAC,CAAC;QAEH,OAAO;QACP,eAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,qBAAY,CAAC,yBAAyB,EAAE;YACvD,WAAW,EAAE;gBACX,qBAAqB,EAAE,MAAM;gBAC7B,IAAI,EAAE,KAAK;gBACX,GAAG,EAAE;oBACH,UAAU,EAAE;wBACZ,EAAE;wBACF;4BACE,MAAM,EAAE,EAAE,GAAG,EAAE,gBAAgB,EAAE,EAAE,cAAc;4BACjD,EAAE,GAAG,EAAE,aAAa,EAAE,EAAE,qBAAqB;yBAC9C;qBACA;iBACF;aACF;SACF,CAAC,CAAC,CAAC;QAEJ,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,iEAAiE,CAAC,IAAU;QAC1E,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;QAC9B,MAAM,GAAG,GAAG,IAAI,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE,cAAc,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;QAEhG,OAAO;QACP,IAAI,UAAU,CAAC,MAAM,CAAC,KAAK,EAAE,WAAW,EAAE;YACxC,UAAU,EAAE,MAAM;YAClB,QAAQ,EAAE,GAAG,CAAC,IAAI;YAClB,WAAW,EAAE,IAAI,UAAU,CAAC,cAAc,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,YAAY,EAAE,qBAAqB,EAAE,KAAK,EAAE,CAAC;SAChH,CAAC,CAAC;QAEH,OAAO;QACP,eAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,yBAAgB,CAAC,yBAAyB,EAAE;YAC3D,WAAW,EAAE;gBACX,qBAAqB,EAAE,KAAK;aAC7B;SACF,CAAC,CAAC,CAAC;QAEJ,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,kCAAkC,CAAC,IAAU;QAC3C,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;QAC9B,MAAM,kBAAkB,GAAG,IAAI,UAAU,CAAC,WAAW,CAAC,EAAE,IAAI,EAAE,UAAU,CAAC,eAAe,CAAC,UAAU,EAAE,GAAG,EAAE,oBAAoB,EAAE,CAAC,CAAC;QAClI,MAAM,GAAG,GAAG,IAAI,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,UAAU,EAAE;YACpD,cAAc,EAAE,KAAK;YACrB,MAAM,EAAE,KAAK;YACb,kBAAkB;SACnB,CAAC,CAAC;QAEH,OAAO;QACP,IAAI,UAAU,CAAC,MAAM,CAAC,KAAK,EAAE,WAAW,EAAE;YACxC,UAAU,EAAE,MAAM;YAClB,QAAQ,EAAE,GAAG,CAAC,IAAI;SACnB,CAAC,CAAC;QAEH,OAAO;QACP,eAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,qBAAY,CAAC,yBAAyB,EAAE;YACvD,WAAW,EAAE;gBACX,IAAI,EAAE,YAAY;gBAClB,GAAG,EAAE,oBAAoB;aAC1B;SACF,CAAC,CAAC,CAAC;QAEJ,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,kFAAkF,CAAC,IAAU;QAC3F,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;QAC9B,MAAM,GAAG,GAAG,IAAI,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC;QAEtD,OAAO;QACP,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,MAAM,CAAC,KAAK,EAAE,WAAW,EAAE;YACvD,UAAU,EAAE,MAAM;YAClB,QAAQ,EAAE,GAAG,CAAC,IAAI;SACnB,CAAC,CAAC;QAEH,OAAO;QACP,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE;YAC9C,UAAU,EAAE;gBACV,EAAE;gBACF;oBACA,MAAM;oBACN,EAAE,GAAG,EAAE,gBAAgB,EAAE;oBACzB,eAAe;oBACf,EAAE,GAAG,EAAE,aAAa,EAAE;oBACtB,GAAG;oBACH,EAAE,GAAG,EAAE,gBAAgB,EAAE;oBACzB,GAAG;oBACH,EAAE,GAAG,EAAE,iBAAiB,EAAE;oBAC1B,GAAG;oBACH,EAAE,GAAG,EAAE,oCAAoC,EAAE;oBAC7C,QAAQ;iBACP;aACF;SACF,CAAC,CAAC;QAEH,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,+EAA+E,CAAC,IAAU;QACxF,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;QAC9B,MAAM,GAAG,GAAG,IAAI,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC;QAEtD,OAAO;QACP,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,MAAM,CAAC,KAAK,EAAE,WAAW,EAAE;YACvD,UAAU,EAAE,MAAM;YAClB,QAAQ,EAAE,GAAG,CAAC,IAAI;SACnB,CAAC,CAAC;QAEH,OAAO;QACP,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,aAAa,CAAC,EAAE;YAClD,UAAU,EAAE;gBACV,EAAE;gBACF;oBACA,MAAM;oBACN,EAAE,GAAG,EAAE,gBAAgB,EAAE;oBACzB,eAAe;oBACf,EAAE,GAAG,EAAE,aAAa,EAAE;oBACtB,GAAG;oBACH,EAAE,GAAG,EAAE,gBAAgB,EAAE;oBACzB,GAAG;oBACH,EAAE,GAAG,EAAE,iBAAiB,EAAE;oBAC1B,0BAA0B;iBACzB;aACF;SACF,CAAC,CAAC;QAEH,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,+DAA+D,CAAC,IAAU;QACxE,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;QAC9B,MAAM,GAAG,GAAG,IAAI,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;QACzE,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,MAAM,CAAC,KAAK,EAAE,WAAW,EAAE,EAAE,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC;QAErG,cAAc;QACd,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,SAAS,EAChC,kGAAkG,CAAC,CAAC;QAEtG,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,iFAAiF,CAAC,IAAU;QAC1F,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;QAC9B,MAAM,GAAG,GAAG,IAAI,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;QACzE,MAAM,IAAI,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,QAAQ,EAAE,EAAE,SAAS,EAAE,IAAI,GAAG,CAAC,gBAAgB,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QAE3F,OAAO;QACP,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,IAAI,UAAU,CAAC,WAAW,CAAC;YACnD,IAAI,EAAE,UAAU,CAAC,eAAe,CAAC,SAAS;YAC1C,OAAO,EAAE;gBACP,eAAe,EAAE,IAAI;aACtB;SACF,CAAC,CAAC,CAAC;QAEJ,OAAO;QACP,eAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,yBAAgB,CAAC,yBAAyB,EAAE;YAC3D,WAAW,EAAE;gBACX,WAAW,EAAE,EAAE,YAAY,EAAE,CAAE,gBAAgB,EAAE,KAAK,CAAE,EAAE;aAC3D;SACF,CAAC,CAAC,CAAC;QACJ,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,6FAA6F,CAAC,IAAU;QACtG,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;QAC9B,MAAM,GAAG,GAAG,IAAI,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;QAEzE,OAAO;QACP,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,IAAI,UAAU,CAAC,WAAW,CAAC;YACnD,IAAI,EAAE,UAAU,CAAC,eAAe,CAAC,SAAS;YAC1C,OAAO,EAAE;gBACP,sBAAsB,EAAE,IAAI;aAC7B;SACF,CAAC,CAAC,CAAC;QAEJ,OAAO;QACP,eAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,yBAAgB,CAAC,yBAAyB,EAAE;YAC3D,WAAW,EAAE;gBACX,WAAW,EAAE,EAAE,UAAU,EAAE,CAAE,EAAE,EAAE,CAAE,MAAM,EAAE,EAAE,GAAG,EAAE,gBAAgB,EAAE,EAAE,gBAAgB,CAAE,CAAE,EAAE;aAC7F;SACF,CAAC,CAAC,CAAC;QACJ,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,mFAAmF,CAAC,IAAU;QAC5F,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;QAC9B,MAAM,GAAG,GAAG,IAAI,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;QACzE,MAAM,IAAI,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,QAAQ,EAAE,EAAE,SAAS,EAAE,IAAI,GAAG,CAAC,gBAAgB,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QAE3F,OAAO;QACP,MAAM,WAAW,GAAG,IAAI,UAAU,CAAC,WAAW,CAAC;YAC7C,IAAI,EAAE,UAAU,CAAC,eAAe,CAAC,SAAS;YAC1C,OAAO,EAAE;gBACP,sBAAsB,EAAE,IAAI;gBAC5B,eAAe,EAAE,IAAI;aACtB;SACF,CAAC,CAAC;QAEH,OAAO;QACP,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,WAAW,CAAC,EAAE,uEAAuE,CAAC,CAAC;QACnI,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,+DAA+D,CAAC,IAAU;QACxE,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;QAC9B,MAAM,GAAG,GAAG,IAAI,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;QAEzE,OAAO;QACP,MAAM,WAAW,GAAG,IAAI,UAAU,CAAC,WAAW,CAAC;YAC7C,IAAI,EAAE,UAAU,CAAC,eAAe,CAAC,UAAU;YAC3C,qBAAqB,EAAE,KAAK;YAC5B,OAAO,EAAE;gBACP,cAAc,EAAE,oBAAc,CAAC,QAAQ;aACxC;SACF,CAAC,CAAC;QAEH,OAAO;QACP,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,WAAW,CAAC,EAAE,gEAAgE,CAAC,CAAC;QAC5H,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,+DAA+D,CAAC,IAAU;QACxE,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;QAC9B,MAAM,GAAG,GAAG,IAAI,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;QACzE,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QACtC,MAAM,GAAG,GAAG,IAAI,KAAK,CAAC,mBAAmB,CAAC,KAAK,EAAE,KAAK,EAAE;YACtD,GAAG;SACJ,CAAC,CAAC;QACH,MAAM,IAAI,GAAG,IAAI,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE;YACjD,OAAO,EAAE,CAAC,GAAG,CAAC;SACf,CAAC,CAAC;QAEH,OAAO;QACP,MAAM,WAAW,GAAG,IAAI,UAAU,CAAC,WAAW,CAAC;YAC7C,IAAI,EAAE,UAAU,CAAC,eAAe,CAAC,UAAU;YAC3C,qBAAqB,EAAE,KAAK;YAC5B,OAAO,EAAE;gBACP,cAAc,EAAE,oBAAc,CAAC,QAAQ;gBACvC,OAAO,EAAE,IAAI;aACd;SACF,CAAC,CAAC;QAEH,OAAO;QACP,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,WAAW,CAAC,EAAE,yDAAyD,CAAC,CAAC;QACrH,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,6DAA6D,CAAC,IAAU;QACtE,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;QAC9B,MAAM,GAAG,GAAG,IAAI,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;QAEzE,OAAO;QACP,IAAI,UAAU,CAAC,MAAM,CAAC,KAAK,EAAE,YAAY,EAAE;YACzC,UAAU,EAAE,KAAK;YACjB,QAAQ,EAAE,GAAG,CAAC,IAAI;YAClB,OAAO,EAAE;gBACP,eAAe,EAAE,CAAC;wBACd,UAAU,EAAE,KAAK;qBAClB,EAAE;wBACD,UAAU,EAAE,KAAK;wBACjB,kBAAkB,EAAE;4BAClB,mCAAmC,EAAE,KAAK;yBAC3C;qBACF,EAAE;wBACD,UAAU,EAAE,KAAK;wBACjB,kBAAkB,EAAE;4BAClB,iCAAiC,EAAE,IAAI;yBACxC;wBACD,cAAc,EAAE;4BACd,kBAAkB,EAAE,IAAI,gBAAU,EAAE;4BACpC,YAAY,EAAE,IAAI,gBAAU,EAAE;yBAC/B;qBACF;iBACF;aACF;SACF,CAAC,CAAC;QAEH,OAAO;QACP,eAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,qBAAY,CAAC,yBAAyB,EAAE;YACvD,UAAU,EAAE,KAAK;YACjB,eAAe,EAAE,CAAC;oBACd,UAAU,EAAE,KAAK;iBAClB,EAAE;oBACD,UAAU,EAAE,KAAK;oBACjB,kBAAkB,EAAE;wBAClB,mCAAmC,EAAE,KAAK;qBAC3C;iBACF,EAAE;oBACD,UAAU,EAAE,KAAK;oBACjB,kBAAkB,EAAE;wBAClB,iCAAiC,EAAE,IAAI;qBACxC;oBACD,cAAc,EAAE;wBACd,kBAAkB,EAAE,OAAO;wBAC3B,YAAY,EAAE,OAAO;qBACtB;iBACF;aACF;SACF,CAAC,CAAC,CAAC;QAEJ,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,4CAA4C,CAAC,IAAU;QACrD,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;QAC9B,MAAM,GAAG,GAAG,IAAI,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;QAEzE,OAAO;QACP,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,IAAI,UAAU,CAAC,cAAc,CAAC;YACtD,OAAO,EAAE,aAAa;YACtB,MAAM,EAAE,WAAW;YACnB,OAAO,EAAE;gBACP,oBAAoB,EAAE;oBACpB;wBACE,UAAU,EAAE,KAAK;wBACjB,iBAAiB,EAAE,EAAE,kBAAkB,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,EAAE;qBAC7E;oBACD;wBACE,gBAAgB,EAAE,SAAS;wBAC3B,UAAU,EAAE,KAAK;wBACjB,iBAAiB,EAAE,EAAE,kBAAkB,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,iBAAiB,EAAE,CAAC,EAAE;qBAC1G;iBACF;aACF;SACF,CAAC,CAAC,CAAC;QAEJ,OAAO;QACP,eAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,qBAAY,CAAC,yBAAyB,EAAE;YACvD,WAAW,EAAE;gBACX,qBAAqB,EAAE,MAAM;gBAC7B,oBAAoB,EAAE;oBACpB;wBACE,iBAAiB,EAAE,EAAE,kBAAkB,EAAE,kBAAkB,EAAE;wBAC7D,UAAU,EAAE,KAAK;qBAClB;oBACD;wBACE,iBAAiB,EAAE,EAAE,kBAAkB,EAAE,+CAA+C,EAAE;wBAC1F,gBAAgB,EAAE,SAAS;wBAC3B,UAAU,EAAE,KAAK;qBAClB;iBACF;gBACD,IAAI,EAAE,KAAK;gBACX,GAAG,EAAE,EAAE,UAAU,EAAE,CAAC,EAAE,EAAE,CAAC,MAAM,EAAE,EAAE,GAAG,EAAE,gBAAgB,EAAE,EAAE,cAAc,EAAE,EAAE,GAAG,EAAE,aAAa,EAAE,EAAE,+BAA+B,CAAC,CAAC,EAAC;aACvI;SACF,CAAC,CAAC,CAAC;QACJ,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,mCAAmC,CAAC,IAAU;QAC5C,QAAQ;QACR,MAAM,KAAK,GAAG,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;QAC9B,MAAM,GAAG,GAAG,IAAI,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAEjD,OAAO;QACP,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QAC1B,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QAC3B,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QAE1B,OAAO;QACP,eAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,qBAAY,CAAC,yBAAyB,EAAE,EAAE,UAAU,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC;QAClF,eAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,qBAAY,CAAC,yBAAyB,EAAE,EAAE,UAAU,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;QACjF,eAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,qBAAY,CAAC,yBAAyB,EAAE,EAAE,UAAU,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;QACjF,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;CACF,CAAC","sourcesContent":["import { expect, haveResource, haveResourceLike } from '@aws-cdk/assert';\nimport ec2 = require('@aws-cdk/aws-ec2');\nimport elbv2 = require('@aws-cdk/aws-elasticloadbalancingv2');\nimport iam = require('@aws-cdk/aws-iam');\nimport cdk = require('@aws-cdk/core');\nimport { Test } from 'nodeunit';\nimport apigateway = require('../lib');\nimport { ConnectionType, EmptyModel, ErrorModel } from '../lib';\n\nexport = {\n  'default setup'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api', { cloudWatchRole: false, deploy: false });\n\n    // WHEN\n    new apigateway.Method(stack, 'my-method', {\n      httpMethod: 'POST',\n      resource: api.root,\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', {\n      HttpMethod: \"POST\",\n      AuthorizationType: \"NONE\",\n      Integration: {\n        Type: \"MOCK\"\n      }\n    }));\n\n    test.done();\n  },\n\n  'method options can be specified'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api', { cloudWatchRole: false, deploy: false });\n\n    // WHEN\n    new apigateway.Method(stack, 'my-method', {\n      httpMethod: 'POST',\n      resource: api.root,\n      options: {\n        apiKeyRequired: true,\n        operationName: 'MyOperation',\n      }\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', {\n      ApiKeyRequired: true,\n      OperationName: \"MyOperation\"\n    }));\n\n    test.done();\n  },\n\n  'integration can be set via a property'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api', { cloudWatchRole: false, deploy: false });\n\n    // WHEN\n    new apigateway.Method(stack, 'my-method', {\n      httpMethod: 'POST',\n      resource: api.root,\n      integration: new apigateway.AwsIntegration({ service: 's3', path: 'bucket/key' })\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', {\n      Integration: {\n        IntegrationHttpMethod: \"POST\",\n        Type: \"AWS\",\n        Uri: {\n          \"Fn::Join\": [\n          \"\",\n          [\n            \"arn:\", { Ref: \"AWS::Partition\" }, \":apigateway:\",\n            { Ref: \"AWS::Region\" }, \":s3:path/bucket/key\"\n          ]\n          ]\n        }\n      }\n    }));\n\n    test.done();\n  },\n\n  'integration with a custom http method can be set via a property'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api', { cloudWatchRole: false, deploy: false });\n\n    // WHEN\n    new apigateway.Method(stack, 'my-method', {\n      httpMethod: 'POST',\n      resource: api.root,\n      integration: new apigateway.AwsIntegration({ service: 's3', path: 'bucket/key', integrationHttpMethod: 'GET' })\n    });\n\n    // THEN\n    expect(stack).to(haveResourceLike('AWS::ApiGateway::Method', {\n      Integration: {\n        IntegrationHttpMethod: \"GET\"\n      }\n    }));\n\n    test.done();\n  },\n\n  'use default integration from api'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const defaultIntegration = new apigateway.Integration({ type: apigateway.IntegrationType.HTTP_PROXY, uri: 'https://amazon.com' });\n    const api = new apigateway.RestApi(stack, 'test-api', {\n      cloudWatchRole: false,\n      deploy: false,\n      defaultIntegration\n    });\n\n    // WHEN\n    new apigateway.Method(stack, 'my-method', {\n      httpMethod: 'POST',\n      resource: api.root,\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', {\n      Integration: {\n        Type: \"HTTP_PROXY\",\n        Uri: 'https://amazon.com'\n      }\n    }));\n\n    test.done();\n  },\n\n  '\"methodArn\" returns the ARN execute-api ARN for this method in the current stage'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api');\n\n    // WHEN\n    const method = new apigateway.Method(stack, 'my-method', {\n      httpMethod: 'POST',\n      resource: api.root,\n    });\n\n    // THEN\n    test.deepEqual(stack.resolve(method.methodArn), {\n      \"Fn::Join\": [\n        \"\",\n        [\n        \"arn:\",\n        { Ref: \"AWS::Partition\" },\n        \":execute-api:\",\n        { Ref: \"AWS::Region\" },\n        \":\",\n        { Ref: \"AWS::AccountId\" },\n        \":\",\n        { Ref: \"testapiD6451F70\" },\n        \"/\",\n        { Ref: \"testapiDeploymentStageprod5C9E92A4\" },\n        \"/POST/\"\n        ]\n      ]\n    });\n\n    test.done();\n  },\n\n  '\"testMethodArn\" returns the ARN of the \"test-invoke-stage\" stage (console UI)'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api');\n\n    // WHEN\n    const method = new apigateway.Method(stack, 'my-method', {\n      httpMethod: 'POST',\n      resource: api.root,\n    });\n\n    // THEN\n    test.deepEqual(stack.resolve(method.testMethodArn), {\n      \"Fn::Join\": [\n        \"\",\n        [\n        \"arn:\",\n        { Ref: \"AWS::Partition\" },\n        \":execute-api:\",\n        { Ref: \"AWS::Region\" },\n        \":\",\n        { Ref: \"AWS::AccountId\" },\n        \":\",\n        { Ref: \"testapiD6451F70\" },\n        \"/test-invoke-stage/POST/\"\n        ]\n      ]\n    });\n\n    test.done();\n  },\n\n  '\"methodArn\" fails if the API does not have a deployment stage'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api', { deploy: false });\n    const method = new apigateway.Method(stack, 'my-method', { httpMethod: 'POST', resource: api.root });\n\n    // WHEN + THEN\n    test.throws(() => method.methodArn,\n      /Unable to determine ARN for method \"my-method\" since there is no stage associated with this API./);\n\n    test.done();\n  },\n\n  'integration \"credentialsRole\" can be used to assume a role when calling backend'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api', { deploy: false });\n    const role = new iam.Role(stack, 'MyRole', { assumedBy: new iam.ServicePrincipal('foo') });\n\n    // WHEN\n    api.root.addMethod('GET', new apigateway.Integration({\n      type: apigateway.IntegrationType.AWS_PROXY,\n      options: {\n        credentialsRole: role\n      }\n    }));\n\n    // THEN\n    expect(stack).to(haveResourceLike('AWS::ApiGateway::Method', {\n      Integration: {\n        Credentials: { \"Fn::GetAtt\": [ \"MyRoleF48FFE04\", \"Arn\" ] }\n      }\n    }));\n    test.done();\n  },\n\n  'integration \"credentialsPassthrough\" can be used to passthrough user credentials to backend'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api', { deploy: false });\n\n    // WHEN\n    api.root.addMethod('GET', new apigateway.Integration({\n      type: apigateway.IntegrationType.AWS_PROXY,\n      options: {\n        credentialsPassthrough: true\n      }\n    }));\n\n    // THEN\n    expect(stack).to(haveResourceLike('AWS::ApiGateway::Method', {\n      Integration: {\n        Credentials: { \"Fn::Join\": [ \"\", [ \"arn:\", { Ref: \"AWS::Partition\" }, \":iam::*:user/*\" ] ] }\n      }\n    }));\n    test.done();\n  },\n\n  'integration \"credentialsRole\" and \"credentialsPassthrough\" are mutually exclusive'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api', { deploy: false });\n    const role = new iam.Role(stack, 'MyRole', { assumedBy: new iam.ServicePrincipal('foo') });\n\n    // WHEN\n    const integration = new apigateway.Integration({\n      type: apigateway.IntegrationType.AWS_PROXY,\n      options: {\n        credentialsPassthrough: true,\n        credentialsRole: role\n      }\n    });\n\n    // THEN\n    test.throws(() => api.root.addMethod('GET', integration), /'credentialsPassthrough' and 'credentialsRole' are mutually exclusive/);\n    test.done();\n  },\n\n  'integration connectionType VpcLink requires vpcLink to be set'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api', { deploy: false });\n\n    // WHEN\n    const integration = new apigateway.Integration({\n      type: apigateway.IntegrationType.HTTP_PROXY,\n      integrationHttpMethod: 'ANY',\n      options: {\n        connectionType: ConnectionType.VPC_LINK,\n      }\n    });\n\n    // THEN\n    test.throws(() => api.root.addMethod('GET', integration), /'connectionType' of VPC_LINK requires 'vpcLink' prop to be set/);\n    test.done();\n  },\n\n  'connectionType of INTERNET and vpcLink are mutually exclusive'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api', { deploy: false });\n    const vpc = new ec2.Vpc(stack, 'VPC');\n    const nlb = new elbv2.NetworkLoadBalancer(stack, 'NLB', {\n      vpc\n    });\n    const link = new apigateway.VpcLink(stack, 'link', {\n      targets: [nlb]\n    });\n\n    // WHEN\n    const integration = new apigateway.Integration({\n      type: apigateway.IntegrationType.HTTP_PROXY,\n      integrationHttpMethod: 'ANY',\n      options: {\n        connectionType: ConnectionType.INTERNET,\n        vpcLink: link\n      }\n    });\n\n    // THEN\n    test.throws(() => api.root.addMethod('GET', integration), /cannot set 'vpcLink' where 'connectionType' is INTERNET/);\n    test.done();\n  },\n\n  'methodResponse set one or more method responses via options'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api', { deploy: false });\n\n    // WHEN\n    new apigateway.Method(stack, 'method-man', {\n      httpMethod: 'GET',\n      resource: api.root,\n      options: {\n        methodResponses: [{\n            statusCode: '200'\n          }, {\n            statusCode: \"400\",\n            responseParameters: {\n              'method.response.header.killerbees': false\n            }\n          }, {\n            statusCode: \"500\",\n            responseParameters: {\n              'method.response.header.errthing': true\n            },\n            responseModels: {\n              'application/json': new EmptyModel(),\n              'text/plain': new ErrorModel()\n            }\n          }\n        ]\n      }\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', {\n      HttpMethod: 'GET',\n      MethodResponses: [{\n          StatusCode: \"200\"\n        }, {\n          StatusCode: \"400\",\n          ResponseParameters: {\n            'method.response.header.killerbees': false\n          }\n        }, {\n          StatusCode: \"500\",\n          ResponseParameters: {\n            'method.response.header.errthing': true\n          },\n          ResponseModels: {\n            'application/json': 'Empty',\n            'text/plain': 'Error'\n          }\n        }\n      ]\n    }));\n\n    test.done();\n  },\n\n  'multiple integration responses can be used'(test: Test) { // @see https://github.com/awslabs/aws-cdk/issues/1608\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api', { deploy: false });\n\n    // WHEN\n    api.root.addMethod('GET', new apigateway.AwsIntegration({\n      service: 'foo-service',\n      action: 'BarAction',\n      options: {\n        integrationResponses: [\n          {\n            statusCode: '200',\n            responseTemplates: { 'application/json': JSON.stringify({ success: true }) },\n          },\n          {\n            selectionPattern: 'Invalid',\n            statusCode: '503',\n            responseTemplates: { 'application/json': JSON.stringify({ success: false, message: 'Invalid Request' }) },\n          }\n        ],\n      }\n    }));\n\n    // THEN\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', {\n      Integration: {\n        IntegrationHttpMethod: 'POST',\n        IntegrationResponses: [\n          {\n            ResponseTemplates: { 'application/json': '{\"success\":true}' },\n            StatusCode: '200',\n          },\n          {\n            ResponseTemplates: { 'application/json': '{\"success\":false,\"message\":\"Invalid Request\"}' },\n            SelectionPattern: 'Invalid',\n            StatusCode: '503',\n          }\n        ],\n        Type: 'AWS',\n        Uri: { 'Fn::Join': ['', ['arn:', { Ref: 'AWS::Partition' }, ':apigateway:', { Ref: 'AWS::Region' }, ':foo-service:action/BarAction']]}\n      }\n    }));\n    test.done();\n  },\n\n  'method is always set as uppercase'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'api');\n\n    // WHEN\n    api.root.addMethod('get');\n    api.root.addMethod('PoSt');\n    api.root.addMethod('PUT');\n\n    // THEN\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', { HttpMethod: \"POST\" }));\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', { HttpMethod: \"GET\" }));\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', { HttpMethod: \"PUT\" }));\n    test.done();\n  }\n};\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.method.js","sourceRoot":"","sources":["test.method.ts"],"names":[],"mappings":"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","sourcesContent":["import { expect, haveResource, haveResourceLike } from '@aws-cdk/assert';\nimport ec2 = require('@aws-cdk/aws-ec2');\nimport elbv2 = require('@aws-cdk/aws-elasticloadbalancingv2');\nimport iam = require('@aws-cdk/aws-iam');\nimport cdk = require('@aws-cdk/core');\nimport { Test } from 'nodeunit';\nimport apigateway = require('../lib');\nimport { ConnectionType, JsonSchemaType, JsonSchemaVersion } from '../lib';\n\nexport = {\n  'default setup'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api', { cloudWatchRole: false, deploy: false });\n\n    // WHEN\n    new apigateway.Method(stack, 'my-method', {\n      httpMethod: 'POST',\n      resource: api.root,\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', {\n      HttpMethod: \"POST\",\n      AuthorizationType: \"NONE\",\n      Integration: {\n        Type: \"MOCK\"\n      }\n    }));\n\n    test.done();\n  },\n\n  'method options can be specified'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api', { cloudWatchRole: false, deploy: false });\n\n    // WHEN\n    new apigateway.Method(stack, 'my-method', {\n      httpMethod: 'POST',\n      resource: api.root,\n      options: {\n        apiKeyRequired: true,\n        operationName: 'MyOperation',\n      }\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', {\n      ApiKeyRequired: true,\n      OperationName: \"MyOperation\"\n    }));\n\n    test.done();\n  },\n\n  'integration can be set via a property'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api', { cloudWatchRole: false, deploy: false });\n\n    // WHEN\n    new apigateway.Method(stack, 'my-method', {\n      httpMethod: 'POST',\n      resource: api.root,\n      integration: new apigateway.AwsIntegration({ service: 's3', path: 'bucket/key' })\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', {\n      Integration: {\n        IntegrationHttpMethod: \"POST\",\n        Type: \"AWS\",\n        Uri: {\n          \"Fn::Join\": [\n          \"\",\n          [\n            \"arn:\", { Ref: \"AWS::Partition\" }, \":apigateway:\",\n            { Ref: \"AWS::Region\" }, \":s3:path/bucket/key\"\n          ]\n          ]\n        }\n      }\n    }));\n\n    test.done();\n  },\n\n  'integration with a custom http method can be set via a property'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api', { cloudWatchRole: false, deploy: false });\n\n    // WHEN\n    new apigateway.Method(stack, 'my-method', {\n      httpMethod: 'POST',\n      resource: api.root,\n      integration: new apigateway.AwsIntegration({ service: 's3', path: 'bucket/key', integrationHttpMethod: 'GET' })\n    });\n\n    // THEN\n    expect(stack).to(haveResourceLike('AWS::ApiGateway::Method', {\n      Integration: {\n        IntegrationHttpMethod: \"GET\"\n      }\n    }));\n\n    test.done();\n  },\n\n  'use default integration from api'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const defaultIntegration = new apigateway.Integration({ type: apigateway.IntegrationType.HTTP_PROXY, uri: 'https://amazon.com' });\n    const api = new apigateway.RestApi(stack, 'test-api', {\n      cloudWatchRole: false,\n      deploy: false,\n      defaultIntegration\n    });\n\n    // WHEN\n    new apigateway.Method(stack, 'my-method', {\n      httpMethod: 'POST',\n      resource: api.root,\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', {\n      Integration: {\n        Type: \"HTTP_PROXY\",\n        Uri: 'https://amazon.com'\n      }\n    }));\n\n    test.done();\n  },\n\n  '\"methodArn\" returns the ARN execute-api ARN for this method in the current stage'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api');\n\n    // WHEN\n    const method = new apigateway.Method(stack, 'my-method', {\n      httpMethod: 'POST',\n      resource: api.root,\n    });\n\n    // THEN\n    test.deepEqual(stack.resolve(method.methodArn), {\n      \"Fn::Join\": [\n        \"\",\n        [\n        \"arn:\",\n        { Ref: \"AWS::Partition\" },\n        \":execute-api:\",\n        { Ref: \"AWS::Region\" },\n        \":\",\n        { Ref: \"AWS::AccountId\" },\n        \":\",\n        { Ref: \"testapiD6451F70\" },\n        \"/\",\n        { Ref: \"testapiDeploymentStageprod5C9E92A4\" },\n        \"/POST/\"\n        ]\n      ]\n    });\n\n    test.done();\n  },\n\n  '\"testMethodArn\" returns the ARN of the \"test-invoke-stage\" stage (console UI)'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api');\n\n    // WHEN\n    const method = new apigateway.Method(stack, 'my-method', {\n      httpMethod: 'POST',\n      resource: api.root,\n    });\n\n    // THEN\n    test.deepEqual(stack.resolve(method.testMethodArn), {\n      \"Fn::Join\": [\n        \"\",\n        [\n        \"arn:\",\n        { Ref: \"AWS::Partition\" },\n        \":execute-api:\",\n        { Ref: \"AWS::Region\" },\n        \":\",\n        { Ref: \"AWS::AccountId\" },\n        \":\",\n        { Ref: \"testapiD6451F70\" },\n        \"/test-invoke-stage/POST/\"\n        ]\n      ]\n    });\n\n    test.done();\n  },\n\n  '\"methodArn\" fails if the API does not have a deployment stage'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api', { deploy: false });\n    const method = new apigateway.Method(stack, 'my-method', { httpMethod: 'POST', resource: api.root });\n\n    // WHEN + THEN\n    test.throws(() => method.methodArn,\n      /Unable to determine ARN for method \"my-method\" since there is no stage associated with this API./);\n\n    test.done();\n  },\n\n  'integration \"credentialsRole\" can be used to assume a role when calling backend'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api', { deploy: false });\n    const role = new iam.Role(stack, 'MyRole', { assumedBy: new iam.ServicePrincipal('foo') });\n\n    // WHEN\n    api.root.addMethod('GET', new apigateway.Integration({\n      type: apigateway.IntegrationType.AWS_PROXY,\n      options: {\n        credentialsRole: role\n      }\n    }));\n\n    // THEN\n    expect(stack).to(haveResourceLike('AWS::ApiGateway::Method', {\n      Integration: {\n        Credentials: { \"Fn::GetAtt\": [ \"MyRoleF48FFE04\", \"Arn\" ] }\n      }\n    }));\n    test.done();\n  },\n\n  'integration \"credentialsPassthrough\" can be used to passthrough user credentials to backend'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api', { deploy: false });\n\n    // WHEN\n    api.root.addMethod('GET', new apigateway.Integration({\n      type: apigateway.IntegrationType.AWS_PROXY,\n      options: {\n        credentialsPassthrough: true\n      }\n    }));\n\n    // THEN\n    expect(stack).to(haveResourceLike('AWS::ApiGateway::Method', {\n      Integration: {\n        Credentials: { \"Fn::Join\": [ \"\", [ \"arn:\", { Ref: \"AWS::Partition\" }, \":iam::*:user/*\" ] ] }\n      }\n    }));\n    test.done();\n  },\n\n  'integration \"credentialsRole\" and \"credentialsPassthrough\" are mutually exclusive'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api', { deploy: false });\n    const role = new iam.Role(stack, 'MyRole', { assumedBy: new iam.ServicePrincipal('foo') });\n\n    // WHEN\n    const integration = new apigateway.Integration({\n      type: apigateway.IntegrationType.AWS_PROXY,\n      options: {\n        credentialsPassthrough: true,\n        credentialsRole: role\n      }\n    });\n\n    // THEN\n    test.throws(() => api.root.addMethod('GET', integration), /'credentialsPassthrough' and 'credentialsRole' are mutually exclusive/);\n    test.done();\n  },\n\n  'integration connectionType VpcLink requires vpcLink to be set'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api', { deploy: false });\n\n    // WHEN\n    const integration = new apigateway.Integration({\n      type: apigateway.IntegrationType.HTTP_PROXY,\n      integrationHttpMethod: 'ANY',\n      options: {\n        connectionType: ConnectionType.VPC_LINK,\n      }\n    });\n\n    // THEN\n    test.throws(() => api.root.addMethod('GET', integration), /'connectionType' of VPC_LINK requires 'vpcLink' prop to be set/);\n    test.done();\n  },\n\n  'connectionType of INTERNET and vpcLink are mutually exclusive'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api', { deploy: false });\n    const vpc = new ec2.Vpc(stack, 'VPC');\n    const nlb = new elbv2.NetworkLoadBalancer(stack, 'NLB', {\n      vpc\n    });\n    const link = new apigateway.VpcLink(stack, 'link', {\n      targets: [nlb]\n    });\n\n    // WHEN\n    const integration = new apigateway.Integration({\n      type: apigateway.IntegrationType.HTTP_PROXY,\n      integrationHttpMethod: 'ANY',\n      options: {\n        connectionType: ConnectionType.INTERNET,\n        vpcLink: link\n      }\n    });\n\n    // THEN\n    test.throws(() => api.root.addMethod('GET', integration), /cannot set 'vpcLink' where 'connectionType' is INTERNET/);\n    test.done();\n  },\n\n  'methodResponse set one or more method responses via options'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api', { deploy: false });\n\n    // WHEN\n    new apigateway.Method(stack, 'method-man', {\n      httpMethod: 'GET',\n      resource: api.root,\n      options: {\n        methodResponses: [{\n            statusCode: '200'\n          }, {\n            statusCode: \"400\",\n            responseParameters: {\n              'method.response.header.killerbees': false\n            }\n          }, {\n            statusCode: \"500\",\n            responseParameters: {\n              'method.response.header.errthing': true\n            },\n            responseModels: {\n              'application/json': apigateway.Model.EMPTY_MODEL,\n              'text/plain': apigateway.Model.ERROR_MODEL\n            }\n          }\n        ]\n      }\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', {\n      HttpMethod: 'GET',\n      MethodResponses: [{\n          StatusCode: \"200\"\n        }, {\n          StatusCode: \"400\",\n          ResponseParameters: {\n            'method.response.header.killerbees': false\n          }\n        }, {\n          StatusCode: \"500\",\n          ResponseParameters: {\n            'method.response.header.errthing': true\n          },\n          ResponseModels: {\n            'application/json': 'Empty',\n            'text/plain': 'Error'\n          }\n        }\n      ]\n    }));\n\n    test.done();\n  },\n\n  'multiple integration responses can be used'(test: Test) { // @see https://github.com/awslabs/aws-cdk/issues/1608\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api', { deploy: false });\n\n    // WHEN\n    api.root.addMethod('GET', new apigateway.AwsIntegration({\n      service: 'foo-service',\n      action: 'BarAction',\n      options: {\n        integrationResponses: [\n          {\n            statusCode: '200',\n            responseTemplates: { 'application/json': JSON.stringify({ success: true }) },\n          },\n          {\n            selectionPattern: 'Invalid',\n            statusCode: '503',\n            responseTemplates: { 'application/json': JSON.stringify({ success: false, message: 'Invalid Request' }) },\n          }\n        ],\n      }\n    }));\n\n    // THEN\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', {\n      Integration: {\n        IntegrationHttpMethod: 'POST',\n        IntegrationResponses: [\n          {\n            ResponseTemplates: { 'application/json': '{\"success\":true}' },\n            StatusCode: '200',\n          },\n          {\n            ResponseTemplates: { 'application/json': '{\"success\":false,\"message\":\"Invalid Request\"}' },\n            SelectionPattern: 'Invalid',\n            StatusCode: '503',\n          }\n        ],\n        Type: 'AWS',\n        Uri: { 'Fn::Join': ['', ['arn:', { Ref: 'AWS::Partition' }, ':apigateway:', { Ref: 'AWS::Region' }, ':foo-service:action/BarAction']]}\n      }\n    }));\n    test.done();\n  },\n\n  'method is always set as uppercase'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'api');\n\n    // WHEN\n    api.root.addMethod('get');\n    api.root.addMethod('PoSt');\n    api.root.addMethod('PUT');\n\n    // THEN\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', { HttpMethod: \"POST\" }));\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', { HttpMethod: \"GET\" }));\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', { HttpMethod: \"PUT\" }));\n    test.done();\n  },\n\n  'requestModel can be set'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api', { deploy: false });\n    const model = api.addModel('test-model', {\n      contentType: \"application/json\",\n      modelName: 'test-model',\n      schema: {\n        title: \"test\",\n        type: JsonSchemaType.OBJECT,\n        properties: { message: { type: JsonSchemaType.STRING } }\n      }\n    });\n\n    // WHEN\n    new apigateway.Method(stack, 'method-man', {\n      httpMethod: 'GET',\n      resource: api.root,\n      options: {\n        requestModels: {\n          \"application/json\": model\n        }\n      }\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', {\n      HttpMethod: 'GET',\n      RequestModels: {\n        \"application/json\": { Ref: stack.getLogicalId(model.node.findChild('Resource') as cdk.CfnElement) }\n      }\n    }));\n\n    test.done();\n  },\n\n  'methodResponse has a mix of response modes'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api', { deploy: false });\n    const htmlModel = api.addModel('my-model', {\n      schema: {\n        schema: JsonSchemaVersion.DRAFT4,\n        title: \"test\",\n        type: JsonSchemaType.OBJECT,\n        properties: { message: { type: JsonSchemaType.STRING } }\n      }\n    });\n\n    // WHEN\n    new apigateway.Method(stack, 'method-man', {\n      httpMethod: 'GET',\n      resource: api.root,\n      options: {\n        methodResponses: [{\n            statusCode: '200'\n          }, {\n            statusCode: \"400\",\n            responseParameters: {\n              'method.response.header.killerbees': false\n            }\n          }, {\n            statusCode: \"500\",\n            responseParameters: {\n              'method.response.header.errthing': true\n            },\n            responseModels: {\n              'application/json': apigateway.Model.EMPTY_MODEL,\n              'text/plain': apigateway.Model.ERROR_MODEL,\n              'text/html': htmlModel\n            }\n          }\n        ]\n      }\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', {\n      HttpMethod: 'GET',\n      MethodResponses: [{\n          StatusCode: \"200\"\n        }, {\n          StatusCode: \"400\",\n          ResponseParameters: {\n            'method.response.header.killerbees': false\n          }\n        }, {\n          StatusCode: \"500\",\n          ResponseParameters: {\n            'method.response.header.errthing': true\n          },\n          ResponseModels: {\n            'application/json': 'Empty',\n            'text/plain': 'Error',\n            'text/html': { Ref: stack.getLogicalId(htmlModel.node.findChild('Resource') as cdk.CfnElement) }\n          }\n        }\n      ]\n    }));\n\n    test.done();\n  },\n\n  'method has a request validator'(test: Test) {\n    // GIVEN\n    const stack = new cdk.Stack();\n    const api = new apigateway.RestApi(stack, 'test-api', { deploy: false });\n    const validator = api.addRequestValidator('validator', {\n      validateRequestBody: true,\n      validateRequestParameters: false\n    });\n\n    // WHEN\n    new apigateway.Method(stack, 'method-man', {\n      httpMethod: 'GET',\n      resource: api.root,\n      options: {\n        requestValidator: validator\n      }\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::ApiGateway::Method', {\n      RequestValidatorId: { Ref: stack.getLogicalId(validator.node.findChild('Resource') as cdk.CfnElement) }\n    }));\n    expect(stack).to(haveResource('AWS::ApiGateway::RequestValidator', {\n      RestApiId: { Ref: stack.getLogicalId(api.node.findChild('Resource') as cdk.CfnElement) },\n      ValidateRequestBody: true,\n      ValidateRequestParameters: false\n    }));\n\n    test.done();\n  }\n};\n"]}
import { Test } from 'nodeunit';
declare const _default: {
'minimal setup'(test: Test): void;
'"name" is defaulted to construct id'(test: Test): void;
'"name" is defaulted to resource physical name'(test: Test): void;
'fails in synthesis if there are no methods'(test: Test): void;

@@ -24,3 +24,5 @@ '"addResource" can be used on "IRestApiResource" to form a tree'(test: Test): void;

'defaultIntegration and defaultMethodOptions can be used at any level'(test: Test): void;
'addModel is supported'(test: Test): void;
'addRequestValidator is supported'(test: Test): void;
};
export = _default;

@@ -38,2 +38,5 @@ {

{
"path": "../aws-certificatemanager"
},
{
"path": "../aws-elasticloadbalancingv2"

@@ -40,0 +43,0 @@ },

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is too big to display

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc