1 | ;
|
2 | var _a, _b, _c;
|
3 | Object.defineProperty(exports, "__esModule", { value: true });
|
4 | exports.Model = exports.ErrorModel = exports.EmptyModel = void 0;
|
5 | const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
|
6 | const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
7 | const core_1 = require("@aws-cdk/core");
|
8 | const apigateway_generated_1 = require("./apigateway.generated");
|
9 | const restapi_1 = require("./restapi");
|
10 | const util = require("./util");
|
11 | /**
|
12 | * Represents a reference to a REST API's Empty model, which is available
|
13 | * as part of the model collection by default. This can be used for mapping
|
14 | * JSON responses from an integration to what is returned to a client,
|
15 | * where strong typing is not required. In the absence of any defined
|
16 | * model, the Empty model will be used to return the response payload
|
17 | * unmapped.
|
18 | *
|
19 | * Definition
|
20 | * {
|
21 | * "$schema" : "http://json-schema.org/draft-04/schema#",
|
22 | * "title" : "Empty Schema",
|
23 | * "type" : "object"
|
24 | * }
|
25 | *
|
26 | * @see https://docs.amazonaws.cn/en_us/apigateway/latest/developerguide/models-mappings.html#models-mappings-models
|
27 | * @deprecated You should use Model.EMPTY_MODEL
|
28 | */
|
29 | class EmptyModel {
|
30 | constructor() {
|
31 | this.modelId = 'Empty';
|
32 | }
|
33 | }
|
34 | exports.EmptyModel = EmptyModel;
|
35 | _a = JSII_RTTI_SYMBOL_1;
|
36 | EmptyModel[_a] = { fqn: "@aws-cdk/aws-apigateway.EmptyModel", version: "1.173.0" };
|
37 | /**
|
38 | * Represents a reference to a REST API's Error model, which is available
|
39 | * as part of the model collection by default. This can be used for mapping
|
40 | * error JSON responses from an integration to a client, where a simple
|
41 | * generic message field is sufficient to map and return an error payload.
|
42 | *
|
43 | * Definition
|
44 | * {
|
45 | * "$schema" : "http://json-schema.org/draft-04/schema#",
|
46 | * "title" : "Error Schema",
|
47 | * "type" : "object",
|
48 | * "properties" : {
|
49 | * "message" : { "type" : "string" }
|
50 | * }
|
51 | * }
|
52 | * @deprecated You should use Model.ERROR_MODEL
|
53 | */
|
54 | class ErrorModel {
|
55 | constructor() {
|
56 | this.modelId = 'Error';
|
57 | }
|
58 | }
|
59 | exports.ErrorModel = ErrorModel;
|
60 | _b = JSII_RTTI_SYMBOL_1;
|
61 | ErrorModel[_b] = { fqn: "@aws-cdk/aws-apigateway.ErrorModel", version: "1.173.0" };
|
62 | class Model extends core_1.Resource {
|
63 | constructor(scope, id, props) {
|
64 | super(scope, id, {
|
65 | physicalName: props.modelName,
|
66 | });
|
67 | try {
|
68 | jsiiDeprecationWarnings._aws_cdk_aws_apigateway_ModelProps(props);
|
69 | }
|
70 | catch (error) {
|
71 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
72 | Error.captureStackTrace(error, Model);
|
73 | }
|
74 | throw error;
|
75 | }
|
76 | const modelProps = {
|
77 | name: this.physicalName,
|
78 | restApiId: props.restApi.restApiId,
|
79 | contentType: props.contentType ?? 'application/json',
|
80 | description: props.description,
|
81 | schema: util.JsonSchemaMapper.toCfnJsonSchema(props.schema),
|
82 | };
|
83 | const resource = new apigateway_generated_1.CfnModel(this, 'Resource', modelProps);
|
84 | this.modelId = this.getResourceNameAttribute(resource.ref);
|
85 | const deployment = (props.restApi instanceof restapi_1.RestApi) ? props.restApi.latestDeployment : undefined;
|
86 | if (deployment) {
|
87 | deployment.node.addDependency(resource);
|
88 | deployment.addToLogicalId({ model: modelProps });
|
89 | }
|
90 | }
|
91 | static fromModelName(scope, id, modelName) {
|
92 | class Import extends core_1.Resource {
|
93 | constructor() {
|
94 | super(...arguments);
|
95 | this.modelId = modelName;
|
96 | }
|
97 | }
|
98 | return new Import(scope, id);
|
99 | }
|
100 | }
|
101 | exports.Model = Model;
|
102 | _c = JSII_RTTI_SYMBOL_1;
|
103 | Model[_c] = { fqn: "@aws-cdk/aws-apigateway.Model", version: "1.173.0" };
|
104 | /**
|
105 | * Represents a reference to a REST API's Error model, which is available
|
106 | * as part of the model collection by default. This can be used for mapping
|
107 | * error JSON responses from an integration to a client, where a simple
|
108 | * generic message field is sufficient to map and return an error payload.
|
109 | *
|
110 | * Definition
|
111 | * {
|
112 | * "$schema" : "http://json-schema.org/draft-04/schema#",
|
113 | * "title" : "Error Schema",
|
114 | * "type" : "object",
|
115 | * "properties" : {
|
116 | * "message" : { "type" : "string" }
|
117 | * }
|
118 | * }
|
119 | */
|
120 | Model.ERROR_MODEL = new ErrorModel();
|
121 | /**
|
122 | * Represents a reference to a REST API's Empty model, which is available
|
123 | * as part of the model collection by default. This can be used for mapping
|
124 | * JSON responses from an integration to what is returned to a client,
|
125 | * where strong typing is not required. In the absence of any defined
|
126 | * model, the Empty model will be used to return the response payload
|
127 | * unmapped.
|
128 | *
|
129 | * Definition
|
130 | * {
|
131 | * "$schema" : "http://json-schema.org/draft-04/schema#",
|
132 | * "title" : "Empty Schema",
|
133 | * "type" : "object"
|
134 | * }
|
135 | *
|
136 | * @see https://docs.amazonaws.cn/en_us/apigateway/latest/developerguide/models-mappings.html#models-mappings-models
|
137 | */
|
138 | Model.EMPTY_MODEL = new EmptyModel();
|
139 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"model.js","sourceRoot":"","sources":["model.ts"],"names":[],"mappings":";;;;;;AAAA,wCAAyC;AAEzC,iEAAiE;AAEjE,uCAA8C;AAC9C,+BAA+B;AAW/B;;;;;;;;;;;;;;;;;GAiBG;AACH,MAAa,UAAU;IAAvB;QACkB,YAAO,GAAG,OAAO,CAAC;KACnC;;AAFD,gCAEC;;;AAED;;;;;;;;;;;;;;;;GAgBG;AACH,MAAa,UAAU;IAAvB;QACkB,YAAO,GAAG,OAAO,CAAC;KACnC;;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;;;;;;+CAxDM,KAAK;;;;QA0Dd,MAAM,UAAU,GAAkB;YAChC,IAAI,EAAE,IAAI,CAAC,YAAY;YACvB,SAAS,EAAE,KAAK,CAAC,OAAO,CAAC,SAAS;YAClC,WAAW,EAAE,KAAK,CAAC,WAAW,IAAI,kBAAkB;YACpD,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;KACF;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;KAC9B;;AA5CH,sBA4EC;;;AA3EC;;;;;;;;;;;;;;;GAeG;AACoB,iBAAW,GAAW,IAAI,UAAU,EAAE,CAAC;AAE9D;;;;;;;;;;;;;;;;GAgBG;AACoB,iBAAW,GAAW,IAAI,UAAU,EAAE,CAAC","sourcesContent":["import { Resource } from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { CfnModel, CfnModelProps } from './apigateway.generated';\nimport * as jsonSchema from './json-schema';\nimport { IRestApi, RestApi } from './restapi';\nimport * as util from './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 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 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 'application/json'\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 ?? 'application/json',\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}\n"]} |
\ | No newline at end of file |