UNPKG

50.5 kBJavaScriptView Raw
1"use strict";
2var _a, _b, _c;
3Object.defineProperty(exports, "__esModule", { value: true });
4exports.AccessLogFormat = exports.AccessLogField = exports.LogGroupLogDestination = void 0;
5const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
6const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
7/**
8 * Use CloudWatch Logs as a custom access log destination for API Gateway.
9 */
10class 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}
32exports.LogGroupLogDestination = LogGroupLogDestination;
33_a = JSII_RTTI_SYMBOL_1;
34LogGroupLogDestination[_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 */
38class 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}
384exports.AccessLogField = AccessLogField;
385_b = JSII_RTTI_SYMBOL_1;
386AccessLogField[_b] = { fqn: "@aws-cdk/aws-apigateway.AccessLogField", version: "1.173.0" };
387/**
388 * factory methods for access log format.
389 */
390class 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}
467exports.AccessLogFormat = AccessLogFormat;
468_c = JSII_RTTI_SYMBOL_1;
469AccessLogFormat[_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