cdk-nextjs 0.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (125) hide show
  1. package/.jsii +13811 -0
  2. package/.prettierrc +0 -0
  3. package/API.md +9694 -0
  4. package/LICENSE +202 -0
  5. package/README.md +137 -0
  6. package/THIRD-PARTY-LICENSES.md +31 -0
  7. package/assets/lambdas/assets-deployment/assets-deployment.lambda/assets-deployment.Dockerfile +18 -0
  8. package/assets/lambdas/assets-deployment/assets-deployment.lambda/index.js +8831 -0
  9. package/assets/lambdas/revalidate/revalidate.lambda/index.js +67 -0
  10. package/assets/lambdas/sign-fn-url/sign-fn-url.lambda/index.js +2002 -0
  11. package/examples/README.md +14 -0
  12. package/lib/common.d.ts +23 -0
  13. package/lib/common.js +28 -0
  14. package/lib/generated-structs/OptionalApplicationLoadBalancedTaskImageOptions.d.ts +106 -0
  15. package/lib/generated-structs/OptionalApplicationLoadBalancedTaskImageOptions.js +3 -0
  16. package/lib/generated-structs/OptionalCloudFrontFunctionProps.d.ts +43 -0
  17. package/lib/generated-structs/OptionalCloudFrontFunctionProps.js +3 -0
  18. package/lib/generated-structs/OptionalClusterProps.d.ts +49 -0
  19. package/lib/generated-structs/OptionalClusterProps.js +3 -0
  20. package/lib/generated-structs/OptionalDistributionProps.d.ts +155 -0
  21. package/lib/generated-structs/OptionalDistributionProps.js +3 -0
  22. package/lib/generated-structs/OptionalDockerImageAssetProps.d.ts +124 -0
  23. package/lib/generated-structs/OptionalDockerImageAssetProps.js +3 -0
  24. package/lib/generated-structs/OptionalDockerImageFunctionProps.d.ts +399 -0
  25. package/lib/generated-structs/OptionalDockerImageFunctionProps.js +3 -0
  26. package/lib/generated-structs/OptionalEdgeFunctionProps.d.ts +428 -0
  27. package/lib/generated-structs/OptionalEdgeFunctionProps.js +3 -0
  28. package/lib/generated-structs/OptionalFunctionProps.d.ts +422 -0
  29. package/lib/generated-structs/OptionalFunctionProps.js +3 -0
  30. package/lib/generated-structs/OptionalFunctionUrlProps.d.ts +30 -0
  31. package/lib/generated-structs/OptionalFunctionUrlProps.js +3 -0
  32. package/lib/generated-structs/OptionalNextjsAssetsDeploymentProps.d.ts +45 -0
  33. package/lib/generated-structs/OptionalNextjsAssetsDeploymentProps.js +3 -0
  34. package/lib/generated-structs/OptionalNextjsBuildProps.d.ts +30 -0
  35. package/lib/generated-structs/OptionalNextjsBuildProps.js +3 -0
  36. package/lib/generated-structs/OptionalNextjsContainersProps.d.ts +43 -0
  37. package/lib/generated-structs/OptionalNextjsContainersProps.js +3 -0
  38. package/lib/generated-structs/OptionalNextjsDistributionProps.d.ts +50 -0
  39. package/lib/generated-structs/OptionalNextjsDistributionProps.js +3 -0
  40. package/lib/generated-structs/OptionalNextjsFileSystemProps.d.ts +15 -0
  41. package/lib/generated-structs/OptionalNextjsFileSystemProps.js +3 -0
  42. package/lib/generated-structs/OptionalNextjsInvalidationProps.d.ts +17 -0
  43. package/lib/generated-structs/OptionalNextjsInvalidationProps.js +3 -0
  44. package/lib/generated-structs/OptionalNextjsVpcProps.d.ts +21 -0
  45. package/lib/generated-structs/OptionalNextjsVpcProps.js +3 -0
  46. package/lib/generated-structs/OptionalS3OriginProps.d.ts +64 -0
  47. package/lib/generated-structs/OptionalS3OriginProps.js +3 -0
  48. package/lib/generated-structs/OptionalVpcProps.d.ts +224 -0
  49. package/lib/generated-structs/OptionalVpcProps.js +3 -0
  50. package/lib/index.d.ts +35 -0
  51. package/lib/index.js +32 -0
  52. package/lib/lambdas/assets-deployment/assets-deployment-function.d.ts +13 -0
  53. package/lib/lambdas/assets-deployment/assets-deployment-function.js +23 -0
  54. package/lib/lambdas/assets-deployment/assets-deployment.lambda.d.ts +2 -0
  55. package/lib/lambdas/assets-deployment/assets-deployment.lambda.js +62 -0
  56. package/lib/lambdas/assets-deployment/common.d.ts +8 -0
  57. package/lib/lambdas/assets-deployment/common.js +32 -0
  58. package/lib/lambdas/assets-deployment/fs-to-fs.d.ts +2 -0
  59. package/lib/lambdas/assets-deployment/fs-to-fs.js +9 -0
  60. package/lib/lambdas/assets-deployment/fs-to-s3.d.ts +2 -0
  61. package/lib/lambdas/assets-deployment/fs-to-s3.js +45 -0
  62. package/lib/lambdas/assets-deployment/prune-s3.d.ts +15 -0
  63. package/lib/lambdas/assets-deployment/prune-s3.js +42 -0
  64. package/lib/lambdas/assets-deployment/s3.d.ts +2 -0
  65. package/lib/lambdas/assets-deployment/s3.js +7 -0
  66. package/lib/lambdas/assets-deployment/utils.d.ts +18 -0
  67. package/lib/lambdas/assets-deployment/utils.js +35 -0
  68. package/lib/lambdas/revalidate/revalidate-function.d.ts +13 -0
  69. package/lib/lambdas/revalidate/revalidate-function.js +23 -0
  70. package/lib/lambdas/revalidate/revalidate.lambda.d.ts +2 -0
  71. package/lib/lambdas/revalidate/revalidate.lambda.js +53 -0
  72. package/lib/lambdas/sign-fn-url/sign-fn-url-function.d.ts +13 -0
  73. package/lib/lambdas/sign-fn-url/sign-fn-url-function.js +23 -0
  74. package/lib/lambdas/sign-fn-url/sign-fn-url.lambda.d.ts +9 -0
  75. package/lib/lambdas/sign-fn-url/sign-fn-url.lambda.js +35 -0
  76. package/lib/lambdas/sign-fn-url/sign-request.d.ts +28 -0
  77. package/lib/lambdas/sign-fn-url/sign-request.js +119 -0
  78. package/lib/lambdas/sign-fn-url/sign-request.test.d.ts +1 -0
  79. package/lib/lambdas/sign-fn-url/sign-request.test.js +129 -0
  80. package/lib/nextjs-assets-deployment.d.ts +116 -0
  81. package/lib/nextjs-assets-deployment.js +93 -0
  82. package/lib/nextjs-build/add-cache-handler.d.ts +1 -0
  83. package/lib/nextjs-build/add-cache-handler.js +23 -0
  84. package/lib/nextjs-build/add-cache-handler.mjs +18 -0
  85. package/lib/nextjs-build/builder.Dockerfile +29 -0
  86. package/lib/nextjs-build/cache-handler.cjs +21513 -0
  87. package/lib/nextjs-build/cache-handler.d.ts +6 -0
  88. package/lib/nextjs-build/cache-handler.js +22 -0
  89. package/lib/nextjs-build/global-containers.Dockerfile +45 -0
  90. package/lib/nextjs-build/global-functions.Dockerfile +46 -0
  91. package/lib/nextjs-build/nextjs-build.d.ts +150 -0
  92. package/lib/nextjs-build/nextjs-build.js +220 -0
  93. package/lib/nextjs-build/regional-containers.Dockerfile +45 -0
  94. package/lib/nextjs-build/symlink-full-route-cache.d.ts +1 -0
  95. package/lib/nextjs-build/symlink-full-route-cache.js +37 -0
  96. package/lib/nextjs-build/symlink-full-route-cache.mjs +23 -0
  97. package/lib/nextjs-compute/nextjs-compute-base-props.d.ts +8 -0
  98. package/lib/nextjs-compute/nextjs-compute-base-props.js +3 -0
  99. package/lib/nextjs-compute/nextjs-containers.d.ts +43 -0
  100. package/lib/nextjs-compute/nextjs-containers.js +149 -0
  101. package/lib/nextjs-compute/nextjs-functions.d.ts +23 -0
  102. package/lib/nextjs-compute/nextjs-functions.js +57 -0
  103. package/lib/nextjs-distribution.d.ts +120 -0
  104. package/lib/nextjs-distribution.js +362 -0
  105. package/lib/nextjs-file-system.d.ts +42 -0
  106. package/lib/nextjs-file-system.js +74 -0
  107. package/lib/nextjs-invalidation.d.ts +19 -0
  108. package/lib/nextjs-invalidation.js +52 -0
  109. package/lib/nextjs-revalidation.d.ts +30 -0
  110. package/lib/nextjs-revalidation.js +65 -0
  111. package/lib/nextjs-static-assets.d.ts +21 -0
  112. package/lib/nextjs-static-assets.js +32 -0
  113. package/lib/nextjs-vpc.d.ts +42 -0
  114. package/lib/nextjs-vpc.js +64 -0
  115. package/lib/root-constructs/nextjs-base-overrides.d.ts +26 -0
  116. package/lib/root-constructs/nextjs-base-overrides.js +3 -0
  117. package/lib/root-constructs/nextjs-base-props.d.ts +56 -0
  118. package/lib/root-constructs/nextjs-base-props.js +3 -0
  119. package/lib/root-constructs/nextjs-global-containers.d.ts +74 -0
  120. package/lib/root-constructs/nextjs-global-containers.js +125 -0
  121. package/lib/root-constructs/nextjs-global-functions.d.ts +76 -0
  122. package/lib/root-constructs/nextjs-global-functions.js +131 -0
  123. package/lib/root-constructs/nextjs-regional-containers.d.ts +43 -0
  124. package/lib/root-constructs/nextjs-regional-containers.js +92 -0
  125. package/package.json +165 -0
@@ -0,0 +1,50 @@
1
+ import type { NextjsDistributionOverrides, NextjsType, PublicDirEntry } from '../';
2
+ import type { aws_certificatemanager, aws_cloudfront, aws_s3 } from 'aws-cdk-lib';
3
+ /**
4
+ * OptionalNextjsDistributionProps
5
+ */
6
+ export interface OptionalNextjsDistributionProps {
7
+ /**
8
+ * Override props for every construct.
9
+ * @stability stable
10
+ */
11
+ readonly overrides?: NextjsDistributionOverrides;
12
+ /**
13
+ * Required if `NextjsType.GLOBAL_FUNCTIONS`.
14
+ * @stability stable
15
+ */
16
+ readonly functionArn?: string;
17
+ /**
18
+ * @stability stable
19
+ */
20
+ readonly distribution?: aws_cloudfront.Distribution;
21
+ /**
22
+ * Optional but only applicable for `NextjsType.GLOBAL_CONTAINERS`.
23
+ * @stability stable
24
+ */
25
+ readonly certificate?: aws_certificatemanager.ICertificate;
26
+ /**
27
+ * @stability stable
28
+ */
29
+ readonly basePath?: string;
30
+ /**
31
+ * Path to directory of Next.js app's public directory. Used to add static behaviors to distribution.
32
+ * @stability stable
33
+ */
34
+ readonly publicDirEntries?: Array<PublicDirEntry>;
35
+ /**
36
+ * @stability stable
37
+ */
38
+ readonly nextjsType?: NextjsType;
39
+ /**
40
+ * Dynamic (Next.js server) URL to add behavior to distribution.
41
+ * @stability stable
42
+ */
43
+ readonly dynamicUrl?: string;
44
+ /**
45
+ * Bucket containing static assets.
46
+ * Must be provided if you want to serve static files.
47
+ * @stability stable
48
+ */
49
+ readonly assetsBucket?: aws_s3.IBucket;
50
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiT3B0aW9uYWxOZXh0anNEaXN0cmlidXRpb25Qcm9wcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9nZW5lcmF0ZWQtc3RydWN0cy9PcHRpb25hbE5leHRqc0Rpc3RyaWJ1dGlvblByb3BzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvLyB+fiBHZW5lcmF0ZWQgYnkgcHJvamVuLiBUbyBtb2RpZnksIGVkaXQgLnByb2plbnJjLnRzIGFuZCBydW4gXCJwbnBtIGRseCBwcm9qZW5cIi5cbmltcG9ydCB0eXBlIHsgTmV4dGpzRGlzdHJpYnV0aW9uT3ZlcnJpZGVzLCBOZXh0anNUeXBlLCBQdWJsaWNEaXJFbnRyeSB9IGZyb20gJy4uLyc7XG5pbXBvcnQgdHlwZSB7IGF3c19jZXJ0aWZpY2F0ZW1hbmFnZXIsIGF3c19jbG91ZGZyb250LCBhd3NfczMgfSBmcm9tICdhd3MtY2RrLWxpYic7XG5cbi8qKlxuICogT3B0aW9uYWxOZXh0anNEaXN0cmlidXRpb25Qcm9wc1xuICovXG5leHBvcnQgaW50ZXJmYWNlIE9wdGlvbmFsTmV4dGpzRGlzdHJpYnV0aW9uUHJvcHMge1xuICAvKipcbiAgICogT3ZlcnJpZGUgcHJvcHMgZm9yIGV2ZXJ5IGNvbnN0cnVjdC5cbiAgICogQHN0YWJpbGl0eSBzdGFibGVcbiAgICovXG4gIHJlYWRvbmx5IG92ZXJyaWRlcz86IE5leHRqc0Rpc3RyaWJ1dGlvbk92ZXJyaWRlcztcbiAgLyoqXG4gICAqIFJlcXVpcmVkIGlmIGBOZXh0anNUeXBlLkdMT0JBTF9GVU5DVElPTlNgLlxuICAgKiBAc3RhYmlsaXR5IHN0YWJsZVxuICAgKi9cbiAgcmVhZG9ubHkgZnVuY3Rpb25Bcm4/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBAc3RhYmlsaXR5IHN0YWJsZVxuICAgKi9cbiAgcmVhZG9ubHkgZGlzdHJpYnV0aW9uPzogYXdzX2Nsb3VkZnJvbnQuRGlzdHJpYnV0aW9uO1xuICAvKipcbiAgICogT3B0aW9uYWwgYnV0IG9ubHkgYXBwbGljYWJsZSBmb3IgYE5leHRqc1R5cGUuR0xPQkFMX0NPTlRBSU5FUlNgLlxuICAgKiBAc3RhYmlsaXR5IHN0YWJsZVxuICAgKi9cbiAgcmVhZG9ubHkgY2VydGlmaWNhdGU/OiBhd3NfY2VydGlmaWNhdGVtYW5hZ2VyLklDZXJ0aWZpY2F0ZTtcbiAgLyoqXG4gICAqIEBzdGFiaWxpdHkgc3RhYmxlXG4gICAqL1xuICByZWFkb25seSBiYXNlUGF0aD86IHN0cmluZztcbiAgLyoqXG4gICAqIFBhdGggdG8gZGlyZWN0b3J5IG9mIE5leHQuanMgYXBwJ3MgcHVibGljIGRpcmVjdG9yeS4gVXNlZCB0byBhZGQgc3RhdGljIGJlaGF2aW9ycyB0byBkaXN0cmlidXRpb24uXG4gICAqIEBzdGFiaWxpdHkgc3RhYmxlXG4gICAqL1xuICByZWFkb25seSBwdWJsaWNEaXJFbnRyaWVzPzogQXJyYXk8UHVibGljRGlyRW50cnk+O1xuICAvKipcbiAgICogQHN0YWJpbGl0eSBzdGFibGVcbiAgICovXG4gIHJlYWRvbmx5IG5leHRqc1R5cGU/OiBOZXh0anNUeXBlO1xuICAvKipcbiAgICogRHluYW1pYyAoTmV4dC5qcyBzZXJ2ZXIpIFVSTCB0byBhZGQgYmVoYXZpb3IgdG8gZGlzdHJpYnV0aW9uLlxuICAgKiBAc3RhYmlsaXR5IHN0YWJsZVxuICAgKi9cbiAgcmVhZG9ubHkgZHluYW1pY1VybD86IHN0cmluZztcbiAgLyoqXG4gICAqIEJ1Y2tldCBjb250YWluaW5nIHN0YXRpYyBhc3NldHMuXG4gICAqIE11c3QgYmUgcHJvdmlkZWQgaWYgeW91IHdhbnQgdG8gc2VydmUgc3RhdGljIGZpbGVzLlxuICAgKiBAc3RhYmlsaXR5IHN0YWJsZVxuICAgKi9cbiAgcmVhZG9ubHkgYXNzZXRzQnVja2V0PzogYXdzX3MzLklCdWNrZXQ7XG59XG4iXX0=
@@ -0,0 +1,15 @@
1
+ import type { NextjsFileSystemOverrides } from '../';
2
+ import type { aws_ec2 } from 'aws-cdk-lib';
3
+ /**
4
+ * OptionalNextjsFileSystemProps
5
+ */
6
+ export interface OptionalNextjsFileSystemProps {
7
+ /**
8
+ * @stability stable
9
+ */
10
+ readonly overrides?: NextjsFileSystemOverrides;
11
+ /**
12
+ * @stability stable
13
+ */
14
+ readonly vpc?: aws_ec2.IVpc;
15
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiT3B0aW9uYWxOZXh0anNGaWxlU3lzdGVtUHJvcHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZ2VuZXJhdGVkLXN0cnVjdHMvT3B0aW9uYWxOZXh0anNGaWxlU3lzdGVtUHJvcHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8vIH5+IEdlbmVyYXRlZCBieSBwcm9qZW4uIFRvIG1vZGlmeSwgZWRpdCAucHJvamVucmMudHMgYW5kIHJ1biBcInBucG0gZGx4IHByb2plblwiLlxuaW1wb3J0IHR5cGUgeyBOZXh0anNGaWxlU3lzdGVtT3ZlcnJpZGVzIH0gZnJvbSAnLi4vJztcbmltcG9ydCB0eXBlIHsgYXdzX2VjMiB9IGZyb20gJ2F3cy1jZGstbGliJztcblxuLyoqXG4gKiBPcHRpb25hbE5leHRqc0ZpbGVTeXN0ZW1Qcm9wc1xuICovXG5leHBvcnQgaW50ZXJmYWNlIE9wdGlvbmFsTmV4dGpzRmlsZVN5c3RlbVByb3BzIHtcbiAgLyoqXG4gICAqIEBzdGFiaWxpdHkgc3RhYmxlXG4gICAqL1xuICByZWFkb25seSBvdmVycmlkZXM/OiBOZXh0anNGaWxlU3lzdGVtT3ZlcnJpZGVzO1xuICAvKipcbiAgICogQHN0YWJpbGl0eSBzdGFibGVcbiAgICovXG4gIHJlYWRvbmx5IHZwYz86IGF3c19lYzIuSVZwYztcbn1cbiJdfQ==
@@ -0,0 +1,17 @@
1
+ import type { NextjsInvalidationOverrides } from '../';
2
+ import type { aws_cloudfront } from 'aws-cdk-lib';
3
+ /**
4
+ * OptionalNextjsInvalidationProps
5
+ */
6
+ export interface OptionalNextjsInvalidationProps {
7
+ /**
8
+ * Override props for every construct.
9
+ * @stability stable
10
+ */
11
+ readonly overrides?: NextjsInvalidationOverrides;
12
+ /**
13
+ * CloudFront Distribution to invalidate.
14
+ * @stability stable
15
+ */
16
+ readonly distribution?: aws_cloudfront.IDistribution;
17
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiT3B0aW9uYWxOZXh0anNJbnZhbGlkYXRpb25Qcm9wcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9nZW5lcmF0ZWQtc3RydWN0cy9PcHRpb25hbE5leHRqc0ludmFsaWRhdGlvblByb3BzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvLyB+fiBHZW5lcmF0ZWQgYnkgcHJvamVuLiBUbyBtb2RpZnksIGVkaXQgLnByb2plbnJjLnRzIGFuZCBydW4gXCJwbnBtIGRseCBwcm9qZW5cIi5cbmltcG9ydCB0eXBlIHsgTmV4dGpzSW52YWxpZGF0aW9uT3ZlcnJpZGVzIH0gZnJvbSAnLi4vJztcbmltcG9ydCB0eXBlIHsgYXdzX2Nsb3VkZnJvbnQgfSBmcm9tICdhd3MtY2RrLWxpYic7XG5cbi8qKlxuICogT3B0aW9uYWxOZXh0anNJbnZhbGlkYXRpb25Qcm9wc1xuICovXG5leHBvcnQgaW50ZXJmYWNlIE9wdGlvbmFsTmV4dGpzSW52YWxpZGF0aW9uUHJvcHMge1xuICAvKipcbiAgICogT3ZlcnJpZGUgcHJvcHMgZm9yIGV2ZXJ5IGNvbnN0cnVjdC5cbiAgICogQHN0YWJpbGl0eSBzdGFibGVcbiAgICovXG4gIHJlYWRvbmx5IG92ZXJyaWRlcz86IE5leHRqc0ludmFsaWRhdGlvbk92ZXJyaWRlcztcbiAgLyoqXG4gICAqIENsb3VkRnJvbnQgRGlzdHJpYnV0aW9uIHRvIGludmFsaWRhdGUuXG4gICAqIEBzdGFiaWxpdHkgc3RhYmxlXG4gICAqL1xuICByZWFkb25seSBkaXN0cmlidXRpb24/OiBhd3NfY2xvdWRmcm9udC5JRGlzdHJpYnV0aW9uO1xufVxuIl19
@@ -0,0 +1,21 @@
1
+ import type { aws_ec2 } from 'aws-cdk-lib';
2
+ import type { NextjsType, NextjsVpcOverrides } from '../';
3
+ /**
4
+ * OptionalNextjsVpcProps
5
+ */
6
+ export interface OptionalNextjsVpcProps {
7
+ /**
8
+ * Bring your own VPC.
9
+ * @stability stable
10
+ */
11
+ readonly vpc?: aws_ec2.IVpc;
12
+ /**
13
+ * Override any construct.
14
+ * @stability stable
15
+ */
16
+ readonly overrides?: NextjsVpcOverrides;
17
+ /**
18
+ * @stability stable
19
+ */
20
+ readonly nextjsType?: NextjsType;
21
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiT3B0aW9uYWxOZXh0anNWcGNQcm9wcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9nZW5lcmF0ZWQtc3RydWN0cy9PcHRpb25hbE5leHRqc1ZwY1Byb3BzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvLyB+fiBHZW5lcmF0ZWQgYnkgcHJvamVuLiBUbyBtb2RpZnksIGVkaXQgLnByb2plbnJjLnRzIGFuZCBydW4gXCJwbnBtIGRseCBwcm9qZW5cIi5cbmltcG9ydCB0eXBlIHsgYXdzX2VjMiB9IGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCB0eXBlIHsgTmV4dGpzVHlwZSwgTmV4dGpzVnBjT3ZlcnJpZGVzIH0gZnJvbSAnLi4vJztcblxuLyoqXG4gKiBPcHRpb25hbE5leHRqc1ZwY1Byb3BzXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgT3B0aW9uYWxOZXh0anNWcGNQcm9wcyB7XG4gIC8qKlxuICAgKiBCcmluZyB5b3VyIG93biBWUEMuXG4gICAqIEBzdGFiaWxpdHkgc3RhYmxlXG4gICAqL1xuICByZWFkb25seSB2cGM/OiBhd3NfZWMyLklWcGM7XG4gIC8qKlxuICAgKiBPdmVycmlkZSBhbnkgY29uc3RydWN0LlxuICAgKiBAc3RhYmlsaXR5IHN0YWJsZVxuICAgKi9cbiAgcmVhZG9ubHkgb3ZlcnJpZGVzPzogTmV4dGpzVnBjT3ZlcnJpZGVzO1xuICAvKipcbiAgICogQHN0YWJpbGl0eSBzdGFibGVcbiAgICovXG4gIHJlYWRvbmx5IG5leHRqc1R5cGU/OiBOZXh0anNUeXBlO1xufVxuIl19
@@ -0,0 +1,64 @@
1
+ import type { aws_cloudfront, Duration } from 'aws-cdk-lib';
2
+ /**
3
+ * OptionalS3OriginProps
4
+ */
5
+ export interface OptionalS3OriginProps {
6
+ /**
7
+ * An optional Origin Access Identity of the origin identity cloudfront will use when calling your s3 bucket.
8
+ * @default - An Origin Access Identity will be created.
9
+ * @stability stable
10
+ */
11
+ readonly originAccessIdentity?: aws_cloudfront.IOriginAccessIdentity;
12
+ /**
13
+ * An optional path that CloudFront appends to the origin domain name when CloudFront requests content from the origin.
14
+ * Must begin, but not end, with '/' (e.g., '/production/images').
15
+ * @default '/'
16
+ * @stability stable
17
+ */
18
+ readonly originPath?: string;
19
+ /**
20
+ * When you enable Origin Shield in the AWS Region that has the lowest latency to your origin, you can get better network performance.
21
+ * @default - origin shield not enabled
22
+ * @stability stable
23
+ */
24
+ readonly originShieldRegion?: string;
25
+ /**
26
+ * Origin Shield is enabled by setting originShieldRegion to a valid region, after this to disable Origin Shield again you must set this flag to false.
27
+ * @default - true
28
+ * @stability stable
29
+ */
30
+ readonly originShieldEnabled?: boolean;
31
+ /**
32
+ * A unique identifier for the origin.
33
+ * This value must be unique within the distribution.
34
+ * @default - an originid will be generated for you
35
+ * @stability stable
36
+ */
37
+ readonly originId?: string;
38
+ /**
39
+ * The unique identifier of an origin access control for this origin.
40
+ * @default - no origin access control
41
+ * @stability stable
42
+ */
43
+ readonly originAccessControlId?: string;
44
+ /**
45
+ * A list of HTTP header names and values that CloudFront adds to requests it sends to the origin.
46
+ * @default {}
47
+ * @stability stable
48
+ */
49
+ readonly customHeaders?: Record<string, string>;
50
+ /**
51
+ * The number of seconds that CloudFront waits when trying to establish a connection to the origin.
52
+ * Valid values are 1-10 seconds, inclusive.
53
+ * @default Duration.seconds(10)
54
+ * @stability stable
55
+ */
56
+ readonly connectionTimeout?: Duration;
57
+ /**
58
+ * The number of times that CloudFront attempts to connect to the origin;
59
+ * valid values are 1, 2, or 3 attempts.
60
+ * @default 3
61
+ * @stability stable
62
+ */
63
+ readonly connectionAttempts?: number;
64
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiT3B0aW9uYWxTM09yaWdpblByb3BzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2dlbmVyYXRlZC1zdHJ1Y3RzL09wdGlvbmFsUzNPcmlnaW5Qcm9wcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiLy8gfn4gR2VuZXJhdGVkIGJ5IHByb2plbi4gVG8gbW9kaWZ5LCBlZGl0IC5wcm9qZW5yYy50cyBhbmQgcnVuIFwicG5wbSBkbHggcHJvamVuXCIuXG5pbXBvcnQgdHlwZSB7IGF3c19jbG91ZGZyb250LCBEdXJhdGlvbiB9IGZyb20gJ2F3cy1jZGstbGliJztcblxuLyoqXG4gKiBPcHRpb25hbFMzT3JpZ2luUHJvcHNcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBPcHRpb25hbFMzT3JpZ2luUHJvcHMge1xuICAvKipcbiAgICogQW4gb3B0aW9uYWwgT3JpZ2luIEFjY2VzcyBJZGVudGl0eSBvZiB0aGUgb3JpZ2luIGlkZW50aXR5IGNsb3VkZnJvbnQgd2lsbCB1c2Ugd2hlbiBjYWxsaW5nIHlvdXIgczMgYnVja2V0LlxuICAgKiBAZGVmYXVsdCAtIEFuIE9yaWdpbiBBY2Nlc3MgSWRlbnRpdHkgd2lsbCBiZSBjcmVhdGVkLlxuICAgKiBAc3RhYmlsaXR5IHN0YWJsZVxuICAgKi9cbiAgcmVhZG9ubHkgb3JpZ2luQWNjZXNzSWRlbnRpdHk/OiBhd3NfY2xvdWRmcm9udC5JT3JpZ2luQWNjZXNzSWRlbnRpdHk7XG4gIC8qKlxuICAgKiBBbiBvcHRpb25hbCBwYXRoIHRoYXQgQ2xvdWRGcm9udCBhcHBlbmRzIHRvIHRoZSBvcmlnaW4gZG9tYWluIG5hbWUgd2hlbiBDbG91ZEZyb250IHJlcXVlc3RzIGNvbnRlbnQgZnJvbSB0aGUgb3JpZ2luLlxuICAgKiBNdXN0IGJlZ2luLCBidXQgbm90IGVuZCwgd2l0aCAnLycgKGUuZy4sICcvcHJvZHVjdGlvbi9pbWFnZXMnKS5cbiAgICogQGRlZmF1bHQgJy8nXG4gICAqIEBzdGFiaWxpdHkgc3RhYmxlXG4gICAqL1xuICByZWFkb25seSBvcmlnaW5QYXRoPzogc3RyaW5nO1xuICAvKipcbiAgICogV2hlbiB5b3UgZW5hYmxlIE9yaWdpbiBTaGllbGQgaW4gdGhlIEFXUyBSZWdpb24gdGhhdCBoYXMgdGhlIGxvd2VzdCBsYXRlbmN5IHRvIHlvdXIgb3JpZ2luLCB5b3UgY2FuIGdldCBiZXR0ZXIgbmV0d29yayBwZXJmb3JtYW5jZS5cbiAgICogQGRlZmF1bHQgLSBvcmlnaW4gc2hpZWxkIG5vdCBlbmFibGVkXG4gICAqIEBzdGFiaWxpdHkgc3RhYmxlXG4gICAqL1xuICByZWFkb25seSBvcmlnaW5TaGllbGRSZWdpb24/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBPcmlnaW4gU2hpZWxkIGlzIGVuYWJsZWQgYnkgc2V0dGluZyBvcmlnaW5TaGllbGRSZWdpb24gdG8gYSB2YWxpZCByZWdpb24sIGFmdGVyIHRoaXMgdG8gZGlzYWJsZSBPcmlnaW4gU2hpZWxkIGFnYWluIHlvdSBtdXN0IHNldCB0aGlzIGZsYWcgdG8gZmFsc2UuXG4gICAqIEBkZWZhdWx0IC0gdHJ1ZVxuICAgKiBAc3RhYmlsaXR5IHN0YWJsZVxuICAgKi9cbiAgcmVhZG9ubHkgb3JpZ2luU2hpZWxkRW5hYmxlZD86IGJvb2xlYW47XG4gIC8qKlxuICAgKiBBIHVuaXF1ZSBpZGVudGlmaWVyIGZvciB0aGUgb3JpZ2luLlxuICAgKiBUaGlzIHZhbHVlIG11c3QgYmUgdW5pcXVlIHdpdGhpbiB0aGUgZGlzdHJpYnV0aW9uLlxuICAgKiBAZGVmYXVsdCAtIGFuIG9yaWdpbmlkIHdpbGwgYmUgZ2VuZXJhdGVkIGZvciB5b3VcbiAgICogQHN0YWJpbGl0eSBzdGFibGVcbiAgICovXG4gIHJlYWRvbmx5IG9yaWdpbklkPzogc3RyaW5nO1xuICAvKipcbiAgICogVGhlIHVuaXF1ZSBpZGVudGlmaWVyIG9mIGFuIG9yaWdpbiBhY2Nlc3MgY29udHJvbCBmb3IgdGhpcyBvcmlnaW4uXG4gICAqIEBkZWZhdWx0IC0gbm8gb3JpZ2luIGFjY2VzcyBjb250cm9sXG4gICAqIEBzdGFiaWxpdHkgc3RhYmxlXG4gICAqL1xuICByZWFkb25seSBvcmlnaW5BY2Nlc3NDb250cm9sSWQ/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBBIGxpc3Qgb2YgSFRUUCBoZWFkZXIgbmFtZXMgYW5kIHZhbHVlcyB0aGF0IENsb3VkRnJvbnQgYWRkcyB0byByZXF1ZXN0cyBpdCBzZW5kcyB0byB0aGUgb3JpZ2luLlxuICAgKiBAZGVmYXVsdCB7fVxuICAgKiBAc3RhYmlsaXR5IHN0YWJsZVxuICAgKi9cbiAgcmVhZG9ubHkgY3VzdG9tSGVhZGVycz86IFJlY29yZDxzdHJpbmcsIHN0cmluZz47XG4gIC8qKlxuICAgKiBUaGUgbnVtYmVyIG9mIHNlY29uZHMgdGhhdCBDbG91ZEZyb250IHdhaXRzIHdoZW4gdHJ5aW5nIHRvIGVzdGFibGlzaCBhIGNvbm5lY3Rpb24gdG8gdGhlIG9yaWdpbi5cbiAgICogVmFsaWQgdmFsdWVzIGFyZSAxLTEwIHNlY29uZHMsIGluY2x1c2l2ZS5cbiAgICogQGRlZmF1bHQgRHVyYXRpb24uc2Vjb25kcygxMClcbiAgICogQHN0YWJpbGl0eSBzdGFibGVcbiAgICovXG4gIHJlYWRvbmx5IGNvbm5lY3Rpb25UaW1lb3V0PzogRHVyYXRpb247XG4gIC8qKlxuICAgKiBUaGUgbnVtYmVyIG9mIHRpbWVzIHRoYXQgQ2xvdWRGcm9udCBhdHRlbXB0cyB0byBjb25uZWN0IHRvIHRoZSBvcmlnaW47XG4gICAqIHZhbGlkIHZhbHVlcyBhcmUgMSwgMiwgb3IgMyBhdHRlbXB0cy5cbiAgICogQGRlZmF1bHQgM1xuICAgKiBAc3RhYmlsaXR5IHN0YWJsZVxuICAgKi9cbiAgcmVhZG9ubHkgY29ubmVjdGlvbkF0dGVtcHRzPzogbnVtYmVyO1xufVxuIl19
@@ -0,0 +1,224 @@
1
+ import type { aws_ec2 } from 'aws-cdk-lib';
2
+ /**
3
+ * OptionalVpcProps
4
+ */
5
+ export interface OptionalVpcProps {
6
+ /**
7
+ * Where to propagate VPN routes.
8
+ * @default - On the route tables associated with private subnets. If no
9
+ private subnets exists, isolated subnets are used. If no isolated subnets
10
+ exists, public subnets are used.
11
+ * @stability stable
12
+ */
13
+ readonly vpnRoutePropagation?: Array<aws_ec2.SubnetSelection>;
14
+ /**
15
+ * The private Autonomous System Number (ASN) for the VPN gateway.
16
+ * @default - Amazon default ASN.
17
+ * @stability stable
18
+ */
19
+ readonly vpnGatewayAsn?: number;
20
+ /**
21
+ * Indicates whether a VPN gateway should be created and attached to this VPC.
22
+ * @default - true when vpnGatewayAsn or vpnConnections is specified
23
+ * @stability stable
24
+ */
25
+ readonly vpnGateway?: boolean;
26
+ /**
27
+ * VPN connections to this VPC.
28
+ * @default - No connections.
29
+ * @stability stable
30
+ */
31
+ readonly vpnConnections?: Record<string, aws_ec2.VpnConnectionOptions>;
32
+ /**
33
+ * The VPC name.
34
+ * Since the VPC resource doesn't support providing a physical name, the value provided here will be recorded in the `Name` tag
35
+ * @default this.node.path
36
+ * @stability stable
37
+ */
38
+ readonly vpcName?: string;
39
+ /**
40
+ * Configure the subnets to build for each AZ.
41
+ * Each entry in this list configures a Subnet Group; each group will contain a
42
+ * subnet for each Availability Zone.
43
+ *
44
+ * For example, if you want 1 public subnet, 1 private subnet, and 1 isolated
45
+ * subnet in each AZ provide the following:
46
+ *
47
+ * ```ts
48
+ * new ec2.Vpc(this, 'VPC', {
49
+ * subnetConfiguration: [
50
+ * {
51
+ * cidrMask: 24,
52
+ * name: 'ingress',
53
+ * subnetType: ec2.SubnetType.PUBLIC,
54
+ * },
55
+ * {
56
+ * cidrMask: 24,
57
+ * name: 'application',
58
+ * subnetType: ec2.SubnetType.PRIVATE_WITH_EGRESS,
59
+ * },
60
+ * {
61
+ * cidrMask: 28,
62
+ * name: 'rds',
63
+ * subnetType: ec2.SubnetType.PRIVATE_ISOLATED,
64
+ * }
65
+ * ]
66
+ * });
67
+ * ```
68
+ * @default - The VPC CIDR will be evenly divided between 1 public and 1
69
+ private subnet per AZ.
70
+ * @stability stable
71
+ */
72
+ readonly subnetConfiguration?: Array<aws_ec2.SubnetConfiguration>;
73
+ /**
74
+ * If set to true then the default inbound & outbound rules will be removed from the default security group.
75
+ * @default true if '@aws-cdk/aws-ec2:restrictDefaultSecurityGroup' is enabled, false otherwise
76
+ * @stability stable
77
+ */
78
+ readonly restrictDefaultSecurityGroup?: boolean;
79
+ /**
80
+ * Define the number of AZs to reserve.
81
+ * When specified, the IP space is reserved for the azs but no actual
82
+ * resources are provisioned.
83
+ * @default 0
84
+ * @stability stable
85
+ */
86
+ readonly reservedAzs?: number;
87
+ /**
88
+ * Configures the subnets which will have NAT Gateways/Instances.
89
+ * You can pick a specific group of subnets by specifying the group name;
90
+ * the picked subnets must be public subnets.
91
+ *
92
+ * Only necessary if you have more than one public subnet group.
93
+ * @default - All public subnets.
94
+ * @stability stable
95
+ */
96
+ readonly natGatewaySubnets?: aws_ec2.SubnetSelection;
97
+ /**
98
+ * The number of NAT Gateways/Instances to create.
99
+ * The type of NAT gateway or instance will be determined by the
100
+ * `natGatewayProvider` parameter.
101
+ *
102
+ * You can set this number lower than the number of Availability Zones in your
103
+ * VPC in order to save on NAT cost. Be aware you may be charged for
104
+ * cross-AZ data traffic instead.
105
+ * @default - One NAT gateway/instance per Availability Zone
106
+ * @stability stable
107
+ */
108
+ readonly natGateways?: number;
109
+ /**
110
+ * What type of NAT provider to use.
111
+ * Select between NAT gateways or NAT instances. NAT gateways
112
+ * may not be available in all AWS regions.
113
+ * @default NatProvider.gateway()
114
+ * @stability stable
115
+ */
116
+ readonly natGatewayProvider?: aws_ec2.NatProvider;
117
+ /**
118
+ * Define the maximum number of AZs to use in this region.
119
+ * If the region has more AZs than you want to use (for example, because of
120
+ * EIP limits), pick a lower number here. The AZs will be sorted and picked
121
+ * from the start of the list.
122
+ *
123
+ * If you pick a higher number than the number of AZs in the region, all AZs
124
+ * in the region will be selected. To use "all AZs" available to your
125
+ * account, use a high number (such as 99).
126
+ *
127
+ * Be aware that environment-agnostic stacks will be created with access to
128
+ * only 2 AZs, so to use more than 2 AZs, be sure to specify the account and
129
+ * region on your stack.
130
+ *
131
+ * Specify this option only if you do not specify `availabilityZones`.
132
+ * @default 3
133
+ * @stability stable
134
+ */
135
+ readonly maxAzs?: number;
136
+ /**
137
+ * The Provider to use to allocate IPv6 Space to your VPC.
138
+ * Options include amazon provided CIDR block.
139
+ *
140
+ * Note this is specific to IPv6 addresses.
141
+ * @default Ipv6Addresses.amazonProvided
142
+ * @stability stable
143
+ */
144
+ readonly ipv6Addresses?: aws_ec2.IIpv6Addresses;
145
+ /**
146
+ * The protocol of the vpc.
147
+ * Options are IPv4 only or dual stack.
148
+ * @default IpProtocol.IPV4_ONLY
149
+ * @stability stable
150
+ */
151
+ readonly ipProtocol?: aws_ec2.IpProtocol;
152
+ /**
153
+ * The Provider to use to allocate IPv4 Space to your VPC.
154
+ * Options include static allocation or from a pool.
155
+ *
156
+ * Note this is specific to IPv4 addresses.
157
+ * @default ec2.IpAddresses.cidr
158
+ * @stability stable
159
+ */
160
+ readonly ipAddresses?: aws_ec2.IIpAddresses;
161
+ /**
162
+ * Gateway endpoints to add to this VPC.
163
+ * @default - None.
164
+ * @stability stable
165
+ */
166
+ readonly gatewayEndpoints?: Record<string, aws_ec2.GatewayVpcEndpointOptions>;
167
+ /**
168
+ * Flow logs to add to this VPC.
169
+ * @default - No flow logs.
170
+ * @stability stable
171
+ */
172
+ readonly flowLogs?: Record<string, aws_ec2.FlowLogOptions>;
173
+ /**
174
+ * Indicates whether the DNS resolution is supported for the VPC.
175
+ * If this attribute is false, the Amazon-provided DNS server in the VPC that
176
+ * resolves public DNS hostnames to IP addresses is not enabled. If this
177
+ * attribute is true, queries to the Amazon provided DNS server at the
178
+ * 169.254.169.253 IP address, or the reserved IP address at the base of the
179
+ * VPC IPv4 network range plus two will succeed.
180
+ * @default true
181
+ * @stability stable
182
+ */
183
+ readonly enableDnsSupport?: boolean;
184
+ /**
185
+ * Indicates whether the instances launched in the VPC get public DNS hostnames.
186
+ * If this attribute is true, instances in the VPC get public DNS hostnames,
187
+ * but only if the enableDnsSupport attribute is also set to true.
188
+ * @default true
189
+ * @stability stable
190
+ */
191
+ readonly enableDnsHostnames?: boolean;
192
+ /**
193
+ * The default tenancy of instances launched into the VPC.
194
+ * By setting this to dedicated tenancy, instances will be launched on
195
+ * hardware dedicated to a single AWS customer, unless specifically specified
196
+ * at instance launch time. Please note, not all instance types are usable
197
+ * with Dedicated tenancy.
198
+ * @default DefaultInstanceTenancy.Default (shared) tenancy
199
+ * @stability stable
200
+ */
201
+ readonly defaultInstanceTenancy?: aws_ec2.DefaultInstanceTenancy;
202
+ /**
203
+ * If set to false then disable the creation of the default internet gateway.
204
+ * @default true
205
+ * @stability stable
206
+ */
207
+ readonly createInternetGateway?: boolean;
208
+ /**
209
+ * The CIDR range to use for the VPC, e.g. '10.0.0.0/16'.
210
+ * Should be a minimum of /28 and maximum size of /16. The range will be
211
+ * split across all subnets per Availability Zone.
212
+ * @default Vpc.DEFAULT_CIDR_RANGE
213
+ * @deprecated Use ipAddresses instead
214
+ * @stability deprecated
215
+ */
216
+ readonly cidr?: string;
217
+ /**
218
+ * Availability zones this VPC spans.
219
+ * Specify this option only if you do not specify `maxAzs`.
220
+ * @default - a subset of AZs of the stack
221
+ * @stability stable
222
+ */
223
+ readonly availabilityZones?: Array<string>;
224
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"OptionalVpcProps.js","sourceRoot":"","sources":["../../src/generated-structs/OptionalVpcProps.ts"],"names":[],"mappings":"","sourcesContent":["// ~~ Generated by projen. To modify, edit .projenrc.ts and run \"pnpm dlx projen\".\nimport type { aws_ec2 } from 'aws-cdk-lib';\n\n/**\n * OptionalVpcProps\n */\nexport interface OptionalVpcProps {\n  /**\n   * Where to propagate VPN routes.\n   * @default - On the route tables associated with private subnets. If no\nprivate subnets exists, isolated subnets are used. If no isolated subnets\nexists, public subnets are used.\n   * @stability stable\n   */\n  readonly vpnRoutePropagation?: Array<aws_ec2.SubnetSelection>;\n  /**\n   * The private Autonomous System Number (ASN) for the VPN gateway.\n   * @default - Amazon default ASN.\n   * @stability stable\n   */\n  readonly vpnGatewayAsn?: number;\n  /**\n   * Indicates whether a VPN gateway should be created and attached to this VPC.\n   * @default - true when vpnGatewayAsn or vpnConnections is specified\n   * @stability stable\n   */\n  readonly vpnGateway?: boolean;\n  /**\n   * VPN connections to this VPC.\n   * @default - No connections.\n   * @stability stable\n   */\n  readonly vpnConnections?: Record<string, aws_ec2.VpnConnectionOptions>;\n  /**\n   * The VPC name.\n   * Since the VPC resource doesn't support providing a physical name, the value provided here will be recorded in the `Name` tag\n   * @default this.node.path\n   * @stability stable\n   */\n  readonly vpcName?: string;\n  /**\n   * Configure the subnets to build for each AZ.\n   * Each entry in this list configures a Subnet Group; each group will contain a\n   * subnet for each Availability Zone.\n   *\n   * For example, if you want 1 public subnet, 1 private subnet, and 1 isolated\n   * subnet in each AZ provide the following:\n   *\n   * ```ts\n   * new ec2.Vpc(this, 'VPC', {\n   *   subnetConfiguration: [\n   *      {\n   *        cidrMask: 24,\n   *        name: 'ingress',\n   *        subnetType: ec2.SubnetType.PUBLIC,\n   *      },\n   *      {\n   *        cidrMask: 24,\n   *        name: 'application',\n   *        subnetType: ec2.SubnetType.PRIVATE_WITH_EGRESS,\n   *      },\n   *      {\n   *        cidrMask: 28,\n   *        name: 'rds',\n   *        subnetType: ec2.SubnetType.PRIVATE_ISOLATED,\n   *      }\n   *   ]\n   * });\n   * ```\n   * @default - The VPC CIDR will be evenly divided between 1 public and 1\nprivate subnet per AZ.\n   * @stability stable\n   */\n  readonly subnetConfiguration?: Array<aws_ec2.SubnetConfiguration>;\n  /**\n   * If set to true then the default inbound & outbound rules will be removed from the default security group.\n   * @default true if '@aws-cdk/aws-ec2:restrictDefaultSecurityGroup' is enabled, false otherwise\n   * @stability stable\n   */\n  readonly restrictDefaultSecurityGroup?: boolean;\n  /**\n   * Define the number of AZs to reserve.\n   * When specified, the IP space is reserved for the azs but no actual\n   * resources are provisioned.\n   * @default 0\n   * @stability stable\n   */\n  readonly reservedAzs?: number;\n  /**\n   * Configures the subnets which will have NAT Gateways/Instances.\n   * You can pick a specific group of subnets by specifying the group name;\n   * the picked subnets must be public subnets.\n   *\n   * Only necessary if you have more than one public subnet group.\n   * @default - All public subnets.\n   * @stability stable\n   */\n  readonly natGatewaySubnets?: aws_ec2.SubnetSelection;\n  /**\n   * The number of NAT Gateways/Instances to create.\n   * The type of NAT gateway or instance will be determined by the\n   * `natGatewayProvider` parameter.\n   *\n   * You can set this number lower than the number of Availability Zones in your\n   * VPC in order to save on NAT cost. Be aware you may be charged for\n   * cross-AZ data traffic instead.\n   * @default - One NAT gateway/instance per Availability Zone\n   * @stability stable\n   */\n  readonly natGateways?: number;\n  /**\n   * What type of NAT provider to use.\n   * Select between NAT gateways or NAT instances. NAT gateways\n   * may not be available in all AWS regions.\n   * @default NatProvider.gateway()\n   * @stability stable\n   */\n  readonly natGatewayProvider?: aws_ec2.NatProvider;\n  /**\n   * Define the maximum number of AZs to use in this region.\n   * If the region has more AZs than you want to use (for example, because of\n   * EIP limits), pick a lower number here. The AZs will be sorted and picked\n   * from the start of the list.\n   *\n   * If you pick a higher number than the number of AZs in the region, all AZs\n   * in the region will be selected. To use \"all AZs\" available to your\n   * account, use a high number (such as 99).\n   *\n   * Be aware that environment-agnostic stacks will be created with access to\n   * only 2 AZs, so to use more than 2 AZs, be sure to specify the account and\n   * region on your stack.\n   *\n   * Specify this option only if you do not specify `availabilityZones`.\n   * @default 3\n   * @stability stable\n   */\n  readonly maxAzs?: number;\n  /**\n   * The Provider to use to allocate IPv6 Space to your VPC.\n   * Options include amazon provided CIDR block.\n   *\n   * Note this is specific to IPv6 addresses.\n   * @default Ipv6Addresses.amazonProvided\n   * @stability stable\n   */\n  readonly ipv6Addresses?: aws_ec2.IIpv6Addresses;\n  /**\n   * The protocol of the vpc.\n   * Options are IPv4 only or dual stack.\n   * @default IpProtocol.IPV4_ONLY\n   * @stability stable\n   */\n  readonly ipProtocol?: aws_ec2.IpProtocol;\n  /**\n   * The Provider to use to allocate IPv4 Space to your VPC.\n   * Options include static allocation or from a pool.\n   *\n   * Note this is specific to IPv4 addresses.\n   * @default ec2.IpAddresses.cidr\n   * @stability stable\n   */\n  readonly ipAddresses?: aws_ec2.IIpAddresses;\n  /**\n   * Gateway endpoints to add to this VPC.\n   * @default - None.\n   * @stability stable\n   */\n  readonly gatewayEndpoints?: Record<string, aws_ec2.GatewayVpcEndpointOptions>;\n  /**\n   * Flow logs to add to this VPC.\n   * @default - No flow logs.\n   * @stability stable\n   */\n  readonly flowLogs?: Record<string, aws_ec2.FlowLogOptions>;\n  /**\n   * Indicates whether the DNS resolution is supported for the VPC.\n   * If this attribute is false, the Amazon-provided DNS server in the VPC that\n   * resolves public DNS hostnames to IP addresses is not enabled. If this\n   * attribute is true, queries to the Amazon provided DNS server at the\n   * 169.254.169.253 IP address, or the reserved IP address at the base of the\n   * VPC IPv4 network range plus two will succeed.\n   * @default true\n   * @stability stable\n   */\n  readonly enableDnsSupport?: boolean;\n  /**\n   * Indicates whether the instances launched in the VPC get public DNS hostnames.\n   * If this attribute is true, instances in the VPC get public DNS hostnames,\n   * but only if the enableDnsSupport attribute is also set to true.\n   * @default true\n   * @stability stable\n   */\n  readonly enableDnsHostnames?: boolean;\n  /**\n   * The default tenancy of instances launched into the VPC.\n   * By setting this to dedicated tenancy, instances will be launched on\n   * hardware dedicated to a single AWS customer, unless specifically specified\n   * at instance launch time. Please note, not all instance types are usable\n   * with Dedicated tenancy.\n   * @default DefaultInstanceTenancy.Default (shared) tenancy\n   * @stability stable\n   */\n  readonly defaultInstanceTenancy?: aws_ec2.DefaultInstanceTenancy;\n  /**\n   * If set to false then disable the creation of the default internet gateway.\n   * @default true\n   * @stability stable\n   */\n  readonly createInternetGateway?: boolean;\n  /**\n   * The CIDR range to use for the VPC, e.g. '10.0.0.0/16'.\n   * Should be a minimum of /28 and maximum size of /16. The range will be\n   * split across all subnets per Availability Zone.\n   * @default Vpc.DEFAULT_CIDR_RANGE\n   * @deprecated Use ipAddresses instead\n   * @stability deprecated\n   */\n  readonly cidr?: string;\n  /**\n   * Availability zones this VPC spans.\n   * Specify this option only if you do not specify `maxAzs`.\n   * @default - a subset of AZs of the stack\n   * @stability stable\n   */\n  readonly availabilityZones?: Array<string>;\n}\n"]}
package/lib/index.d.ts ADDED
@@ -0,0 +1,35 @@
1
+ export { NextjsType } from "./common";
2
+ export { CustomResourceProperties, NextjsAssetsDeployment, NextjsAssetDeploymentOverrides, NextjsAssetsDeploymentProps, } from "./nextjs-assets-deployment";
3
+ export { NextjsBuild, NextjsBuildProps, NextjsBuildOverrides, BuilderImageProps, PublicDirEntry, } from "./nextjs-build/nextjs-build";
4
+ export { NextjsComputeBaseProps } from "./nextjs-compute/nextjs-compute-base-props";
5
+ export { NextjsContainers, NextjsContainersOverrides, NextjsContainersProps, } from "./nextjs-compute/nextjs-containers";
6
+ export { NextjsDistribution, NextjsDistributionOverrides, NextjsDistributionProps, } from "./nextjs-distribution";
7
+ export { NextjsFunctions, NextjsFunctionsOverrides, NextjsFunctionsProps, } from "./nextjs-compute/nextjs-functions";
8
+ export { NextjsFileSystem, NextjsFileSystemOverrides, NextjsFileSystemProps, AllowComputeProps, } from "./nextjs-file-system";
9
+ export { BaseNextjsConstructOverrides, BaseNextjsOverrides, } from "./root-constructs/nextjs-base-overrides";
10
+ export { NextjsBaseProps } from "./root-constructs/nextjs-base-props";
11
+ export { NextjsGlobalContainers, NextjsGlobalContainersConstructOverrides, NextjsGlobalContainersOverrides, NextjsGlobalContainersProps, } from "./root-constructs/nextjs-global-containers";
12
+ export { NextjsGlobalFunctions, NextjsGlobalFunctionsConstructOverrides, NextjsGlobalFunctionsOverrides, NextjsGlobalFunctionsProps, } from "./root-constructs/nextjs-global-functions";
13
+ export { NextjsRegionalContainers, NextjsRegionalContainersConstructOverrides, NextjsRegionalContainersOverrides, NextjsRegionalContainersProps, } from "./root-constructs/nextjs-regional-containers";
14
+ export { NextjsInvalidation, NextjsInvalidationOverrides, NextjsInvalidationProps, } from "./nextjs-invalidation";
15
+ export { NextjsRevalidation, NextjsRevalidationProps, NextjsRevalidationOverrides, } from "./nextjs-revalidation";
16
+ export { NextjsStaticAssets, NextjsStaticAssetsOverrides, NextjsStaticAssetsProps, } from "./nextjs-static-assets";
17
+ export { NextjsVpc, NextjsVpcOverrides, NextjsVpcProps } from "./nextjs-vpc";
18
+ export { OptionalNextjsAssetsDeploymentProps } from "./generated-structs/OptionalNextjsAssetsDeploymentProps";
19
+ export { OptionalNextjsBuildProps } from "./generated-structs/OptionalNextjsBuildProps";
20
+ export { OptionalNextjsContainersProps } from "./generated-structs/OptionalNextjsContainersProps";
21
+ export { OptionalNextjsDistributionProps } from "./generated-structs/OptionalNextjsDistributionProps";
22
+ export { OptionalNextjsFileSystemProps } from "./generated-structs/OptionalNextjsFileSystemProps";
23
+ export { OptionalNextjsInvalidationProps } from "./generated-structs/OptionalNextjsInvalidationProps";
24
+ export { OptionalNextjsVpcProps } from "./generated-structs/OptionalNextjsVpcProps";
25
+ export { OptionalApplicationLoadBalancedTaskImageOptions } from "./generated-structs/OptionalApplicationLoadBalancedTaskImageOptions";
26
+ export { OptionalCloudFrontFunctionProps } from "./generated-structs/OptionalCloudFrontFunctionProps";
27
+ export { OptionalClusterProps } from "./generated-structs/OptionalClusterProps";
28
+ export { OptionalDistributionProps } from "./generated-structs/OptionalDistributionProps";
29
+ export { OptionalDockerImageAssetProps } from "./generated-structs/OptionalDockerImageAssetProps";
30
+ export { OptionalDockerImageFunctionProps } from "./generated-structs/OptionalDockerImageFunctionProps";
31
+ export { OptionalEdgeFunctionProps } from "./generated-structs/OptionalEdgeFunctionProps";
32
+ export { OptionalFunctionProps } from "./generated-structs/OptionalFunctionProps";
33
+ export { OptionalFunctionUrlProps } from "./generated-structs/OptionalFunctionUrlProps";
34
+ export { OptionalS3OriginProps } from "./generated-structs/OptionalS3OriginProps";
35
+ export { OptionalVpcProps } from "./generated-structs/OptionalVpcProps";
package/lib/index.js ADDED
@@ -0,0 +1,32 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.NextjsVpc = exports.NextjsStaticAssets = exports.NextjsRevalidation = exports.NextjsInvalidation = exports.NextjsRegionalContainers = exports.NextjsGlobalFunctions = exports.NextjsGlobalContainers = exports.NextjsFileSystem = exports.NextjsFunctions = exports.NextjsDistribution = exports.NextjsContainers = exports.NextjsBuild = exports.NextjsAssetsDeployment = exports.NextjsType = void 0;
4
+ var common_1 = require("./common");
5
+ Object.defineProperty(exports, "NextjsType", { enumerable: true, get: function () { return common_1.NextjsType; } });
6
+ var nextjs_assets_deployment_1 = require("./nextjs-assets-deployment");
7
+ Object.defineProperty(exports, "NextjsAssetsDeployment", { enumerable: true, get: function () { return nextjs_assets_deployment_1.NextjsAssetsDeployment; } });
8
+ var nextjs_build_1 = require("./nextjs-build/nextjs-build");
9
+ Object.defineProperty(exports, "NextjsBuild", { enumerable: true, get: function () { return nextjs_build_1.NextjsBuild; } });
10
+ var nextjs_containers_1 = require("./nextjs-compute/nextjs-containers");
11
+ Object.defineProperty(exports, "NextjsContainers", { enumerable: true, get: function () { return nextjs_containers_1.NextjsContainers; } });
12
+ var nextjs_distribution_1 = require("./nextjs-distribution");
13
+ Object.defineProperty(exports, "NextjsDistribution", { enumerable: true, get: function () { return nextjs_distribution_1.NextjsDistribution; } });
14
+ var nextjs_functions_1 = require("./nextjs-compute/nextjs-functions");
15
+ Object.defineProperty(exports, "NextjsFunctions", { enumerable: true, get: function () { return nextjs_functions_1.NextjsFunctions; } });
16
+ var nextjs_file_system_1 = require("./nextjs-file-system");
17
+ Object.defineProperty(exports, "NextjsFileSystem", { enumerable: true, get: function () { return nextjs_file_system_1.NextjsFileSystem; } });
18
+ var nextjs_global_containers_1 = require("./root-constructs/nextjs-global-containers");
19
+ Object.defineProperty(exports, "NextjsGlobalContainers", { enumerable: true, get: function () { return nextjs_global_containers_1.NextjsGlobalContainers; } });
20
+ var nextjs_global_functions_1 = require("./root-constructs/nextjs-global-functions");
21
+ Object.defineProperty(exports, "NextjsGlobalFunctions", { enumerable: true, get: function () { return nextjs_global_functions_1.NextjsGlobalFunctions; } });
22
+ var nextjs_regional_containers_1 = require("./root-constructs/nextjs-regional-containers");
23
+ Object.defineProperty(exports, "NextjsRegionalContainers", { enumerable: true, get: function () { return nextjs_regional_containers_1.NextjsRegionalContainers; } });
24
+ var nextjs_invalidation_1 = require("./nextjs-invalidation");
25
+ Object.defineProperty(exports, "NextjsInvalidation", { enumerable: true, get: function () { return nextjs_invalidation_1.NextjsInvalidation; } });
26
+ var nextjs_revalidation_1 = require("./nextjs-revalidation");
27
+ Object.defineProperty(exports, "NextjsRevalidation", { enumerable: true, get: function () { return nextjs_revalidation_1.NextjsRevalidation; } });
28
+ var nextjs_static_assets_1 = require("./nextjs-static-assets");
29
+ Object.defineProperty(exports, "NextjsStaticAssets", { enumerable: true, get: function () { return nextjs_static_assets_1.NextjsStaticAssets; } });
30
+ var nextjs_vpc_1 = require("./nextjs-vpc");
31
+ Object.defineProperty(exports, "NextjsVpc", { enumerable: true, get: function () { return nextjs_vpc_1.NextjsVpc; } });
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsbUNBQXNDO0FBQTdCLG9HQUFBLFVBQVUsT0FBQTtBQUNuQix1RUFLb0M7QUFIbEMsa0lBQUEsc0JBQXNCLE9BQUE7QUFJeEIsNERBTXFDO0FBTG5DLDJHQUFBLFdBQVcsT0FBQTtBQU9iLHdFQUk0QztBQUgxQyxxSEFBQSxnQkFBZ0IsT0FBQTtBQUlsQiw2REFJK0I7QUFIN0IseUhBQUEsa0JBQWtCLE9BQUE7QUFJcEIsc0VBSTJDO0FBSHpDLG1IQUFBLGVBQWUsT0FBQTtBQUlqQiwyREFLOEI7QUFKNUIsc0hBQUEsZ0JBQWdCLE9BQUE7QUFVbEIsdUZBS29EO0FBSmxELGtJQUFBLHNCQUFzQixPQUFBO0FBS3hCLHFGQUttRDtBQUpqRCxnSUFBQSxxQkFBcUIsT0FBQTtBQUt2QiwyRkFLc0Q7QUFKcEQsc0lBQUEsd0JBQXdCLE9BQUE7QUFLMUIsNkRBSStCO0FBSDdCLHlIQUFBLGtCQUFrQixPQUFBO0FBSXBCLDZEQUkrQjtBQUg3Qix5SEFBQSxrQkFBa0IsT0FBQTtBQUlwQiwrREFJZ0M7QUFIOUIsMEhBQUEsa0JBQWtCLE9BQUE7QUFJcEIsMkNBQTZFO0FBQXBFLHVHQUFBLFNBQVMsT0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IE5leHRqc1R5cGUgfSBmcm9tIFwiLi9jb21tb25cIjtcbmV4cG9ydCB7XG4gIEN1c3RvbVJlc291cmNlUHJvcGVydGllcyxcbiAgTmV4dGpzQXNzZXRzRGVwbG95bWVudCxcbiAgTmV4dGpzQXNzZXREZXBsb3ltZW50T3ZlcnJpZGVzLFxuICBOZXh0anNBc3NldHNEZXBsb3ltZW50UHJvcHMsXG59IGZyb20gXCIuL25leHRqcy1hc3NldHMtZGVwbG95bWVudFwiO1xuZXhwb3J0IHtcbiAgTmV4dGpzQnVpbGQsXG4gIE5leHRqc0J1aWxkUHJvcHMsXG4gIE5leHRqc0J1aWxkT3ZlcnJpZGVzLFxuICBCdWlsZGVySW1hZ2VQcm9wcyxcbiAgUHVibGljRGlyRW50cnksXG59IGZyb20gXCIuL25leHRqcy1idWlsZC9uZXh0anMtYnVpbGRcIjtcbmV4cG9ydCB7IE5leHRqc0NvbXB1dGVCYXNlUHJvcHMgfSBmcm9tIFwiLi9uZXh0anMtY29tcHV0ZS9uZXh0anMtY29tcHV0ZS1iYXNlLXByb3BzXCI7XG5leHBvcnQge1xuICBOZXh0anNDb250YWluZXJzLFxuICBOZXh0anNDb250YWluZXJzT3ZlcnJpZGVzLFxuICBOZXh0anNDb250YWluZXJzUHJvcHMsXG59IGZyb20gXCIuL25leHRqcy1jb21wdXRlL25leHRqcy1jb250YWluZXJzXCI7XG5leHBvcnQge1xuICBOZXh0anNEaXN0cmlidXRpb24sXG4gIE5leHRqc0Rpc3RyaWJ1dGlvbk92ZXJyaWRlcyxcbiAgTmV4dGpzRGlzdHJpYnV0aW9uUHJvcHMsXG59IGZyb20gXCIuL25leHRqcy1kaXN0cmlidXRpb25cIjtcbmV4cG9ydCB7XG4gIE5leHRqc0Z1bmN0aW9ucyxcbiAgTmV4dGpzRnVuY3Rpb25zT3ZlcnJpZGVzLFxuICBOZXh0anNGdW5jdGlvbnNQcm9wcyxcbn0gZnJvbSBcIi4vbmV4dGpzLWNvbXB1dGUvbmV4dGpzLWZ1bmN0aW9uc1wiO1xuZXhwb3J0IHtcbiAgTmV4dGpzRmlsZVN5c3RlbSxcbiAgTmV4dGpzRmlsZVN5c3RlbU92ZXJyaWRlcyxcbiAgTmV4dGpzRmlsZVN5c3RlbVByb3BzLFxuICBBbGxvd0NvbXB1dGVQcm9wcyxcbn0gZnJvbSBcIi4vbmV4dGpzLWZpbGUtc3lzdGVtXCI7XG5leHBvcnQge1xuICBCYXNlTmV4dGpzQ29uc3RydWN0T3ZlcnJpZGVzLFxuICBCYXNlTmV4dGpzT3ZlcnJpZGVzLFxufSBmcm9tIFwiLi9yb290LWNvbnN0cnVjdHMvbmV4dGpzLWJhc2Utb3ZlcnJpZGVzXCI7XG5leHBvcnQgeyBOZXh0anNCYXNlUHJvcHMgfSBmcm9tIFwiLi9yb290LWNvbnN0cnVjdHMvbmV4dGpzLWJhc2UtcHJvcHNcIjtcbmV4cG9ydCB7XG4gIE5leHRqc0dsb2JhbENvbnRhaW5lcnMsXG4gIE5leHRqc0dsb2JhbENvbnRhaW5lcnNDb25zdHJ1Y3RPdmVycmlkZXMsXG4gIE5leHRqc0dsb2JhbENvbnRhaW5lcnNPdmVycmlkZXMsXG4gIE5leHRqc0dsb2JhbENvbnRhaW5lcnNQcm9wcyxcbn0gZnJvbSBcIi4vcm9vdC1jb25zdHJ1Y3RzL25leHRqcy1nbG9iYWwtY29udGFpbmVyc1wiO1xuZXhwb3J0IHtcbiAgTmV4dGpzR2xvYmFsRnVuY3Rpb25zLFxuICBOZXh0anNHbG9iYWxGdW5jdGlvbnNDb25zdHJ1Y3RPdmVycmlkZXMsXG4gIE5leHRqc0dsb2JhbEZ1bmN0aW9uc092ZXJyaWRlcyxcbiAgTmV4dGpzR2xvYmFsRnVuY3Rpb25zUHJvcHMsXG59IGZyb20gXCIuL3Jvb3QtY29uc3RydWN0cy9uZXh0anMtZ2xvYmFsLWZ1bmN0aW9uc1wiO1xuZXhwb3J0IHtcbiAgTmV4dGpzUmVnaW9uYWxDb250YWluZXJzLFxuICBOZXh0anNSZWdpb25hbENvbnRhaW5lcnNDb25zdHJ1Y3RPdmVycmlkZXMsXG4gIE5leHRqc1JlZ2lvbmFsQ29udGFpbmVyc092ZXJyaWRlcyxcbiAgTmV4dGpzUmVnaW9uYWxDb250YWluZXJzUHJvcHMsXG59IGZyb20gXCIuL3Jvb3QtY29uc3RydWN0cy9uZXh0anMtcmVnaW9uYWwtY29udGFpbmVyc1wiO1xuZXhwb3J0IHtcbiAgTmV4dGpzSW52YWxpZGF0aW9uLFxuICBOZXh0anNJbnZhbGlkYXRpb25PdmVycmlkZXMsXG4gIE5leHRqc0ludmFsaWRhdGlvblByb3BzLFxufSBmcm9tIFwiLi9uZXh0anMtaW52YWxpZGF0aW9uXCI7XG5leHBvcnQge1xuICBOZXh0anNSZXZhbGlkYXRpb24sXG4gIE5leHRqc1JldmFsaWRhdGlvblByb3BzLFxuICBOZXh0anNSZXZhbGlkYXRpb25PdmVycmlkZXMsXG59IGZyb20gXCIuL25leHRqcy1yZXZhbGlkYXRpb25cIjtcbmV4cG9ydCB7XG4gIE5leHRqc1N0YXRpY0Fzc2V0cyxcbiAgTmV4dGpzU3RhdGljQXNzZXRzT3ZlcnJpZGVzLFxuICBOZXh0anNTdGF0aWNBc3NldHNQcm9wcyxcbn0gZnJvbSBcIi4vbmV4dGpzLXN0YXRpYy1hc3NldHNcIjtcbmV4cG9ydCB7IE5leHRqc1ZwYywgTmV4dGpzVnBjT3ZlcnJpZGVzLCBOZXh0anNWcGNQcm9wcyB9IGZyb20gXCIuL25leHRqcy12cGNcIjtcbmV4cG9ydCB7IE9wdGlvbmFsTmV4dGpzQXNzZXRzRGVwbG95bWVudFByb3BzIH0gZnJvbSBcIi4vZ2VuZXJhdGVkLXN0cnVjdHMvT3B0aW9uYWxOZXh0anNBc3NldHNEZXBsb3ltZW50UHJvcHNcIjtcbmV4cG9ydCB7IE9wdGlvbmFsTmV4dGpzQnVpbGRQcm9wcyB9IGZyb20gXCIuL2dlbmVyYXRlZC1zdHJ1Y3RzL09wdGlvbmFsTmV4dGpzQnVpbGRQcm9wc1wiO1xuZXhwb3J0IHsgT3B0aW9uYWxOZXh0anNDb250YWluZXJzUHJvcHMgfSBmcm9tIFwiLi9nZW5lcmF0ZWQtc3RydWN0cy9PcHRpb25hbE5leHRqc0NvbnRhaW5lcnNQcm9wc1wiO1xuZXhwb3J0IHsgT3B0aW9uYWxOZXh0anNEaXN0cmlidXRpb25Qcm9wcyB9IGZyb20gXCIuL2dlbmVyYXRlZC1zdHJ1Y3RzL09wdGlvbmFsTmV4dGpzRGlzdHJpYnV0aW9uUHJvcHNcIjtcbmV4cG9ydCB7IE9wdGlvbmFsTmV4dGpzRmlsZVN5c3RlbVByb3BzIH0gZnJvbSBcIi4vZ2VuZXJhdGVkLXN0cnVjdHMvT3B0aW9uYWxOZXh0anNGaWxlU3lzdGVtUHJvcHNcIjtcbmV4cG9ydCB7IE9wdGlvbmFsTmV4dGpzSW52YWxpZGF0aW9uUHJvcHMgfSBmcm9tIFwiLi9nZW5lcmF0ZWQtc3RydWN0cy9PcHRpb25hbE5leHRqc0ludmFsaWRhdGlvblByb3BzXCI7XG5leHBvcnQgeyBPcHRpb25hbE5leHRqc1ZwY1Byb3BzIH0gZnJvbSBcIi4vZ2VuZXJhdGVkLXN0cnVjdHMvT3B0aW9uYWxOZXh0anNWcGNQcm9wc1wiO1xuZXhwb3J0IHsgT3B0aW9uYWxBcHBsaWNhdGlvbkxvYWRCYWxhbmNlZFRhc2tJbWFnZU9wdGlvbnMgfSBmcm9tIFwiLi9nZW5lcmF0ZWQtc3RydWN0cy9PcHRpb25hbEFwcGxpY2F0aW9uTG9hZEJhbGFuY2VkVGFza0ltYWdlT3B0aW9uc1wiO1xuZXhwb3J0IHsgT3B0aW9uYWxDbG91ZEZyb250RnVuY3Rpb25Qcm9wcyB9IGZyb20gXCIuL2dlbmVyYXRlZC1zdHJ1Y3RzL09wdGlvbmFsQ2xvdWRGcm9udEZ1bmN0aW9uUHJvcHNcIjtcbmV4cG9ydCB7IE9wdGlvbmFsQ2x1c3RlclByb3BzIH0gZnJvbSBcIi4vZ2VuZXJhdGVkLXN0cnVjdHMvT3B0aW9uYWxDbHVzdGVyUHJvcHNcIjtcbmV4cG9ydCB7IE9wdGlvbmFsRGlzdHJpYnV0aW9uUHJvcHMgfSBmcm9tIFwiLi9nZW5lcmF0ZWQtc3RydWN0cy9PcHRpb25hbERpc3RyaWJ1dGlvblByb3BzXCI7XG5leHBvcnQgeyBPcHRpb25hbERvY2tlckltYWdlQXNzZXRQcm9wcyB9IGZyb20gXCIuL2dlbmVyYXRlZC1zdHJ1Y3RzL09wdGlvbmFsRG9ja2VySW1hZ2VBc3NldFByb3BzXCI7XG5leHBvcnQgeyBPcHRpb25hbERvY2tlckltYWdlRnVuY3Rpb25Qcm9wcyB9IGZyb20gXCIuL2dlbmVyYXRlZC1zdHJ1Y3RzL09wdGlvbmFsRG9ja2VySW1hZ2VGdW5jdGlvblByb3BzXCI7XG5leHBvcnQgeyBPcHRpb25hbEVkZ2VGdW5jdGlvblByb3BzIH0gZnJvbSBcIi4vZ2VuZXJhdGVkLXN0cnVjdHMvT3B0aW9uYWxFZGdlRnVuY3Rpb25Qcm9wc1wiO1xuZXhwb3J0IHsgT3B0aW9uYWxGdW5jdGlvblByb3BzIH0gZnJvbSBcIi4vZ2VuZXJhdGVkLXN0cnVjdHMvT3B0aW9uYWxGdW5jdGlvblByb3BzXCI7XG5leHBvcnQgeyBPcHRpb25hbEZ1bmN0aW9uVXJsUHJvcHMgfSBmcm9tIFwiLi9nZW5lcmF0ZWQtc3RydWN0cy9PcHRpb25hbEZ1bmN0aW9uVXJsUHJvcHNcIjtcbmV4cG9ydCB7IE9wdGlvbmFsUzNPcmlnaW5Qcm9wcyB9IGZyb20gXCIuL2dlbmVyYXRlZC1zdHJ1Y3RzL09wdGlvbmFsUzNPcmlnaW5Qcm9wc1wiO1xuZXhwb3J0IHsgT3B0aW9uYWxWcGNQcm9wcyB9IGZyb20gXCIuL2dlbmVyYXRlZC1zdHJ1Y3RzL09wdGlvbmFsVnBjUHJvcHNcIjtcbiJdfQ==
@@ -0,0 +1,13 @@
1
+ import * as lambda from 'aws-cdk-lib/aws-lambda';
2
+ import { Construct } from 'constructs';
3
+ /**
4
+ * Props for AssetsDeploymentFunction
5
+ */
6
+ export interface AssetsDeploymentFunctionProps extends lambda.FunctionOptions {
7
+ }
8
+ /**
9
+ * An AWS Lambda function which executes src/lambdas/assets-deployment/assets-deployment.
10
+ */
11
+ export declare class AssetsDeploymentFunction extends lambda.Function {
12
+ constructor(scope: Construct, id: string, props?: AssetsDeploymentFunctionProps);
13
+ }
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AssetsDeploymentFunction = void 0;
4
+ // ~~ Generated by projen. To modify, edit .projenrc.ts and run "pnpm dlx projen".
5
+ const path = require("path");
6
+ const lambda = require("aws-cdk-lib/aws-lambda");
7
+ /**
8
+ * An AWS Lambda function which executes src/lambdas/assets-deployment/assets-deployment.
9
+ */
10
+ class AssetsDeploymentFunction extends lambda.Function {
11
+ constructor(scope, id, props) {
12
+ super(scope, id, {
13
+ description: 'src/lambdas/assets-deployment/assets-deployment.lambda.ts',
14
+ ...props,
15
+ runtime: new lambda.Runtime('nodejs20.x', lambda.RuntimeFamily.NODEJS),
16
+ handler: 'index.handler',
17
+ code: lambda.Code.fromAsset(path.join(__dirname, '../../../assets/lambdas/assets-deployment/assets-deployment.lambda')),
18
+ });
19
+ this.addEnvironment('AWS_NODEJS_CONNECTION_REUSE_ENABLED', '1', { removeInEdge: true });
20
+ }
21
+ }
22
+ exports.AssetsDeploymentFunction = AssetsDeploymentFunction;
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzZXRzLWRlcGxveW1lbnQtZnVuY3Rpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGFtYmRhcy9hc3NldHMtZGVwbG95bWVudC9hc3NldHMtZGVwbG95bWVudC1mdW5jdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxrRkFBa0Y7QUFDbEYsNkJBQTZCO0FBQzdCLGlEQUFpRDtBQVNqRDs7R0FFRztBQUNILE1BQWEsd0JBQXlCLFNBQVEsTUFBTSxDQUFDLFFBQVE7SUFDM0QsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUFxQztRQUM3RSxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsRUFBRTtZQUNmLFdBQVcsRUFBRSwyREFBMkQ7WUFDeEUsR0FBRyxLQUFLO1lBQ1IsT0FBTyxFQUFFLElBQUksTUFBTSxDQUFDLE9BQU8sQ0FBQyxZQUFZLEVBQUUsTUFBTSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUM7WUFDdEUsT0FBTyxFQUFFLGVBQWU7WUFDeEIsSUFBSSxFQUFFLE1BQU0sQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLG9FQUFvRSxDQUFDLENBQUM7U0FDeEgsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxDQUFDLGNBQWMsQ0FBQyxxQ0FBcUMsRUFBRSxHQUFHLEVBQUUsRUFBRSxZQUFZLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUMxRixDQUFDO0NBQ0Y7QUFYRCw0REFXQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIH5+IEdlbmVyYXRlZCBieSBwcm9qZW4uIFRvIG1vZGlmeSwgZWRpdCAucHJvamVucmMudHMgYW5kIHJ1biBcInBucG0gZGx4IHByb2plblwiLlxuaW1wb3J0ICogYXMgcGF0aCBmcm9tICdwYXRoJztcbmltcG9ydCAqIGFzIGxhbWJkYSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtbGFtYmRhJztcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xuXG4vKipcbiAqIFByb3BzIGZvciBBc3NldHNEZXBsb3ltZW50RnVuY3Rpb25cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBBc3NldHNEZXBsb3ltZW50RnVuY3Rpb25Qcm9wcyBleHRlbmRzIGxhbWJkYS5GdW5jdGlvbk9wdGlvbnMge1xufVxuXG4vKipcbiAqIEFuIEFXUyBMYW1iZGEgZnVuY3Rpb24gd2hpY2ggZXhlY3V0ZXMgc3JjL2xhbWJkYXMvYXNzZXRzLWRlcGxveW1lbnQvYXNzZXRzLWRlcGxveW1lbnQuXG4gKi9cbmV4cG9ydCBjbGFzcyBBc3NldHNEZXBsb3ltZW50RnVuY3Rpb24gZXh0ZW5kcyBsYW1iZGEuRnVuY3Rpb24ge1xuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wcz86IEFzc2V0c0RlcGxveW1lbnRGdW5jdGlvblByb3BzKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkLCB7XG4gICAgICBkZXNjcmlwdGlvbjogJ3NyYy9sYW1iZGFzL2Fzc2V0cy1kZXBsb3ltZW50L2Fzc2V0cy1kZXBsb3ltZW50LmxhbWJkYS50cycsXG4gICAgICAuLi5wcm9wcyxcbiAgICAgIHJ1bnRpbWU6IG5ldyBsYW1iZGEuUnVudGltZSgnbm9kZWpzMjAueCcsIGxhbWJkYS5SdW50aW1lRmFtaWx5Lk5PREVKUyksXG4gICAgICBoYW5kbGVyOiAnaW5kZXguaGFuZGxlcicsXG4gICAgICBjb2RlOiBsYW1iZGEuQ29kZS5mcm9tQXNzZXQocGF0aC5qb2luKF9fZGlybmFtZSwgJy4uLy4uLy4uL2Fzc2V0cy9sYW1iZGFzL2Fzc2V0cy1kZXBsb3ltZW50L2Fzc2V0cy1kZXBsb3ltZW50LmxhbWJkYScpKSxcbiAgICB9KTtcbiAgICB0aGlzLmFkZEVudmlyb25tZW50KCdBV1NfTk9ERUpTX0NPTk5FQ1RJT05fUkVVU0VfRU5BQkxFRCcsICcxJywgeyByZW1vdmVJbkVkZ2U6IHRydWUgfSk7XG4gIH1cbn0iXX0=
@@ -0,0 +1,2 @@
1
+ import type { CloudFormationCustomResourceHandler } from "aws-lambda";
2
+ export declare const handler: CloudFormationCustomResourceHandler;