1 | ;
|
2 | var _a, _b, _c;
|
3 | Object.defineProperty(exports, "__esModule", { value: true });
|
4 | exports.AccessLogFormat = exports.AccessLogField = exports.LogGroupLogDestination = void 0;
|
5 | const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
|
6 | const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
7 | /**
|
8 | * Use CloudWatch Logs as a custom access log destination for API Gateway.
|
9 | */
|
10 | class LogGroupLogDestination {
|
11 | constructor(logGroup) {
|
12 | this.logGroup = logGroup;
|
13 | }
|
14 | /**
|
15 | * Binds this destination to the CloudWatch Logs.
|
16 | */
|
17 | bind(_stage) {
|
18 | try {
|
19 | jsiiDeprecationWarnings._aws_cdk_aws_apigateway_IStage(_stage);
|
20 | }
|
21 | catch (error) {
|
22 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
23 | Error.captureStackTrace(error, this.bind);
|
24 | }
|
25 | throw error;
|
26 | }
|
27 | return {
|
28 | destinationArn: this.logGroup.logGroupArn,
|
29 | };
|
30 | }
|
31 | }
|
32 | exports.LogGroupLogDestination = LogGroupLogDestination;
|
33 | _a = JSII_RTTI_SYMBOL_1;
|
34 | LogGroupLogDestination[_a] = { fqn: "@aws-cdk/aws-apigateway.LogGroupLogDestination", version: "1.173.0" };
|
35 | /**
|
36 | * $context variables that can be used to customize access log pattern.
|
37 | */
|
38 | class AccessLogField {
|
39 | /**
|
40 | * The API owner's AWS account ID.
|
41 | */
|
42 | static contextAccountId() {
|
43 | return '$context.identity.accountId';
|
44 | }
|
45 | /**
|
46 | * The identifier API Gateway assigns to your API.
|
47 | */
|
48 | static contextApiId() {
|
49 | return '$context.apiId';
|
50 | }
|
51 | /**
|
52 | * A property of the claims returned from the Amazon Cognito user pool after the method caller is successfully authenticated.
|
53 | * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-integrate-with-cognito.html
|
54 | *
|
55 | * @param property A property key of the claims.
|
56 | */
|
57 | static contextAuthorizerClaims(property) {
|
58 | return `$context.authorizer.claims.${property}`;
|
59 | }
|
60 | /**
|
61 | * The principal user identification associated with the token sent by the client and returned
|
62 | * from an API Gateway Lambda authorizer (formerly known as a custom authorizer).
|
63 | * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-use-lambda-authorizer.html
|
64 | */
|
65 | static contextAuthorizerPrincipalId() {
|
66 | return '$context.authorizer.principalId';
|
67 | }
|
68 | /**
|
69 | * The stringified value of the specified key-value pair of the `context` map returned from an API Gateway Lambda authorizer function.
|
70 | * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-use-lambda-authorizer.html
|
71 | * @param property key of the context map.
|
72 | */
|
73 | static contextAuthorizer(property) {
|
74 | return `$context.authorizer.${property}`;
|
75 | }
|
76 | /**
|
77 | * The AWS endpoint's request ID.
|
78 | */
|
79 | static contextAwsEndpointRequestId() {
|
80 | return '$context.awsEndpointRequestId';
|
81 | }
|
82 | /**
|
83 | * The full domain name used to invoke the API. This should be the same as the incoming `Host` header.
|
84 | */
|
85 | static contextDomainName() {
|
86 | return '$context.domainName';
|
87 | }
|
88 | /**
|
89 | * The first label of the `$context.domainName`. This is often used as a caller/customer identifier.
|
90 | */
|
91 | static contextDomainPrefix() {
|
92 | return '$context.domainPrefix';
|
93 | }
|
94 | /**
|
95 | * A string containing an API Gateway error message.
|
96 | */
|
97 | static contextErrorMessage() {
|
98 | return '$context.error.message';
|
99 | }
|
100 | /**
|
101 | * The quoted value of $context.error.message, namely "$context.error.message".
|
102 | */
|
103 | static contextErrorMessageString() {
|
104 | return '$context.error.messageString';
|
105 | }
|
106 | /**
|
107 | * A type of GatewayResponse. This variable can only be used for simple variable substitution in a GatewayResponse body-mapping template,
|
108 | * which is not processed by the Velocity Template Language engine, and in access logging.
|
109 | *
|
110 | * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-websocket-api-logging.html
|
111 | * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/customize-gateway-responses.html
|
112 | */
|
113 | static contextErrorResponseType() {
|
114 | return '$context.error.responseType';
|
115 | }
|
116 | /**
|
117 | * A string containing a detailed validation error message.
|
118 | */
|
119 | static contextErrorValidationErrorString() {
|
120 | return '$context.error.validationErrorString';
|
121 | }
|
122 | /**
|
123 | * The extended ID that API Gateway assigns to the API request, which contains more useful information for debugging/troubleshooting.
|
124 | */
|
125 | static contextExtendedRequestId() {
|
126 | return '$context.extendedRequestId';
|
127 | }
|
128 | /**
|
129 | * The HTTP method used. Valid values include: `DELETE`, `GET`, `HEAD`, `OPTIONS`, `PATCH`, `POST`, and `PUT`.
|
130 | */
|
131 | static contextHttpMethod() {
|
132 | return '$context.httpMethod';
|
133 | }
|
134 | /**
|
135 | * The AWS account ID associated with the request.
|
136 | */
|
137 | static contextIdentityAccountId() {
|
138 | return '$context.identity.accountId';
|
139 | }
|
140 | /**
|
141 | * For API methods that require an API key, this variable is the API key associated with the method request.
|
142 | * For methods that don't require an API key, this variable is
|
143 | * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-api-usage-plans.html
|
144 | */
|
145 | static contextIdentityApiKey() {
|
146 | return '$context.identity.apiKey';
|
147 | }
|
148 | /**
|
149 | * The API key ID associated with an API request that requires an API key.
|
150 | */
|
151 | static contextIdentityApiKeyId() {
|
152 | return '$context.identity.apiKeyId';
|
153 | }
|
154 | /**
|
155 | * The principal identifier of the caller making the request.
|
156 | */
|
157 | static contextIdentityCaller() {
|
158 | return '$context.identity.caller';
|
159 | }
|
160 | /**
|
161 | * The Amazon Cognito authentication provider used by the caller making the request.
|
162 | * Available only if the request was signed with Amazon Cognito credentials.
|
163 | * @see https://docs.aws.amazon.com/cognito/latest/developerguide/cognito-identity.html
|
164 | */
|
165 | static contextIdentityCognitoAuthenticationProvider() {
|
166 | return '$context.identity.cognitoAuthenticationProvider';
|
167 | }
|
168 | /**
|
169 | * The Amazon Cognito authentication type of the caller making the request.
|
170 | * Available only if the request was signed with Amazon Cognito credentials.
|
171 | */
|
172 | static contextIdentityCognitoAuthenticationType() {
|
173 | return '$context.identity.cognitoAuthenticationType';
|
174 | }
|
175 | /**
|
176 | * The Amazon Cognito identity ID of the caller making the request. Available only if the request was signed with Amazon Cognito credentials.
|
177 | */
|
178 | static contextIdentityCognitoIdentityId() {
|
179 | return '$context.identity.cognitoIdentityId';
|
180 | }
|
181 | /**
|
182 | * The Amazon Cognito identity pool ID of the caller making the request.
|
183 | * Available only if the request was signed with Amazon Cognito credentials.
|
184 | */
|
185 | static contextIdentityCognitoIdentityPoolId() {
|
186 | return '$context.identity.cognitoIdentityPoolId';
|
187 | }
|
188 | /**
|
189 | * The AWS organization ID.
|
190 | */
|
191 | static contextIdentityPrincipalOrgId() {
|
192 | return '$context.identity.principalOrgId';
|
193 | }
|
194 | /**
|
195 | * The source IP address of the TCP connection making the request to API Gateway.
|
196 | * Warning: You should not trust this value if there is any chance that the `X-Forwarded-For` header could be forged.
|
197 | */
|
198 | static contextIdentitySourceIp() {
|
199 | return '$context.identity.sourceIp';
|
200 | }
|
201 | /**
|
202 | * The principal identifier of the user making the request. Used in Lambda authorizers.
|
203 | * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-lambda-authorizer-output.html
|
204 | */
|
205 | static contextIdentityUser() {
|
206 | return '$context.identity.user';
|
207 | }
|
208 | /**
|
209 | * The User-Agent header of the API caller.
|
210 | */
|
211 | static contextIdentityUserAgent() {
|
212 | return '$context.identity.userAgent';
|
213 | }
|
214 | /**
|
215 | * The Amazon Resource Name (ARN) of the effective user identified after authentication.
|
216 | * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/id_users.html
|
217 | */
|
218 | static contextIdentityUserArn() {
|
219 | return '$context.identity.userArn';
|
220 | }
|
221 | /**
|
222 | * The request path.
|
223 | * For example, for a non-proxy request URL of https://{rest-api-id.execute-api.{region}.amazonaws.com/{stage}/root/child,
|
224 | * this value is /{stage}/root/child.
|
225 | */
|
226 | static contextPath() {
|
227 | return '$context.path';
|
228 | }
|
229 | /**
|
230 | * The request protocol, for example, HTTP/1.1.
|
231 | */
|
232 | static contextProtocol() {
|
233 | return '$context.protocol';
|
234 | }
|
235 | /**
|
236 | * The ID that API Gateway assigns to the API request.
|
237 | */
|
238 | static contextRequestId() {
|
239 | return '$context.requestId';
|
240 | }
|
241 | /**
|
242 | * The request header override.
|
243 | * If this parameter is defined, it contains the headers to be used instead of the HTTP Headers that are defined in the Integration Request pane.
|
244 | * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-override-request-response-parameters.html
|
245 | *
|
246 | * @param headerName
|
247 | */
|
248 | static contextRequestOverrideHeader(headerName) {
|
249 | return `$context.requestOverride.header.${headerName}`;
|
250 | }
|
251 | /**
|
252 | * The request path override. If this parameter is defined,
|
253 | * it contains the request path to be used instead of the URL Path Parameters that are defined in the Integration Request pane.
|
254 | * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-override-request-response-parameters.html
|
255 | *
|
256 | * @param pathName
|
257 | */
|
258 | static contextRequestOverridePath(pathName) {
|
259 | return `$context.requestOverride.path.${pathName}`;
|
260 | }
|
261 | /**
|
262 | * The request query string override.
|
263 | * If this parameter is defined, it contains the request query strings to be used instead
|
264 | * of the URL Query String Parameters that are defined in the Integration Request pane.
|
265 | *
|
266 | * @param querystringName
|
267 | */
|
268 | static contextRequestOverrideQuerystring(querystringName) {
|
269 | return `$context.requestOverride.querystring.${querystringName}`;
|
270 | }
|
271 | /**
|
272 | * The response header override.
|
273 | * If this parameter is defined, it contains the header to be returned instead of the Response header
|
274 | * that is defined as the Default mapping in the Integration Response pane.
|
275 | * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-override-request-response-parameters.html
|
276 | *
|
277 | * @param headerName
|
278 | */
|
279 | static contextResponseOverrideHeader(headerName) {
|
280 | return `$context.responseOverride.header.${headerName}`;
|
281 | }
|
282 | /**
|
283 | * The response status code override.
|
284 | * If this parameter is defined, it contains the status code to be returned instead of the Method response status
|
285 | * that is defined as the Default mapping in the Integration Response pane.
|
286 | * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-override-request-response-parameters.html
|
287 | */
|
288 | static contextResponseOverrideStatus() {
|
289 | return '$context.responseOverride.status';
|
290 | }
|
291 | /**
|
292 | * The CLF-formatted request time (dd/MMM/yyyy:HH:mm:ss +-hhmm).
|
293 | */
|
294 | static contextRequestTime() {
|
295 | return '$context.requestTime';
|
296 | }
|
297 | /**
|
298 | * The Epoch-formatted request time.
|
299 | */
|
300 | static contextRequestTimeEpoch() {
|
301 | return '$context.requestTimeEpoch';
|
302 | }
|
303 | /**
|
304 | * The identifier that API Gateway assigns to your resource.
|
305 | */
|
306 | static contextResourceId() {
|
307 | return '$context.resourceId';
|
308 | }
|
309 | /**
|
310 | * The path to your resource.
|
311 | * For example, for the non-proxy request URI of `https://{rest-api-id.execute-api.{region}.amazonaws.com/{stage}/root/child`,
|
312 | * The $context.resourcePath value is `/root/child`.
|
313 | * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-create-api-step-by-step.html
|
314 | */
|
315 | static contextResourcePath() {
|
316 | return '$context.resourcePath';
|
317 | }
|
318 | /**
|
319 | * The deployment stage of the API request (for example, `Beta` or `Prod`).
|
320 | */
|
321 | static contextStage() {
|
322 | return '$context.stage';
|
323 | }
|
324 | /**
|
325 | * The response received from AWS WAF: `WAF_ALLOW` or `WAF_BLOCK`. Will not be set if the stage is not associated with a web ACL.
|
326 | * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-control-access-aws-waf.html
|
327 | */
|
328 | static contextWafResponseCode() {
|
329 | return '$context.wafResponseCode';
|
330 | }
|
331 | /**
|
332 | * The complete ARN of the web ACL that is used to decide whether to allow or block the request.
|
333 | * Will not be set if the stage is not associated with a web ACL.
|
334 | * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-control-access-aws-waf.html
|
335 | */
|
336 | static contextWebaclArn() {
|
337 | return '$context.webaclArn';
|
338 | }
|
339 | /**
|
340 | * The trace ID for the X-Ray trace.
|
341 | * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-enabling-xray.html
|
342 | */
|
343 | static contextXrayTraceId() {
|
344 | return '$context.xrayTraceId';
|
345 | }
|
346 | /**
|
347 | * The authorizer latency in ms.
|
348 | */
|
349 | static contextAuthorizerIntegrationLatency() {
|
350 | return '$context.authorizer.integrationLatency';
|
351 | }
|
352 | /**
|
353 | * The integration latency in ms.
|
354 | */
|
355 | static contextIntegrationLatency() {
|
356 | return '$context.integrationLatency';
|
357 | }
|
358 | /**
|
359 | * For Lambda proxy integration, this parameter represents the status code returned from AWS Lambda,
|
360 | * not from the backend Lambda function.
|
361 | */
|
362 | static contextIntegrationStatus() {
|
363 | return '$context.integrationStatus';
|
364 | }
|
365 | /**
|
366 | * The response latency in ms.
|
367 | */
|
368 | static contextResponseLatency() {
|
369 | return '$context.responseLatency';
|
370 | }
|
371 | /**
|
372 | * The response payload length.
|
373 | */
|
374 | static contextResponseLength() {
|
375 | return '$context.responseLength';
|
376 | }
|
377 | /**
|
378 | * The method response status.
|
379 | */
|
380 | static contextStatus() {
|
381 | return '$context.status';
|
382 | }
|
383 | }
|
384 | exports.AccessLogField = AccessLogField;
|
385 | _b = JSII_RTTI_SYMBOL_1;
|
386 | AccessLogField[_b] = { fqn: "@aws-cdk/aws-apigateway.AccessLogField", version: "1.173.0" };
|
387 | /**
|
388 | * factory methods for access log format.
|
389 | */
|
390 | class AccessLogFormat {
|
391 | constructor(format) {
|
392 | this.format = format;
|
393 | }
|
394 | /**
|
395 | * Custom log format.
|
396 | * You can create any log format string. You can easily get the $ context variable by using the methods of AccessLogField.
|
397 | * @param format
|
398 | * @example
|
399 | *
|
400 | * apigateway.AccessLogFormat.custom(JSON.stringify({
|
401 | * requestId: apigateway.AccessLogField.contextRequestId(),
|
402 | * sourceIp: apigateway.AccessLogField.contextIdentitySourceIp(),
|
403 | * method: apigateway.AccessLogField.contextHttpMethod(),
|
404 | * userContext: {
|
405 | * sub: apigateway.AccessLogField.contextAuthorizerClaims('sub'),
|
406 | * email: apigateway.AccessLogField.contextAuthorizerClaims('email')
|
407 | * }
|
408 | * }))
|
409 | */
|
410 | static custom(format) {
|
411 | return new AccessLogFormat(format);
|
412 | }
|
413 | /**
|
414 | * Generate Common Log Format.
|
415 | */
|
416 | static clf() {
|
417 | const requester = [AccessLogField.contextIdentitySourceIp(), AccessLogField.contextIdentityCaller(), AccessLogField.contextIdentityUser()].join(' ');
|
418 | const requestTime = AccessLogField.contextRequestTime();
|
419 | const request = [AccessLogField.contextHttpMethod(), AccessLogField.contextResourcePath(), AccessLogField.contextProtocol()].join(' ');
|
420 | const status = [AccessLogField.contextStatus(), AccessLogField.contextResponseLength(), AccessLogField.contextRequestId()].join(' ');
|
421 | return new AccessLogFormat(`${requester} [${requestTime}] "${request}" ${status}`);
|
422 | }
|
423 | /**
|
424 | * Access log will be produced in the JSON format with a set of fields most useful in the access log. All fields are turned on by default with the
|
425 | * option to turn off specific fields.
|
426 | */
|
427 | static jsonWithStandardFields(fields = {
|
428 | ip: true,
|
429 | user: true,
|
430 | caller: true,
|
431 | requestTime: true,
|
432 | httpMethod: true,
|
433 | resourcePath: true,
|
434 | status: true,
|
435 | protocol: true,
|
436 | responseLength: true,
|
437 | }) {
|
438 | try {
|
439 | jsiiDeprecationWarnings._aws_cdk_aws_apigateway_JsonWithStandardFieldProps(fields);
|
440 | }
|
441 | catch (error) {
|
442 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
443 | Error.captureStackTrace(error, this.jsonWithStandardFields);
|
444 | }
|
445 | throw error;
|
446 | }
|
447 | return this.custom(JSON.stringify({
|
448 | requestId: AccessLogField.contextRequestId(),
|
449 | ip: fields.ip ? AccessLogField.contextIdentitySourceIp() : undefined,
|
450 | user: fields.user ? AccessLogField.contextIdentityUser() : undefined,
|
451 | caller: fields.caller ? AccessLogField.contextIdentityCaller() : undefined,
|
452 | requestTime: fields.requestTime ? AccessLogField.contextRequestTime() : undefined,
|
453 | httpMethod: fields.httpMethod ? AccessLogField.contextHttpMethod() : undefined,
|
454 | resourcePath: fields.resourcePath ? AccessLogField.contextResourcePath() : undefined,
|
455 | status: fields.status ? AccessLogField.contextStatus() : undefined,
|
456 | protocol: fields.protocol ? AccessLogField.contextProtocol() : undefined,
|
457 | responseLength: fields.responseLength ? AccessLogField.contextResponseLength() : undefined,
|
458 | }));
|
459 | }
|
460 | /**
|
461 | * Output a format string to be used with CloudFormation.
|
462 | */
|
463 | toString() {
|
464 | return this.format;
|
465 | }
|
466 | }
|
467 | exports.AccessLogFormat = AccessLogFormat;
|
468 | _c = JSII_RTTI_SYMBOL_1;
|
469 | AccessLogFormat[_c] = { fqn: "@aws-cdk/aws-apigateway.AccessLogFormat", version: "1.173.0" };
|
470 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"access-log.js","sourceRoot":"","sources":["access-log.ts"],"names":[],"mappings":"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","sourcesContent":["import { ILogGroup } from '@aws-cdk/aws-logs';\nimport { IStage } from './stage';\n\n/**\n * Access log destination for a RestApi Stage.\n */\nexport interface IAccessLogDestination {\n  /**\n   * Binds this destination to the RestApi Stage.\n   */\n  bind(stage: IStage): AccessLogDestinationConfig\n}\n\n/**\n * Options when binding a log destination to a RestApi Stage.\n */\nexport interface AccessLogDestinationConfig {\n  /**\n   * The Amazon Resource Name (ARN) of the destination resource\n   */\n  readonly destinationArn: string;\n}\n\n/**\n * Use CloudWatch Logs as a custom access log destination for API Gateway.\n */\nexport class LogGroupLogDestination implements IAccessLogDestination {\n  constructor(private readonly logGroup: ILogGroup) {\n  }\n\n  /**\n   * Binds this destination to the CloudWatch Logs.\n   */\n  public bind(_stage: IStage): AccessLogDestinationConfig {\n    return {\n      destinationArn: this.logGroup.logGroupArn,\n    };\n  }\n}\n\n/**\n * $context variables that can be used to customize access log pattern.\n */\nexport class AccessLogField {\n  /**\n   * The API owner's AWS account ID.\n   */\n  public static contextAccountId() {\n    return '$context.identity.accountId';\n  }\n\n  /**\n   * The identifier API Gateway assigns to your API.\n   */\n  public static contextApiId() {\n    return '$context.apiId';\n  }\n\n  /**\n   * A property of the claims returned from the Amazon Cognito user pool after the method caller is successfully authenticated.\n   * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-integrate-with-cognito.html\n   *\n   * @param property A property key of the claims.\n   */\n  public static contextAuthorizerClaims(property: string) {\n    return `$context.authorizer.claims.${property}`;\n  }\n\n  /**\n   * The principal user identification associated with the token sent by the client and returned\n   * from an API Gateway Lambda authorizer (formerly known as a custom authorizer).\n   * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-use-lambda-authorizer.html\n   */\n  public static contextAuthorizerPrincipalId() {\n    return '$context.authorizer.principalId';\n  }\n\n  /**\n   * The stringified value of the specified key-value pair of the `context` map returned from an API Gateway Lambda authorizer function.\n   * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-use-lambda-authorizer.html\n   * @param property key of the context map.\n   */\n  public static contextAuthorizer(property: string) {\n    return `$context.authorizer.${property}`;\n  }\n\n  /**\n   * The AWS endpoint's request ID.\n   */\n  public static contextAwsEndpointRequestId() {\n    return '$context.awsEndpointRequestId';\n  }\n\n  /**\n   * The full domain name used to invoke the API. This should be the same as the incoming `Host` header.\n   */\n  public static contextDomainName() {\n    return '$context.domainName';\n  }\n\n  /**\n   * The first label of the `$context.domainName`. This is often used as a caller/customer identifier.\n   */\n  public static contextDomainPrefix() {\n    return '$context.domainPrefix';\n  }\n\n  /**\n   * A string containing an API Gateway error message.\n   */\n  public static contextErrorMessage() {\n    return '$context.error.message';\n  }\n\n  /**\n   * The quoted value of $context.error.message, namely \"$context.error.message\".\n   */\n  public static contextErrorMessageString() {\n    return '$context.error.messageString';\n  }\n\n  /**\n   * A type of GatewayResponse. This variable can only be used for simple variable substitution in a GatewayResponse body-mapping template,\n   * which is not processed by the Velocity Template Language engine, and in access logging.\n   *\n   * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-websocket-api-logging.html\n   * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/customize-gateway-responses.html\n   */\n  public static contextErrorResponseType() {\n    return '$context.error.responseType';\n  }\n\n  /**\n   * A string containing a detailed validation error message.\n   */\n  public static contextErrorValidationErrorString() {\n    return '$context.error.validationErrorString';\n  }\n\n  /**\n   * The extended ID that API Gateway assigns to the API request, which contains more useful information for debugging/troubleshooting.\n   */\n  public static contextExtendedRequestId() {\n    return '$context.extendedRequestId';\n  }\n\n  /**\n   * The HTTP method used. Valid values include: `DELETE`, `GET`, `HEAD`, `OPTIONS`, `PATCH`, `POST`, and `PUT`.\n   */\n  public static contextHttpMethod() {\n    return '$context.httpMethod';\n  }\n\n  /**\n   * The AWS account ID associated with the request.\n   */\n  public static contextIdentityAccountId() {\n    return '$context.identity.accountId';\n  }\n\n  /**\n   * For API methods that require an API key, this variable is the API key associated with the method request.\n   * For methods that don't require an API key, this variable is\n   * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-api-usage-plans.html\n   */\n  public static contextIdentityApiKey() {\n    return '$context.identity.apiKey';\n  }\n\n  /**\n   * The API key ID associated with an API request that requires an API key.\n   */\n  public static contextIdentityApiKeyId() {\n    return '$context.identity.apiKeyId';\n  }\n\n  /**\n   * The principal identifier of the caller making the request.\n   */\n  public static contextIdentityCaller() {\n    return '$context.identity.caller';\n  }\n\n  /**\n   * The Amazon Cognito authentication provider used by the caller making the request.\n   * Available only if the request was signed with Amazon Cognito credentials.\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/cognito-identity.html\n   */\n  public static contextIdentityCognitoAuthenticationProvider() {\n    return '$context.identity.cognitoAuthenticationProvider';\n  }\n\n  /**\n   * The Amazon Cognito authentication type of the caller making the request.\n   * Available only if the request was signed with Amazon Cognito credentials.\n   */\n  public static contextIdentityCognitoAuthenticationType() {\n    return '$context.identity.cognitoAuthenticationType';\n  }\n\n  /**\n   * The Amazon Cognito identity ID of the caller making the request. Available only if the request was signed with Amazon Cognito credentials.\n   */\n  public static contextIdentityCognitoIdentityId() {\n    return '$context.identity.cognitoIdentityId';\n  }\n\n  /**\n   * The Amazon Cognito identity pool ID of the caller making the request.\n   * Available only if the request was signed with Amazon Cognito credentials.\n   */\n  public static contextIdentityCognitoIdentityPoolId() {\n    return '$context.identity.cognitoIdentityPoolId';\n  }\n\n  /**\n   * The AWS organization ID.\n   */\n  public static contextIdentityPrincipalOrgId() {\n    return '$context.identity.principalOrgId';\n  }\n\n  /**\n   * The source IP address of the TCP connection making the request to API Gateway.\n   * Warning: You should not trust this value if there is any chance that the `X-Forwarded-For` header could be forged.\n   */\n  public static contextIdentitySourceIp() {\n    return '$context.identity.sourceIp';\n  }\n\n  /**\n   * The principal identifier of the user making the request. Used in Lambda authorizers.\n   * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-lambda-authorizer-output.html\n   */\n  public static contextIdentityUser() {\n    return '$context.identity.user';\n  }\n\n  /**\n   * The User-Agent header of the API caller.\n   */\n  public static contextIdentityUserAgent() {\n    return '$context.identity.userAgent';\n  }\n\n  /**\n   * The Amazon Resource Name (ARN) of the effective user identified after authentication.\n   * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/id_users.html\n   */\n  public static contextIdentityUserArn() {\n    return '$context.identity.userArn';\n  }\n\n  /**\n   * The request path.\n   * For example, for a non-proxy request URL of https://{rest-api-id.execute-api.{region}.amazonaws.com/{stage}/root/child,\n   * this value is /{stage}/root/child.\n   */\n  public static contextPath() {\n    return '$context.path';\n  }\n\n  /**\n   * The request protocol, for example, HTTP/1.1.\n   */\n  public static contextProtocol() {\n    return '$context.protocol';\n  }\n\n  /**\n   * The ID that API Gateway assigns to the API request.\n   */\n  public static contextRequestId() {\n    return '$context.requestId';\n  }\n\n  /**\n   * The request header override.\n   * If this parameter is defined, it contains the headers to be used instead of the HTTP Headers that are defined in the Integration Request pane.\n   * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-override-request-response-parameters.html\n   *\n   * @param headerName\n   */\n  public static contextRequestOverrideHeader(headerName: string) {\n    return `$context.requestOverride.header.${headerName}`;\n  }\n\n  /**\n   * The request path override. If this parameter is defined,\n   * it contains the request path to be used instead of the URL Path Parameters that are defined in the Integration Request pane.\n   * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-override-request-response-parameters.html\n   *\n   * @param pathName\n   */\n  public static contextRequestOverridePath(pathName: string) {\n    return `$context.requestOverride.path.${pathName}`;\n  }\n\n  /**\n   * The request query string override.\n   * If this parameter is defined, it contains the request query strings to be used instead\n   * of the URL Query String Parameters that are defined in the Integration Request pane.\n   *\n   * @param querystringName\n   */\n  public static contextRequestOverrideQuerystring(querystringName: string) {\n    return `$context.requestOverride.querystring.${querystringName}`;\n  }\n\n  /**\n   * The response header override.\n   * If this parameter is defined, it contains the header to be returned instead of the Response header\n   * that is defined as the Default mapping in the Integration Response pane.\n   * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-override-request-response-parameters.html\n   *\n   * @param headerName\n   */\n  public static contextResponseOverrideHeader(headerName: string) {\n    return `$context.responseOverride.header.${headerName}`;\n  }\n\n  /**\n   * The response status code override.\n   * If this parameter is defined, it contains the status code to be returned instead of the Method response status\n   * that is defined as the Default mapping in the Integration Response pane.\n   * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-override-request-response-parameters.html\n   */\n  public static contextResponseOverrideStatus() {\n    return '$context.responseOverride.status';\n  }\n\n  /**\n   * The CLF-formatted request time (dd/MMM/yyyy:HH:mm:ss +-hhmm).\n   */\n  public static contextRequestTime() {\n    return '$context.requestTime';\n  }\n\n  /**\n   * The Epoch-formatted request time.\n   */\n  public static contextRequestTimeEpoch() {\n    return '$context.requestTimeEpoch';\n  }\n\n  /**\n   * The identifier that API Gateway assigns to your resource.\n   */\n  public static contextResourceId() {\n    return '$context.resourceId';\n  }\n\n  /**\n   * The path to your resource.\n   * For example, for the non-proxy request URI of `https://{rest-api-id.execute-api.{region}.amazonaws.com/{stage}/root/child`,\n   * The $context.resourcePath value is `/root/child`.\n   * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-create-api-step-by-step.html\n   */\n  public static contextResourcePath() {\n    return '$context.resourcePath';\n  }\n\n  /**\n   * The deployment stage of the API request (for example, `Beta` or `Prod`).\n   */\n  public static contextStage() {\n    return '$context.stage';\n  }\n\n  /**\n   * The response received from AWS WAF: `WAF_ALLOW` or `WAF_BLOCK`. Will not be set if the stage is not associated with a web ACL.\n   * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-control-access-aws-waf.html\n   */\n  public static contextWafResponseCode() {\n    return '$context.wafResponseCode';\n  }\n\n  /**\n   * The complete ARN of the web ACL that is used to decide whether to allow or block the request.\n   * Will not be set if the stage is not associated with a web ACL.\n   * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-control-access-aws-waf.html\n   */\n  public static contextWebaclArn() {\n    return '$context.webaclArn';\n  }\n\n  /**\n   * The trace ID for the X-Ray trace.\n   * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-enabling-xray.html\n   */\n  public static contextXrayTraceId() {\n    return '$context.xrayTraceId';\n  }\n\n  /**\n   * The authorizer latency in ms.\n   */\n  public static contextAuthorizerIntegrationLatency() {\n    return '$context.authorizer.integrationLatency';\n  }\n\n  /**\n   * The integration latency in ms.\n   */\n  public static contextIntegrationLatency() {\n    return '$context.integrationLatency';\n  }\n\n  /**\n   * For Lambda proxy integration, this parameter represents the status code returned from AWS Lambda,\n   * not from the backend Lambda function.\n   */\n  public static contextIntegrationStatus() {\n    return '$context.integrationStatus';\n  }\n\n  /**\n   * The response latency in ms.\n   */\n  public static contextResponseLatency() {\n    return '$context.responseLatency';\n  }\n\n  /**\n   * The response payload length.\n   */\n  public static contextResponseLength() {\n    return '$context.responseLength';\n  }\n\n  /**\n   * The method response status.\n   */\n  public static contextStatus() {\n    return '$context.status';\n  }\n}\n\n/**\n * Properties for controlling items output in JSON standard format\n */\nexport interface JsonWithStandardFieldProps {\n  /**\n   * If this flag is enabled, the source IP of request will be output to the log\n   */\n  readonly ip: boolean,\n  /**\n   * If this flag is enabled, the principal identifier of the caller will be output to the log\n   */\n  readonly caller: boolean,\n  /**\n   * If this flag is enabled, the principal identifier of the user will be output to the log\n   */\n  readonly user: boolean,\n  /**\n   * If this flag is enabled, the CLF-formatted request time((dd/MMM/yyyy:HH:mm:ss +-hhmm) will be output to the log\n   */\n  readonly requestTime: boolean,\n  /**\n   * If this flag is enabled, the http method will be output to the log\n   */\n  readonly httpMethod: boolean,\n  /**\n   * If this flag is enabled, the path to your resource will be output to the log\n   */\n  readonly resourcePath: boolean,\n  /**\n   * If this flag is enabled, the method response status will be output to the log\n   */\n  readonly status: boolean,\n  /**\n   * If this flag is enabled, the request protocol will be output to the log\n   */\n  readonly protocol: boolean,\n  /**\n   * If this flag is enabled, the response payload length will be output to the log\n   */\n  readonly responseLength: boolean\n}\n\n/**\n * factory methods for access log format.\n */\nexport class AccessLogFormat {\n  /**\n   * Custom log format.\n   * You can create any log format string. You can easily get the $ context variable by using the methods of AccessLogField.\n   * @param format\n   * @example\n   *\n   *  apigateway.AccessLogFormat.custom(JSON.stringify({\n   *      requestId: apigateway.AccessLogField.contextRequestId(),\n   *      sourceIp: apigateway.AccessLogField.contextIdentitySourceIp(),\n   *      method: apigateway.AccessLogField.contextHttpMethod(),\n   *      userContext: {\n   *        sub: apigateway.AccessLogField.contextAuthorizerClaims('sub'),\n   *        email: apigateway.AccessLogField.contextAuthorizerClaims('email')\n   *      }\n   *   }))\n   */\n  public static custom(format: string): AccessLogFormat {\n    return new AccessLogFormat(format);\n  }\n\n  /**\n   * Generate Common Log Format.\n   */\n  public static clf(): AccessLogFormat {\n    const requester = [AccessLogField.contextIdentitySourceIp(), AccessLogField.contextIdentityCaller(), AccessLogField.contextIdentityUser()].join(' ');\n    const requestTime = AccessLogField.contextRequestTime();\n    const request = [AccessLogField.contextHttpMethod(), AccessLogField.contextResourcePath(), AccessLogField.contextProtocol()].join(' ');\n    const status = [AccessLogField.contextStatus(), AccessLogField.contextResponseLength(), AccessLogField.contextRequestId()].join(' ');\n\n    return new AccessLogFormat(`${requester} [${requestTime}] \"${request}\" ${status}`);\n  }\n\n  /**\n   * Access log will be produced in the JSON format with a set of fields most useful in the access log. All fields are turned on by default with the\n   * option to turn off specific fields.\n   */\n  public static jsonWithStandardFields(\n    fields: JsonWithStandardFieldProps = {\n      ip: true,\n      user: true,\n      caller: true,\n      requestTime: true,\n      httpMethod: true,\n      resourcePath: true,\n      status: true,\n      protocol: true,\n      responseLength: true,\n    }): AccessLogFormat {\n    return this.custom(JSON.stringify({\n      requestId: AccessLogField.contextRequestId(),\n      ip: fields.ip ? AccessLogField.contextIdentitySourceIp() : undefined,\n      user: fields.user ? AccessLogField.contextIdentityUser() : undefined,\n      caller: fields.caller ? AccessLogField.contextIdentityCaller() : undefined,\n      requestTime: fields.requestTime ? AccessLogField.contextRequestTime() : undefined,\n      httpMethod: fields.httpMethod ? AccessLogField.contextHttpMethod() : undefined,\n      resourcePath: fields.resourcePath ? AccessLogField.contextResourcePath() : undefined,\n      status: fields.status ? AccessLogField.contextStatus() : undefined,\n      protocol: fields.protocol ? AccessLogField.contextProtocol() : undefined,\n      responseLength: fields.responseLength ? AccessLogField.contextResponseLength() : undefined,\n    }));\n  }\n\n  /**\n   * A API Gateway custom access log format\n   */\n  private readonly format: string;\n\n  private constructor(format: string) {\n    this.format = format;\n  }\n\n  /**\n   * Output a format string to be used with CloudFormation.\n   */\n  public toString(): string {\n    return this.format;\n  }\n}\n"]} |
\ | No newline at end of file |