aws-cdk 2.1004.0 → 2.1006.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 (207) hide show
  1. package/THIRD_PARTY_LICENSES +31 -31
  2. package/build-info.json +2 -2
  3. package/db.json.gz +0 -0
  4. package/lib/api/aws-auth/account-cache.d.ts +1 -1
  5. package/lib/api/aws-auth/account-cache.js +1 -1
  6. package/lib/api/aws-auth/awscli-compatible.d.ts +1 -1
  7. package/lib/api/aws-auth/awscli-compatible.js +9 -10
  8. package/lib/api/aws-auth/credential-plugins.d.ts +1 -1
  9. package/lib/api/aws-auth/credential-plugins.js +6 -7
  10. package/lib/api/aws-auth/provider-caching.d.ts +1 -1
  11. package/lib/api/aws-auth/provider-caching.js +1 -1
  12. package/lib/api/aws-auth/sdk-logger.d.ts +2 -2
  13. package/lib/api/aws-auth/sdk-logger.js +3 -4
  14. package/lib/api/aws-auth/sdk-provider.d.ts +4 -4
  15. package/lib/api/aws-auth/sdk-provider.js +11 -13
  16. package/lib/api/aws-auth/sdk.d.ts +12 -12
  17. package/lib/api/aws-auth/sdk.js +8 -9
  18. package/lib/api/aws-auth/tracing.js +3 -4
  19. package/lib/api/aws-auth/user-agent.js +4 -5
  20. package/lib/api/bootstrap/bootstrap-environment.d.ts +2 -2
  21. package/lib/api/bootstrap/bootstrap-environment.js +42 -46
  22. package/lib/api/bootstrap/bootstrap-props.d.ts +3 -3
  23. package/lib/api/bootstrap/bootstrap-props.js +1 -1
  24. package/lib/api/bootstrap/deploy-bootstrap.d.ts +4 -4
  25. package/lib/api/bootstrap/deploy-bootstrap.js +11 -14
  26. package/lib/api/bootstrap/legacy-template.d.ts +1 -1
  27. package/lib/api/bootstrap/legacy-template.js +1 -1
  28. package/lib/api/{evaluate-cloudformation-template.d.ts → cloudformation/evaluate-cloudformation-template.d.ts} +10 -9
  29. package/lib/api/cloudformation/evaluate-cloudformation-template.js +440 -0
  30. package/lib/api/cloudformation/index.d.ts +4 -0
  31. package/lib/api/cloudformation/index.js +21 -0
  32. package/lib/api/{deployments → cloudformation}/nested-stack-helpers.d.ts +1 -1
  33. package/lib/api/cloudformation/nested-stack-helpers.js +86 -0
  34. package/lib/api/cloudformation/stack-helpers.d.ts +96 -0
  35. package/lib/api/cloudformation/stack-helpers.js +158 -0
  36. package/lib/api/{util → cloudformation}/template-body-parameter.d.ts +4 -3
  37. package/lib/api/cloudformation/template-body-parameter.js +104 -0
  38. package/lib/api/context.js +3 -3
  39. package/lib/api/cxapp/cloud-assembly.js +13 -15
  40. package/lib/api/cxapp/cloud-executable.d.ts +3 -3
  41. package/lib/api/cxapp/cloud-executable.js +4 -5
  42. package/lib/api/cxapp/environments.d.ts +3 -3
  43. package/lib/api/cxapp/environments.js +4 -4
  44. package/lib/api/cxapp/exec.d.ts +4 -4
  45. package/lib/api/cxapp/exec.js +20 -23
  46. package/lib/api/deployments/asset-publishing.d.ts +2 -4
  47. package/lib/api/deployments/asset-publishing.js +24 -31
  48. package/lib/api/deployments/assets.d.ts +3 -3
  49. package/lib/api/deployments/assets.js +12 -13
  50. package/lib/api/deployments/{cloudformation.d.ts → cfn-api.d.ts} +5 -102
  51. package/lib/api/deployments/cfn-api.js +438 -0
  52. package/lib/api/deployments/checks.d.ts +2 -2
  53. package/lib/api/deployments/checks.js +12 -13
  54. package/lib/api/deployments/deploy-stack.d.ts +6 -7
  55. package/lib/api/deployments/deploy-stack.js +69 -80
  56. package/lib/api/deployments/deployment-result.js +3 -3
  57. package/lib/api/deployments/deployments.d.ts +7 -7
  58. package/lib/api/deployments/deployments.js +35 -42
  59. package/lib/api/deployments/hotswap-deployments.d.ts +7 -5
  60. package/lib/api/deployments/hotswap-deployments.js +160 -82
  61. package/lib/api/deployments/index.d.ts +0 -2
  62. package/lib/api/deployments/index.js +1 -3
  63. package/lib/api/environment/environment-access.d.ts +6 -6
  64. package/lib/api/environment/environment-access.js +18 -20
  65. package/lib/api/environment/environment-resources.d.ts +1 -1
  66. package/lib/api/environment/environment-resources.js +17 -19
  67. package/lib/api/environment/index.d.ts +1 -0
  68. package/lib/api/environment/index.js +2 -1
  69. package/lib/api/environment/placeholders.js +23 -0
  70. package/lib/api/garbage-collection/garbage-collector.d.ts +4 -4
  71. package/lib/api/garbage-collection/garbage-collector.js +57 -67
  72. package/lib/api/garbage-collection/progress-printer.d.ts +2 -2
  73. package/lib/api/garbage-collection/progress-printer.js +7 -7
  74. package/lib/api/garbage-collection/stack-refresh.d.ts +2 -2
  75. package/lib/api/garbage-collection/stack-refresh.js +12 -15
  76. package/lib/api/hotswap/appsync-mapping-templates.d.ts +4 -3
  77. package/lib/api/hotswap/appsync-mapping-templates.js +32 -27
  78. package/lib/api/hotswap/code-build-projects.d.ts +4 -3
  79. package/lib/api/hotswap/code-build-projects.js +19 -12
  80. package/lib/api/hotswap/common.d.ts +27 -64
  81. package/lib/api/hotswap/common.js +40 -82
  82. package/lib/api/hotswap/ecs-services.d.ts +4 -3
  83. package/lib/api/hotswap/ecs-services.js +44 -25
  84. package/lib/api/hotswap/lambda-functions.d.ts +4 -3
  85. package/lib/api/hotswap/lambda-functions.js +61 -75
  86. package/lib/api/hotswap/s3-bucket-deployments.d.ts +5 -9
  87. package/lib/api/hotswap/s3-bucket-deployments.js +26 -21
  88. package/lib/api/hotswap/stepfunctions-state-machines.d.ts +4 -3
  89. package/lib/api/hotswap/stepfunctions-state-machines.js +15 -9
  90. package/lib/api/logs/find-cloudwatch-logs.d.ts +1 -1
  91. package/lib/api/logs/find-cloudwatch-logs.js +7 -9
  92. package/lib/api/logs/logs-monitor.d.ts +2 -2
  93. package/lib/api/logs/logs-monitor.js +5 -8
  94. package/lib/api/plugin/plugin.js +6 -10
  95. package/lib/api/resource-import/importer.d.ts +10 -5
  96. package/lib/api/resource-import/importer.js +23 -29
  97. package/lib/api/resource-import/migrator.d.ts +4 -4
  98. package/lib/api/resource-import/migrator.js +6 -6
  99. package/lib/api/settings.d.ts +0 -3
  100. package/lib/api/settings.js +4 -40
  101. package/lib/api/stack-events/stack-activity-monitor.d.ts +1 -2
  102. package/lib/api/stack-events/stack-activity-monitor.js +14 -37
  103. package/lib/api/stack-events/stack-event-poller.js +9 -10
  104. package/lib/api/stack-events/stack-progress-monitor.d.ts +1 -1
  105. package/lib/api/stack-events/stack-progress-monitor.js +1 -1
  106. package/lib/api/toolkit-info.d.ts +3 -3
  107. package/lib/api/toolkit-info.js +20 -24
  108. package/lib/{tree.d.ts → api/tree.d.ts} +3 -3
  109. package/lib/api/tree.js +37 -0
  110. package/lib/api/util/rwlock.js +4 -4
  111. package/lib/api/work-graph/work-graph-builder.d.ts +2 -2
  112. package/lib/api/work-graph/work-graph-builder.js +4 -4
  113. package/lib/api/work-graph/work-graph-types.d.ts +2 -2
  114. package/lib/api/work-graph/work-graph-types.js +1 -1
  115. package/lib/api/work-graph/work-graph.d.ts +2 -2
  116. package/lib/api/work-graph/work-graph.js +13 -15
  117. package/lib/cli/activity-printer/base.d.ts +3 -3
  118. package/lib/cli/activity-printer/base.js +6 -8
  119. package/lib/cli/activity-printer/current.d.ts +2 -1
  120. package/lib/cli/activity-printer/current.js +7 -11
  121. package/lib/cli/activity-printer/history.d.ts +2 -1
  122. package/lib/cli/activity-printer/history.js +2 -3
  123. package/lib/cli/cdk-toolkit.d.ts +9 -15
  124. package/lib/cli/cdk-toolkit.js +90 -73
  125. package/lib/cli/ci-systems.d.ts +29 -0
  126. package/lib/cli/ci-systems.js +61 -0
  127. package/lib/cli/cli-config.js +3 -3
  128. package/lib/cli/cli.d.ts +1 -1
  129. package/lib/cli/cli.js +69 -52
  130. package/lib/cli/convert-to-user-input.js +110 -111
  131. package/lib/{toolkit → cli/io-host}/cli-io-host.d.ts +22 -3
  132. package/lib/cli/io-host/cli-io-host.js +356 -0
  133. package/lib/cli/io-host/index.d.ts +1 -0
  134. package/lib/{toolkit/error.js → cli/io-host/index.js} +2 -2
  135. package/lib/cli/messages.d.ts +2 -2
  136. package/lib/cli/messages.js +2 -3
  137. package/lib/cli/parse-command-line-arguments.js +1 -1
  138. package/lib/cli/pretty-print-error.d.ts +1 -0
  139. package/lib/cli/pretty-print-error.js +35 -0
  140. package/lib/cli/root-dir.js +4 -4
  141. package/lib/cli/user-configuration.js +57 -14
  142. package/lib/cli/user-input.js +1 -1
  143. package/lib/cli/util/npm.js +3 -3
  144. package/lib/cli/util/yargs-helpers.d.ts +1 -1
  145. package/lib/cli/util/yargs-helpers.js +3 -3
  146. package/lib/cli/version.js +4 -4
  147. package/lib/commands/context.d.ts +1 -1
  148. package/lib/commands/context.js +7 -8
  149. package/lib/commands/diff.d.ts +50 -0
  150. package/lib/commands/diff.js +215 -0
  151. package/lib/commands/init/index.d.ts +1 -0
  152. package/lib/commands/init/index.js +18 -0
  153. package/lib/commands/init/init-hooks.js +63 -0
  154. package/lib/commands/init/init.js +435 -0
  155. package/lib/{os.js → commands/init/os.js} +4 -4
  156. package/lib/{list-stacks.d.ts → commands/list-stacks.d.ts} +1 -1
  157. package/lib/{list-stacks.js → commands/list-stacks.js} +2 -2
  158. package/lib/commands/migrate.d.ts +1 -1
  159. package/lib/commands/migrate.js +29 -32
  160. package/lib/context-providers/ami.d.ts +4 -2
  161. package/lib/context-providers/ami.js +8 -8
  162. package/lib/context-providers/availability-zones.d.ts +4 -2
  163. package/lib/context-providers/availability-zones.js +4 -4
  164. package/lib/context-providers/cc-api-provider.d.ts +9 -13
  165. package/lib/context-providers/cc-api-provider.js +88 -66
  166. package/lib/context-providers/endpoint-service-availability-zones.d.ts +4 -2
  167. package/lib/context-providers/endpoint-service-availability-zones.js +6 -6
  168. package/lib/context-providers/hosted-zones.d.ts +5 -3
  169. package/lib/context-providers/hosted-zones.js +11 -11
  170. package/lib/context-providers/index.d.ts +22 -8
  171. package/lib/context-providers/index.js +35 -17
  172. package/lib/context-providers/keys.d.ts +4 -2
  173. package/lib/context-providers/keys.js +8 -8
  174. package/lib/context-providers/load-balancers.d.ts +3 -3
  175. package/lib/context-providers/load-balancers.js +15 -18
  176. package/lib/context-providers/security-groups.js +10 -12
  177. package/lib/context-providers/ssm-parameters.d.ts +4 -2
  178. package/lib/context-providers/ssm-parameters.js +7 -7
  179. package/lib/context-providers/vpcs.d.ts +4 -2
  180. package/lib/context-providers/vpcs.js +14 -15
  181. package/lib/index.js +115212 -114237
  182. package/lib/init-templates/.init-version.json +1 -1
  183. package/lib/init-templates/.recommended-feature-flags.json +2 -1
  184. package/lib/legacy-exports-source.d.ts +4 -5
  185. package/lib/legacy-exports-source.js +6 -7
  186. package/lib/legacy-logging-source.js +1 -1
  187. package/lib/logging.d.ts +3 -3
  188. package/lib/logging.js +38 -36
  189. package/lib/notices.d.ts +22 -18
  190. package/lib/notices.js +67 -73
  191. package/package.json +18 -20
  192. package/lib/api/deployments/cloudformation.js +0 -597
  193. package/lib/api/deployments/nested-stack-helpers.js +0 -88
  194. package/lib/api/evaluate-cloudformation-template.js +0 -443
  195. package/lib/api/util/placeholders.js +0 -24
  196. package/lib/api/util/template-body-parameter.js +0 -103
  197. package/lib/diff.d.ts +0 -28
  198. package/lib/diff.js +0 -165
  199. package/lib/init-hooks.js +0 -63
  200. package/lib/init.js +0 -437
  201. package/lib/toolkit/cli-io-host.js +0 -324
  202. package/lib/toolkit/error.d.ts +0 -1
  203. package/lib/tree.js +0 -40
  204. /package/lib/api/{util → environment}/placeholders.d.ts +0 -0
  205. /package/lib/{init-hooks.d.ts → commands/init/init-hooks.d.ts} +0 -0
  206. /package/lib/{init.d.ts → commands/init/init.d.ts} +0 -0
  207. /package/lib/{os.d.ts → commands/init/os.d.ts} +0 -0
@@ -79,4 +79,4 @@ function legacyBootstrapTemplate(params) {
79
79
  },
80
80
  };
81
81
  }
82
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGVnYWN5LXRlbXBsYXRlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsibGVnYWN5LXRlbXBsYXRlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBRUEsMERBNEVDO0FBOUVELHVEQUEyRztBQUUzRyxTQUFnQix1QkFBdUIsQ0FBQyxNQUErQjtJQUNyRSxPQUFPO1FBQ0wsV0FBVyxFQUFFLDZJQUE2STtRQUMxSixVQUFVLEVBQUU7WUFDVixpQ0FBaUMsRUFBRTtnQkFDakMsWUFBWSxFQUFFO29CQUNaLE1BQU0sQ0FBQyw4QkFBOEIsSUFBSSxNQUFNLENBQUMsOEJBQThCLEtBQUssU0FBUyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLE9BQU87b0JBQy9HLE1BQU07aUJBQ1A7YUFDRjtTQUNGO1FBQ0QsU0FBUyxFQUFFO1lBQ1QsYUFBYSxFQUFFO2dCQUNiLElBQUksRUFBRSxpQkFBaUI7Z0JBQ3ZCLFVBQVUsRUFBRTtvQkFDVixVQUFVLEVBQUUsTUFBTSxDQUFDLFVBQVU7b0JBQzdCLGFBQWEsRUFBRSxTQUFTO29CQUN4QixnQkFBZ0IsRUFBRTt3QkFDaEIsaUNBQWlDLEVBQUUsQ0FBQztnQ0FDbEMsNkJBQTZCLEVBQUU7b0NBQzdCLFlBQVksRUFBRSxTQUFTO29DQUN2QixjQUFjLEVBQUUsTUFBTSxDQUFDLFFBQVE7aUNBQ2hDOzZCQUNGLENBQUM7cUJBQ0g7b0JBQ0QsOEJBQThCLEVBQUU7d0JBQzlCLFFBQVEsRUFBRTs0QkFDUixtQ0FBbUM7NEJBQ25DO2dDQUNFLGVBQWUsRUFBRSxJQUFJO2dDQUNyQixpQkFBaUIsRUFBRSxJQUFJO2dDQUN2QixnQkFBZ0IsRUFBRSxJQUFJO2dDQUN0QixxQkFBcUIsRUFBRSxJQUFJOzZCQUM1Qjs0QkFDRCxFQUFFLEdBQUcsRUFBRSxjQUFjLEVBQUU7eUJBQ3hCO3FCQUNGO2lCQUNGO2FBQ0Y7WUFDRCxtQkFBbUIsRUFBRTtnQkFDbkIsSUFBSSxFQUFFLHVCQUF1QjtnQkFDN0IsVUFBVSxFQUFFO29CQUNWLE1BQU0sRUFBRSxFQUFFLEdBQUcsRUFBRSxlQUFlLEVBQUU7b0JBQ2hDLGNBQWMsRUFBRTt3QkFDZCxFQUFFLEVBQUUsZUFBZTt3QkFDbkIsT0FBTyxFQUFFLFlBQVk7d0JBQ3JCLFNBQVMsRUFBRTs0QkFDVDtnQ0FDRSxHQUFHLEVBQUUsc0JBQXNCO2dDQUMzQixNQUFNLEVBQUUsTUFBTTtnQ0FDZCxNQUFNLEVBQUUsTUFBTTtnQ0FDZCxRQUFRLEVBQUU7b0NBQ1IsRUFBRSxTQUFTLEVBQUUsc0JBQXNCLEVBQUU7b0NBQ3JDLEVBQUUsU0FBUyxFQUFFLHdCQUF3QixFQUFFO2lDQUN4QztnQ0FDRCxTQUFTLEVBQUU7b0NBQ1QsSUFBSSxFQUFFLEVBQUUscUJBQXFCLEVBQUUsT0FBTyxFQUFFO2lDQUN6QztnQ0FDRCxTQUFTLEVBQUUsR0FBRzs2QkFDZjt5QkFDRjtxQkFDRjtpQkFDRjthQUNGO1NBQ0Y7UUFDRCxPQUFPLEVBQUU7WUFDUCxDQUFDLG9DQUFrQixDQUFDLEVBQUU7Z0JBQ3BCLFdBQVcsRUFBRSwwREFBMEQ7Z0JBQ3ZFLEtBQUssRUFBRSxFQUFFLEdBQUcsRUFBRSxlQUFlLEVBQUU7YUFDaEM7WUFDRCxDQUFDLDJDQUF5QixDQUFDLEVBQUU7Z0JBQzNCLFdBQVcsRUFBRSxpRUFBaUU7Z0JBQzlFLEtBQUssRUFBRSxFQUFFLFlBQVksRUFBRSxDQUFDLGVBQWUsRUFBRSxvQkFBb0IsQ0FBQyxFQUFFO2FBQ2pFO1NBQ0Y7S0FDRixDQUFDO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJvb3RzdHJhcHBpbmdQYXJhbWV0ZXJzLCBCVUNLRVRfRE9NQUlOX05BTUVfT1VUUFVULCBCVUNLRVRfTkFNRV9PVVRQVVQgfSBmcm9tICcuL2Jvb3RzdHJhcC1wcm9wcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBsZWdhY3lCb290c3RyYXBUZW1wbGF0ZShwYXJhbXM6IEJvb3RzdHJhcHBpbmdQYXJhbWV0ZXJzKTogYW55IHtcbiAgcmV0dXJuIHtcbiAgICBEZXNjcmlwdGlvbjogJ1RoZSBDREsgVG9vbGtpdCBTdGFjay4gSXQgd2FzIGNyZWF0ZWQgYnkgYGNkayBib290c3RyYXBgIGFuZCBtYW5hZ2VzIHJlc291cmNlcyBuZWNlc3NhcnkgZm9yIG1hbmFnaW5nIHlvdXIgQ2xvdWQgQXBwbGljYXRpb25zIHdpdGggQVdTIENESy4nLFxuICAgIENvbmRpdGlvbnM6IHtcbiAgICAgIFVzZVB1YmxpY0FjY2Vzc0Jsb2NrQ29uZmlndXJhdGlvbjoge1xuICAgICAgICAnRm46OkVxdWFscyc6IFtcbiAgICAgICAgICBwYXJhbXMucHVibGljQWNjZXNzQmxvY2tDb25maWd1cmF0aW9uIHx8IHBhcmFtcy5wdWJsaWNBY2Nlc3NCbG9ja0NvbmZpZ3VyYXRpb24gPT09IHVuZGVmaW5lZCA/ICd0cnVlJyA6ICdmYWxzZScsXG4gICAgICAgICAgJ3RydWUnLFxuICAgICAgICBdLFxuICAgICAgfSxcbiAgICB9LFxuICAgIFJlc291cmNlczoge1xuICAgICAgU3RhZ2luZ0J1Y2tldDoge1xuICAgICAgICBUeXBlOiAnQVdTOjpTMzo6QnVja2V0JyxcbiAgICAgICAgUHJvcGVydGllczoge1xuICAgICAgICAgIEJ1Y2tldE5hbWU6IHBhcmFtcy5idWNrZXROYW1lLFxuICAgICAgICAgIEFjY2Vzc0NvbnRyb2w6ICdQcml2YXRlJyxcbiAgICAgICAgICBCdWNrZXRFbmNyeXB0aW9uOiB7XG4gICAgICAgICAgICBTZXJ2ZXJTaWRlRW5jcnlwdGlvbkNvbmZpZ3VyYXRpb246IFt7XG4gICAgICAgICAgICAgIFNlcnZlclNpZGVFbmNyeXB0aW9uQnlEZWZhdWx0OiB7XG4gICAgICAgICAgICAgICAgU1NFQWxnb3JpdGhtOiAnYXdzOmttcycsXG4gICAgICAgICAgICAgICAgS01TTWFzdGVyS2V5SUQ6IHBhcmFtcy5rbXNLZXlJZCxcbiAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIH1dLFxuICAgICAgICAgIH0sXG4gICAgICAgICAgUHVibGljQWNjZXNzQmxvY2tDb25maWd1cmF0aW9uOiB7XG4gICAgICAgICAgICAnRm46OklmJzogW1xuICAgICAgICAgICAgICAnVXNlUHVibGljQWNjZXNzQmxvY2tDb25maWd1cmF0aW9uJyxcbiAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIEJsb2NrUHVibGljQWNsczogdHJ1ZSxcbiAgICAgICAgICAgICAgICBCbG9ja1B1YmxpY1BvbGljeTogdHJ1ZSxcbiAgICAgICAgICAgICAgICBJZ25vcmVQdWJsaWNBY2xzOiB0cnVlLFxuICAgICAgICAgICAgICAgIFJlc3RyaWN0UHVibGljQnVja2V0czogdHJ1ZSxcbiAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgeyBSZWY6ICdBV1M6Ok5vVmFsdWUnIH0sXG4gICAgICAgICAgICBdLFxuICAgICAgICAgIH0sXG4gICAgICAgIH0sXG4gICAgICB9LFxuICAgICAgU3RhZ2luZ0J1Y2tldFBvbGljeToge1xuICAgICAgICBUeXBlOiAnQVdTOjpTMzo6QnVja2V0UG9saWN5JyxcbiAgICAgICAgUHJvcGVydGllczoge1xuICAgICAgICAgIEJ1Y2tldDogeyBSZWY6ICdTdGFnaW5nQnVja2V0JyB9LFxuICAgICAgICAgIFBvbGljeURvY3VtZW50OiB7XG4gICAgICAgICAgICBJZDogJ0FjY2Vzc0NvbnRyb2wnLFxuICAgICAgICAgICAgVmVyc2lvbjogJzIwMTItMTAtMTcnLFxuICAgICAgICAgICAgU3RhdGVtZW50OiBbXG4gICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICBTaWQ6ICdBbGxvd1NTTFJlcXVlc3RzT25seScsXG4gICAgICAgICAgICAgICAgQWN0aW9uOiAnczM6KicsXG4gICAgICAgICAgICAgICAgRWZmZWN0OiAnRGVueScsXG4gICAgICAgICAgICAgICAgUmVzb3VyY2U6IFtcbiAgICAgICAgICAgICAgICAgIHsgJ0ZuOjpTdWInOiAnJHtTdGFnaW5nQnVja2V0LkFybn0nIH0sXG4gICAgICAgICAgICAgICAgICB7ICdGbjo6U3ViJzogJyR7U3RhZ2luZ0J1Y2tldC5Bcm59LyonIH0sXG4gICAgICAgICAgICAgICAgXSxcbiAgICAgICAgICAgICAgICBDb25kaXRpb246IHtcbiAgICAgICAgICAgICAgICAgIEJvb2w6IHsgJ2F3czpTZWN1cmVUcmFuc3BvcnQnOiAnZmFsc2UnIH0sXG4gICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgICBQcmluY2lwYWw6ICcqJyxcbiAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIF0sXG4gICAgICAgICAgfSxcbiAgICAgICAgfSxcbiAgICAgIH0sXG4gICAgfSxcbiAgICBPdXRwdXRzOiB7XG4gICAgICBbQlVDS0VUX05BTUVfT1VUUFVUXToge1xuICAgICAgICBEZXNjcmlwdGlvbjogJ1RoZSBuYW1lIG9mIHRoZSBTMyBidWNrZXQgb3duZWQgYnkgdGhlIENESyB0b29sa2l0IHN0YWNrJyxcbiAgICAgICAgVmFsdWU6IHsgUmVmOiAnU3RhZ2luZ0J1Y2tldCcgfSxcbiAgICAgIH0sXG4gICAgICBbQlVDS0VUX0RPTUFJTl9OQU1FX09VVFBVVF06IHtcbiAgICAgICAgRGVzY3JpcHRpb246ICdUaGUgZG9tYWluIG5hbWUgb2YgdGhlIFMzIGJ1Y2tldCBvd25lZCBieSB0aGUgQ0RLIHRvb2xraXQgc3RhY2snLFxuICAgICAgICBWYWx1ZTogeyAnRm46OkdldEF0dCc6IFsnU3RhZ2luZ0J1Y2tldCcsICdSZWdpb25hbERvbWFpbk5hbWUnXSB9LFxuICAgICAgfSxcbiAgICB9LFxuICB9O1xufVxuIl19
82
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGVnYWN5LXRlbXBsYXRlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsibGVnYWN5LXRlbXBsYXRlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBR0EsMERBNEVDO0FBOUVELHVEQUFrRjtBQUVsRixTQUFnQix1QkFBdUIsQ0FBQyxNQUErQjtJQUNyRSxPQUFPO1FBQ0wsV0FBVyxFQUFFLDZJQUE2STtRQUMxSixVQUFVLEVBQUU7WUFDVixpQ0FBaUMsRUFBRTtnQkFDakMsWUFBWSxFQUFFO29CQUNaLE1BQU0sQ0FBQyw4QkFBOEIsSUFBSSxNQUFNLENBQUMsOEJBQThCLEtBQUssU0FBUyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLE9BQU87b0JBQy9HLE1BQU07aUJBQ1A7YUFDRjtTQUNGO1FBQ0QsU0FBUyxFQUFFO1lBQ1QsYUFBYSxFQUFFO2dCQUNiLElBQUksRUFBRSxpQkFBaUI7Z0JBQ3ZCLFVBQVUsRUFBRTtvQkFDVixVQUFVLEVBQUUsTUFBTSxDQUFDLFVBQVU7b0JBQzdCLGFBQWEsRUFBRSxTQUFTO29CQUN4QixnQkFBZ0IsRUFBRTt3QkFDaEIsaUNBQWlDLEVBQUUsQ0FBQztnQ0FDbEMsNkJBQTZCLEVBQUU7b0NBQzdCLFlBQVksRUFBRSxTQUFTO29DQUN2QixjQUFjLEVBQUUsTUFBTSxDQUFDLFFBQVE7aUNBQ2hDOzZCQUNGLENBQUM7cUJBQ0g7b0JBQ0QsOEJBQThCLEVBQUU7d0JBQzlCLFFBQVEsRUFBRTs0QkFDUixtQ0FBbUM7NEJBQ25DO2dDQUNFLGVBQWUsRUFBRSxJQUFJO2dDQUNyQixpQkFBaUIsRUFBRSxJQUFJO2dDQUN2QixnQkFBZ0IsRUFBRSxJQUFJO2dDQUN0QixxQkFBcUIsRUFBRSxJQUFJOzZCQUM1Qjs0QkFDRCxFQUFFLEdBQUcsRUFBRSxjQUFjLEVBQUU7eUJBQ3hCO3FCQUNGO2lCQUNGO2FBQ0Y7WUFDRCxtQkFBbUIsRUFBRTtnQkFDbkIsSUFBSSxFQUFFLHVCQUF1QjtnQkFDN0IsVUFBVSxFQUFFO29CQUNWLE1BQU0sRUFBRSxFQUFFLEdBQUcsRUFBRSxlQUFlLEVBQUU7b0JBQ2hDLGNBQWMsRUFBRTt3QkFDZCxFQUFFLEVBQUUsZUFBZTt3QkFDbkIsT0FBTyxFQUFFLFlBQVk7d0JBQ3JCLFNBQVMsRUFBRTs0QkFDVDtnQ0FDRSxHQUFHLEVBQUUsc0JBQXNCO2dDQUMzQixNQUFNLEVBQUUsTUFBTTtnQ0FDZCxNQUFNLEVBQUUsTUFBTTtnQ0FDZCxRQUFRLEVBQUU7b0NBQ1IsRUFBRSxTQUFTLEVBQUUsc0JBQXNCLEVBQUU7b0NBQ3JDLEVBQUUsU0FBUyxFQUFFLHdCQUF3QixFQUFFO2lDQUN4QztnQ0FDRCxTQUFTLEVBQUU7b0NBQ1QsSUFBSSxFQUFFLEVBQUUscUJBQXFCLEVBQUUsT0FBTyxFQUFFO2lDQUN6QztnQ0FDRCxTQUFTLEVBQUUsR0FBRzs2QkFDZjt5QkFDRjtxQkFDRjtpQkFDRjthQUNGO1NBQ0Y7UUFDRCxPQUFPLEVBQUU7WUFDUCxDQUFDLG9DQUFrQixDQUFDLEVBQUU7Z0JBQ3BCLFdBQVcsRUFBRSwwREFBMEQ7Z0JBQ3ZFLEtBQUssRUFBRSxFQUFFLEdBQUcsRUFBRSxlQUFlLEVBQUU7YUFDaEM7WUFDRCxDQUFDLDJDQUF5QixDQUFDLEVBQUU7Z0JBQzNCLFdBQVcsRUFBRSxpRUFBaUU7Z0JBQzlFLEtBQUssRUFBRSxFQUFFLFlBQVksRUFBRSxDQUFDLGVBQWUsRUFBRSxvQkFBb0IsQ0FBQyxFQUFFO2FBQ2pFO1NBQ0Y7S0FDRixDQUFDO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgQm9vdHN0cmFwcGluZ1BhcmFtZXRlcnMgfSBmcm9tICcuL2Jvb3RzdHJhcC1wcm9wcyc7XG5pbXBvcnQgeyBCVUNLRVRfRE9NQUlOX05BTUVfT1VUUFVULCBCVUNLRVRfTkFNRV9PVVRQVVQgfSBmcm9tICcuL2Jvb3RzdHJhcC1wcm9wcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBsZWdhY3lCb290c3RyYXBUZW1wbGF0ZShwYXJhbXM6IEJvb3RzdHJhcHBpbmdQYXJhbWV0ZXJzKTogYW55IHtcbiAgcmV0dXJuIHtcbiAgICBEZXNjcmlwdGlvbjogJ1RoZSBDREsgVG9vbGtpdCBTdGFjay4gSXQgd2FzIGNyZWF0ZWQgYnkgYGNkayBib290c3RyYXBgIGFuZCBtYW5hZ2VzIHJlc291cmNlcyBuZWNlc3NhcnkgZm9yIG1hbmFnaW5nIHlvdXIgQ2xvdWQgQXBwbGljYXRpb25zIHdpdGggQVdTIENESy4nLFxuICAgIENvbmRpdGlvbnM6IHtcbiAgICAgIFVzZVB1YmxpY0FjY2Vzc0Jsb2NrQ29uZmlndXJhdGlvbjoge1xuICAgICAgICAnRm46OkVxdWFscyc6IFtcbiAgICAgICAgICBwYXJhbXMucHVibGljQWNjZXNzQmxvY2tDb25maWd1cmF0aW9uIHx8IHBhcmFtcy5wdWJsaWNBY2Nlc3NCbG9ja0NvbmZpZ3VyYXRpb24gPT09IHVuZGVmaW5lZCA/ICd0cnVlJyA6ICdmYWxzZScsXG4gICAgICAgICAgJ3RydWUnLFxuICAgICAgICBdLFxuICAgICAgfSxcbiAgICB9LFxuICAgIFJlc291cmNlczoge1xuICAgICAgU3RhZ2luZ0J1Y2tldDoge1xuICAgICAgICBUeXBlOiAnQVdTOjpTMzo6QnVja2V0JyxcbiAgICAgICAgUHJvcGVydGllczoge1xuICAgICAgICAgIEJ1Y2tldE5hbWU6IHBhcmFtcy5idWNrZXROYW1lLFxuICAgICAgICAgIEFjY2Vzc0NvbnRyb2w6ICdQcml2YXRlJyxcbiAgICAgICAgICBCdWNrZXRFbmNyeXB0aW9uOiB7XG4gICAgICAgICAgICBTZXJ2ZXJTaWRlRW5jcnlwdGlvbkNvbmZpZ3VyYXRpb246IFt7XG4gICAgICAgICAgICAgIFNlcnZlclNpZGVFbmNyeXB0aW9uQnlEZWZhdWx0OiB7XG4gICAgICAgICAgICAgICAgU1NFQWxnb3JpdGhtOiAnYXdzOmttcycsXG4gICAgICAgICAgICAgICAgS01TTWFzdGVyS2V5SUQ6IHBhcmFtcy5rbXNLZXlJZCxcbiAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIH1dLFxuICAgICAgICAgIH0sXG4gICAgICAgICAgUHVibGljQWNjZXNzQmxvY2tDb25maWd1cmF0aW9uOiB7XG4gICAgICAgICAgICAnRm46OklmJzogW1xuICAgICAgICAgICAgICAnVXNlUHVibGljQWNjZXNzQmxvY2tDb25maWd1cmF0aW9uJyxcbiAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIEJsb2NrUHVibGljQWNsczogdHJ1ZSxcbiAgICAgICAgICAgICAgICBCbG9ja1B1YmxpY1BvbGljeTogdHJ1ZSxcbiAgICAgICAgICAgICAgICBJZ25vcmVQdWJsaWNBY2xzOiB0cnVlLFxuICAgICAgICAgICAgICAgIFJlc3RyaWN0UHVibGljQnVja2V0czogdHJ1ZSxcbiAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgeyBSZWY6ICdBV1M6Ok5vVmFsdWUnIH0sXG4gICAgICAgICAgICBdLFxuICAgICAgICAgIH0sXG4gICAgICAgIH0sXG4gICAgICB9LFxuICAgICAgU3RhZ2luZ0J1Y2tldFBvbGljeToge1xuICAgICAgICBUeXBlOiAnQVdTOjpTMzo6QnVja2V0UG9saWN5JyxcbiAgICAgICAgUHJvcGVydGllczoge1xuICAgICAgICAgIEJ1Y2tldDogeyBSZWY6ICdTdGFnaW5nQnVja2V0JyB9LFxuICAgICAgICAgIFBvbGljeURvY3VtZW50OiB7XG4gICAgICAgICAgICBJZDogJ0FjY2Vzc0NvbnRyb2wnLFxuICAgICAgICAgICAgVmVyc2lvbjogJzIwMTItMTAtMTcnLFxuICAgICAgICAgICAgU3RhdGVtZW50OiBbXG4gICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICBTaWQ6ICdBbGxvd1NTTFJlcXVlc3RzT25seScsXG4gICAgICAgICAgICAgICAgQWN0aW9uOiAnczM6KicsXG4gICAgICAgICAgICAgICAgRWZmZWN0OiAnRGVueScsXG4gICAgICAgICAgICAgICAgUmVzb3VyY2U6IFtcbiAgICAgICAgICAgICAgICAgIHsgJ0ZuOjpTdWInOiAnJHtTdGFnaW5nQnVja2V0LkFybn0nIH0sXG4gICAgICAgICAgICAgICAgICB7ICdGbjo6U3ViJzogJyR7U3RhZ2luZ0J1Y2tldC5Bcm59LyonIH0sXG4gICAgICAgICAgICAgICAgXSxcbiAgICAgICAgICAgICAgICBDb25kaXRpb246IHtcbiAgICAgICAgICAgICAgICAgIEJvb2w6IHsgJ2F3czpTZWN1cmVUcmFuc3BvcnQnOiAnZmFsc2UnIH0sXG4gICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgICBQcmluY2lwYWw6ICcqJyxcbiAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIF0sXG4gICAgICAgICAgfSxcbiAgICAgICAgfSxcbiAgICAgIH0sXG4gICAgfSxcbiAgICBPdXRwdXRzOiB7XG4gICAgICBbQlVDS0VUX05BTUVfT1VUUFVUXToge1xuICAgICAgICBEZXNjcmlwdGlvbjogJ1RoZSBuYW1lIG9mIHRoZSBTMyBidWNrZXQgb3duZWQgYnkgdGhlIENESyB0b29sa2l0IHN0YWNrJyxcbiAgICAgICAgVmFsdWU6IHsgUmVmOiAnU3RhZ2luZ0J1Y2tldCcgfSxcbiAgICAgIH0sXG4gICAgICBbQlVDS0VUX0RPTUFJTl9OQU1FX09VVFBVVF06IHtcbiAgICAgICAgRGVzY3JpcHRpb246ICdUaGUgZG9tYWluIG5hbWUgb2YgdGhlIFMzIGJ1Y2tldCBvd25lZCBieSB0aGUgQ0RLIHRvb2xraXQgc3RhY2snLFxuICAgICAgICBWYWx1ZTogeyAnRm46OkdldEF0dCc6IFsnU3RhZ2luZ0J1Y2tldCcsICdSZWdpb25hbERvbWFpbk5hbWUnXSB9LFxuICAgICAgfSxcbiAgICB9LFxuICB9O1xufVxuIl19
@@ -1,6 +1,9 @@
1
+ import type { CloudFormationStackArtifact } from '@aws-cdk/cx-api';
1
2
  import type { Export, StackResourceSummary } from '@aws-sdk/client-cloudformation';
2
- import type { SDK } from './aws-auth';
3
- import type { NestedStackTemplates } from './deployments';
3
+ import type { SDK } from '../aws-auth';
4
+ import type { NestedStackTemplates } from './nested-stack-helpers';
5
+ import type { Template } from './stack-helpers';
6
+ import type { ResourceMetadata } from '../../../../@aws-cdk/tmp-toolkit-helpers/src/api/resource-metadata';
4
7
  export interface ListStackResources {
5
8
  listStackResources(): Promise<StackResourceSummary[]>;
6
9
  }
@@ -33,8 +36,9 @@ export interface ResourceDefinition {
33
36
  };
34
37
  }
35
38
  export interface EvaluateCloudFormationTemplateProps {
36
- readonly stackName: string;
37
- readonly template: Template;
39
+ readonly stackArtifact: CloudFormationStackArtifact;
40
+ readonly stackName?: string;
41
+ readonly template?: Template;
38
42
  readonly parameters: {
39
43
  [parameterName: string]: string;
40
44
  };
@@ -47,6 +51,7 @@ export interface EvaluateCloudFormationTemplateProps {
47
51
  };
48
52
  }
49
53
  export declare class EvaluateCloudFormationTemplate {
54
+ readonly stackArtifact: CloudFormationStackArtifact;
50
55
  private readonly stackName;
51
56
  private readonly template;
52
57
  private readonly context;
@@ -68,6 +73,7 @@ export declare class EvaluateCloudFormationTemplate {
68
73
  findReferencesTo(logicalId: string): Array<ResourceDefinition>;
69
74
  evaluateCfnExpression(cfnExpression: any): Promise<any>;
70
75
  getResourceProperty(logicalId: string, propertyName: string): any;
76
+ metadataFor(logicalId: string): ResourceMetadata | undefined;
71
77
  private references;
72
78
  private parseIntrinsic;
73
79
  private findRefTarget;
@@ -77,8 +83,3 @@ export declare class EvaluateCloudFormationTemplate {
77
83
  private getServiceOfResource;
78
84
  private getResourceTypeArnPartOfResource;
79
85
  }
80
- export type Template = {
81
- [section: string]: {
82
- [headings: string]: any;
83
- };
84
- };
@@ -0,0 +1,440 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.EvaluateCloudFormationTemplate = exports.CfnEvaluationException = exports.LazyLookupExport = exports.LookupExportError = exports.LazyListStackResources = void 0;
4
+ const api_1 = require("../../../../@aws-cdk/tmp-toolkit-helpers/src/api");
5
+ const resource_metadata_1 = require("../../../../@aws-cdk/tmp-toolkit-helpers/src/api/resource-metadata");
6
+ class LazyListStackResources {
7
+ constructor(sdk, stackName) {
8
+ this.sdk = sdk;
9
+ this.stackName = stackName;
10
+ }
11
+ async listStackResources() {
12
+ if (this.stackResources === undefined) {
13
+ this.stackResources = this.sdk.cloudFormation().listStackResources({
14
+ StackName: this.stackName,
15
+ });
16
+ }
17
+ return this.stackResources;
18
+ }
19
+ }
20
+ exports.LazyListStackResources = LazyListStackResources;
21
+ class LookupExportError extends Error {
22
+ }
23
+ exports.LookupExportError = LookupExportError;
24
+ class LazyLookupExport {
25
+ constructor(sdk) {
26
+ this.sdk = sdk;
27
+ this.cachedExports = {};
28
+ }
29
+ async lookupExport(name) {
30
+ if (this.cachedExports[name]) {
31
+ return this.cachedExports[name];
32
+ }
33
+ for await (const cfnExport of this.listExports()) {
34
+ if (!cfnExport.Name) {
35
+ continue; // ignore any result that omits a name
36
+ }
37
+ this.cachedExports[cfnExport.Name] = cfnExport;
38
+ if (cfnExport.Name === name) {
39
+ return cfnExport;
40
+ }
41
+ }
42
+ return undefined; // export not found
43
+ }
44
+ // TODO: Paginate
45
+ async *listExports() {
46
+ let nextToken = undefined;
47
+ while (true) {
48
+ const response = await this.sdk.cloudFormation().listExports({ NextToken: nextToken });
49
+ for (const cfnExport of response.Exports ?? []) {
50
+ yield cfnExport;
51
+ }
52
+ if (!response.NextToken) {
53
+ return;
54
+ }
55
+ nextToken = response.NextToken;
56
+ }
57
+ }
58
+ }
59
+ exports.LazyLookupExport = LazyLookupExport;
60
+ class CfnEvaluationException extends Error {
61
+ }
62
+ exports.CfnEvaluationException = CfnEvaluationException;
63
+ class EvaluateCloudFormationTemplate {
64
+ constructor(props) {
65
+ this.stackArtifact = props.stackArtifact;
66
+ this.stackName = props.stackName ?? props.stackArtifact.stackName;
67
+ this.template = props.template ?? props.stackArtifact.template;
68
+ this.context = {
69
+ 'AWS::AccountId': props.account,
70
+ 'AWS::Region': props.region,
71
+ 'AWS::Partition': props.partition,
72
+ ...props.parameters,
73
+ };
74
+ this.account = props.account;
75
+ this.region = props.region;
76
+ this.partition = props.partition;
77
+ this.sdk = props.sdk;
78
+ // We need names of nested stack so we can evaluate cross stack references
79
+ this.nestedStacks = props.nestedStacks ?? {};
80
+ // The current resources of the Stack.
81
+ // We need them to figure out the physical name of a resource in case it wasn't specified by the user.
82
+ // We fetch it lazily, to save a service call, in case all hotswapped resources have their physical names set.
83
+ this.stackResources = new LazyListStackResources(this.sdk, this.stackName);
84
+ // CloudFormation Exports lookup to be able to resolve Fn::ImportValue intrinsics in template
85
+ this.lookupExport = new LazyLookupExport(this.sdk);
86
+ }
87
+ // clones current EvaluateCloudFormationTemplate object, but updates the stack name
88
+ async createNestedEvaluateCloudFormationTemplate(stackName, nestedTemplate, nestedStackParameters) {
89
+ const evaluatedParams = await this.evaluateCfnExpression(nestedStackParameters);
90
+ return new EvaluateCloudFormationTemplate({
91
+ stackArtifact: this.stackArtifact,
92
+ stackName,
93
+ template: nestedTemplate,
94
+ parameters: evaluatedParams,
95
+ account: this.account,
96
+ region: this.region,
97
+ partition: this.partition,
98
+ sdk: this.sdk,
99
+ nestedStacks: this.nestedStacks,
100
+ });
101
+ }
102
+ async establishResourcePhysicalName(logicalId, physicalNameInCfnTemplate) {
103
+ if (physicalNameInCfnTemplate != null) {
104
+ try {
105
+ return await this.evaluateCfnExpression(physicalNameInCfnTemplate);
106
+ }
107
+ catch (e) {
108
+ // If we can't evaluate the resource's name CloudFormation expression,
109
+ // just look it up in the currently deployed Stack
110
+ if (!(e instanceof CfnEvaluationException)) {
111
+ throw e;
112
+ }
113
+ }
114
+ }
115
+ return this.findPhysicalNameFor(logicalId);
116
+ }
117
+ async findPhysicalNameFor(logicalId) {
118
+ const stackResources = await this.stackResources.listStackResources();
119
+ return stackResources.find((sr) => sr.LogicalResourceId === logicalId)?.PhysicalResourceId;
120
+ }
121
+ async findLogicalIdForPhysicalName(physicalName) {
122
+ const stackResources = await this.stackResources.listStackResources();
123
+ return stackResources.find((sr) => sr.PhysicalResourceId === physicalName)?.LogicalResourceId;
124
+ }
125
+ findReferencesTo(logicalId) {
126
+ const ret = new Array();
127
+ for (const [resourceLogicalId, resourceDef] of Object.entries(this.template?.Resources ?? {})) {
128
+ if (logicalId !== resourceLogicalId && this.references(logicalId, resourceDef)) {
129
+ ret.push({
130
+ ...resourceDef,
131
+ LogicalId: resourceLogicalId,
132
+ });
133
+ }
134
+ }
135
+ return ret;
136
+ }
137
+ async evaluateCfnExpression(cfnExpression) {
138
+ const self = this;
139
+ /**
140
+ * Evaluates CloudFormation intrinsic functions
141
+ *
142
+ * Note that supported intrinsic functions are documented in README.md -- please update
143
+ * list of supported functions when adding new evaluations
144
+ *
145
+ * See: https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/intrinsic-function-reference.html
146
+ */
147
+ class CfnIntrinsics {
148
+ evaluateIntrinsic(intrinsic) {
149
+ const intrinsicFunc = this[intrinsic.name];
150
+ if (!intrinsicFunc) {
151
+ throw new CfnEvaluationException(`CloudFormation function ${intrinsic.name} is not supported`);
152
+ }
153
+ const argsAsArray = Array.isArray(intrinsic.args) ? intrinsic.args : [intrinsic.args];
154
+ return intrinsicFunc.apply(this, argsAsArray);
155
+ }
156
+ async 'Fn::Join'(separator, args) {
157
+ const evaluatedArgs = await self.evaluateCfnExpression(args);
158
+ return evaluatedArgs.join(separator);
159
+ }
160
+ async 'Fn::Split'(separator, args) {
161
+ const evaluatedArgs = await self.evaluateCfnExpression(args);
162
+ return evaluatedArgs.split(separator);
163
+ }
164
+ async 'Fn::Select'(index, args) {
165
+ const evaluatedArgs = await self.evaluateCfnExpression(args);
166
+ return evaluatedArgs[index];
167
+ }
168
+ async Ref(logicalId) {
169
+ const refTarget = await self.findRefTarget(logicalId);
170
+ if (refTarget) {
171
+ return refTarget;
172
+ }
173
+ else {
174
+ throw new CfnEvaluationException(`Parameter or resource '${logicalId}' could not be found for evaluation`);
175
+ }
176
+ }
177
+ async 'Fn::GetAtt'(logicalId, attributeName) {
178
+ // ToDo handle the 'logicalId.attributeName' form of Fn::GetAtt
179
+ const attrValue = await self.findGetAttTarget(logicalId, attributeName);
180
+ if (attrValue) {
181
+ return attrValue;
182
+ }
183
+ else {
184
+ throw new CfnEvaluationException(`Attribute '${attributeName}' of resource '${logicalId}' could not be found for evaluation`);
185
+ }
186
+ }
187
+ async 'Fn::Sub'(template, explicitPlaceholders) {
188
+ const placeholders = explicitPlaceholders ? await self.evaluateCfnExpression(explicitPlaceholders) : {};
189
+ return asyncGlobalReplace(template, /\${([^}]*)}/g, (key) => {
190
+ if (key in placeholders) {
191
+ return placeholders[key];
192
+ }
193
+ else {
194
+ const splitKey = key.split('.');
195
+ return splitKey.length === 1 ? this.Ref(key) : this['Fn::GetAtt'](splitKey[0], splitKey.slice(1).join('.'));
196
+ }
197
+ });
198
+ }
199
+ async 'Fn::ImportValue'(name) {
200
+ const exported = await self.lookupExport.lookupExport(name);
201
+ if (!exported) {
202
+ throw new CfnEvaluationException(`Export '${name}' could not be found for evaluation`);
203
+ }
204
+ if (!exported.Value) {
205
+ throw new CfnEvaluationException(`Export '${name}' exists without a value`);
206
+ }
207
+ return exported.Value;
208
+ }
209
+ }
210
+ if (cfnExpression == null) {
211
+ return cfnExpression;
212
+ }
213
+ if (Array.isArray(cfnExpression)) {
214
+ // Small arrays in practice
215
+ // eslint-disable-next-line @cdklabs/promiseall-no-unbounded-parallelism
216
+ return Promise.all(cfnExpression.map((expr) => this.evaluateCfnExpression(expr)));
217
+ }
218
+ if (typeof cfnExpression === 'object') {
219
+ const intrinsic = this.parseIntrinsic(cfnExpression);
220
+ if (intrinsic) {
221
+ return new CfnIntrinsics().evaluateIntrinsic(intrinsic);
222
+ }
223
+ else {
224
+ const ret = {};
225
+ for (const [key, val] of Object.entries(cfnExpression)) {
226
+ ret[key] = await this.evaluateCfnExpression(val);
227
+ }
228
+ return ret;
229
+ }
230
+ }
231
+ return cfnExpression;
232
+ }
233
+ getResourceProperty(logicalId, propertyName) {
234
+ return this.template.Resources?.[logicalId]?.Properties?.[propertyName];
235
+ }
236
+ metadataFor(logicalId) {
237
+ return (0, resource_metadata_1.resourceMetadata)(this.stackArtifact, logicalId);
238
+ }
239
+ references(logicalId, templateElement) {
240
+ if (typeof templateElement === 'string') {
241
+ return logicalId === templateElement;
242
+ }
243
+ if (templateElement == null) {
244
+ return false;
245
+ }
246
+ if (Array.isArray(templateElement)) {
247
+ return templateElement.some((el) => this.references(logicalId, el));
248
+ }
249
+ if (typeof templateElement === 'object') {
250
+ return Object.values(templateElement).some((el) => this.references(logicalId, el));
251
+ }
252
+ return false;
253
+ }
254
+ parseIntrinsic(x) {
255
+ const keys = Object.keys(x);
256
+ if (keys.length === 1 && (keys[0].startsWith('Fn::') || keys[0] === 'Ref')) {
257
+ return {
258
+ name: keys[0],
259
+ args: x[keys[0]],
260
+ };
261
+ }
262
+ return undefined;
263
+ }
264
+ async findRefTarget(logicalId) {
265
+ // first, check to see if the Ref is a Parameter who's value we have
266
+ if (logicalId === 'AWS::URLSuffix') {
267
+ if (!this.cachedUrlSuffix) {
268
+ this.cachedUrlSuffix = await this.sdk.getUrlSuffix(this.region);
269
+ }
270
+ return this.cachedUrlSuffix;
271
+ }
272
+ // Try finding the ref in the passed in parameters
273
+ const parameterTarget = this.context[logicalId];
274
+ if (parameterTarget) {
275
+ return parameterTarget;
276
+ }
277
+ // If not in the passed in parameters, see if there is a default value in the template parameter that was not passed in
278
+ const defaultParameterValue = this.template.Parameters?.[logicalId]?.Default;
279
+ if (defaultParameterValue) {
280
+ return defaultParameterValue;
281
+ }
282
+ // if it's not a Parameter, we need to search in the current Stack resources
283
+ return this.findGetAttTarget(logicalId);
284
+ }
285
+ async findGetAttTarget(logicalId, attribute) {
286
+ // Handle case where the attribute is referencing a stack output (used in nested stacks to share parameters)
287
+ // See https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/quickref-cloudformation.html#w2ab1c17c23c19b5
288
+ if (logicalId === 'Outputs' && attribute) {
289
+ return this.evaluateCfnExpression(this.template.Outputs[attribute]?.Value);
290
+ }
291
+ const stackResources = await this.stackResources.listStackResources();
292
+ const foundResource = stackResources.find((sr) => sr.LogicalResourceId === logicalId);
293
+ if (!foundResource) {
294
+ return undefined;
295
+ }
296
+ if (foundResource.ResourceType == 'AWS::CloudFormation::Stack' && attribute?.startsWith('Outputs.')) {
297
+ const dependantStack = this.findNestedStack(logicalId, this.nestedStacks);
298
+ if (!dependantStack || !dependantStack.physicalName) {
299
+ // this is a newly created nested stack and cannot be hotswapped
300
+ return undefined;
301
+ }
302
+ const evaluateCfnTemplate = await this.createNestedEvaluateCloudFormationTemplate(dependantStack.physicalName, dependantStack.generatedTemplate, dependantStack.generatedTemplate.Parameters);
303
+ // Split Outputs.<refName> into 'Outputs' and '<refName>' and recursively call evaluate
304
+ return evaluateCfnTemplate.evaluateCfnExpression({
305
+ 'Fn::GetAtt': attribute.split(/\.(.*)/s),
306
+ });
307
+ }
308
+ // now, we need to format the appropriate identifier depending on the resource type,
309
+ // and the requested attribute name
310
+ return this.formatResourceAttribute(foundResource, attribute);
311
+ }
312
+ findNestedStack(logicalId, nestedStacks) {
313
+ for (const nestedStackLogicalId of Object.keys(nestedStacks)) {
314
+ if (nestedStackLogicalId === logicalId) {
315
+ return nestedStacks[nestedStackLogicalId];
316
+ }
317
+ const checkInNestedChildStacks = this.findNestedStack(logicalId, nestedStacks[nestedStackLogicalId].nestedStackTemplates);
318
+ if (checkInNestedChildStacks)
319
+ return checkInNestedChildStacks;
320
+ }
321
+ return undefined;
322
+ }
323
+ formatResourceAttribute(resource, attribute) {
324
+ const physicalId = resource.PhysicalResourceId;
325
+ // no attribute means Ref expression, for which we use the physical ID directly
326
+ if (!attribute) {
327
+ return physicalId;
328
+ }
329
+ const resourceTypeFormats = RESOURCE_TYPE_ATTRIBUTES_FORMATS[resource.ResourceType];
330
+ if (!resourceTypeFormats) {
331
+ throw new CfnEvaluationException(`We don't support attributes of the '${resource.ResourceType}' resource. This is a CDK limitation. ` +
332
+ 'Please report it at https://github.com/aws/aws-cdk/issues/new/choose');
333
+ }
334
+ const attributeFmtFunc = resourceTypeFormats[attribute];
335
+ if (!attributeFmtFunc) {
336
+ throw new CfnEvaluationException(`We don't support the '${attribute}' attribute of the '${resource.ResourceType}' resource. This is a CDK limitation. ` +
337
+ 'Please report it at https://github.com/aws/aws-cdk/issues/new/choose');
338
+ }
339
+ const service = this.getServiceOfResource(resource);
340
+ const resourceTypeArnPart = this.getResourceTypeArnPartOfResource(resource);
341
+ return attributeFmtFunc({
342
+ partition: this.partition,
343
+ service,
344
+ region: this.region,
345
+ account: this.account,
346
+ resourceType: resourceTypeArnPart,
347
+ resourceName: physicalId,
348
+ });
349
+ }
350
+ getServiceOfResource(resource) {
351
+ return resource.ResourceType.split('::')[1].toLowerCase();
352
+ }
353
+ getResourceTypeArnPartOfResource(resource) {
354
+ const resourceType = resource.ResourceType;
355
+ const specialCaseResourceType = RESOURCE_TYPE_SPECIAL_NAMES[resourceType]?.resourceType;
356
+ return specialCaseResourceType
357
+ ? specialCaseResourceType
358
+ : // this is the default case
359
+ resourceType.split('::')[2].toLowerCase();
360
+ }
361
+ }
362
+ exports.EvaluateCloudFormationTemplate = EvaluateCloudFormationTemplate;
363
+ /**
364
+ * Usually, we deduce the names of the service and the resource type used to format the ARN from the CloudFormation resource type.
365
+ * For a CFN type like AWS::Service::ResourceType, the second segment becomes the service name, and the third the resource type
366
+ * (after converting both of them to lowercase).
367
+ * However, some resource types break this simple convention, and we need to special-case them.
368
+ * This map is for storing those cases.
369
+ */
370
+ const RESOURCE_TYPE_SPECIAL_NAMES = {
371
+ 'AWS::Events::EventBus': {
372
+ resourceType: 'event-bus',
373
+ },
374
+ };
375
+ const RESOURCE_TYPE_ATTRIBUTES_FORMATS = {
376
+ 'AWS::IAM::Role': { Arn: iamArnFmt },
377
+ 'AWS::IAM::User': { Arn: iamArnFmt },
378
+ 'AWS::IAM::Group': { Arn: iamArnFmt },
379
+ 'AWS::S3::Bucket': { Arn: s3ArnFmt },
380
+ 'AWS::Lambda::Function': { Arn: stdColonResourceArnFmt },
381
+ 'AWS::Events::EventBus': {
382
+ Arn: stdSlashResourceArnFmt,
383
+ // the name attribute of the EventBus is the same as the Ref
384
+ Name: (parts) => parts.resourceName,
385
+ },
386
+ 'AWS::DynamoDB::Table': { Arn: stdSlashResourceArnFmt },
387
+ 'AWS::AppSync::GraphQLApi': { ApiId: appsyncGraphQlApiApiIdFmt },
388
+ 'AWS::AppSync::FunctionConfiguration': {
389
+ FunctionId: appsyncGraphQlFunctionIDFmt,
390
+ },
391
+ 'AWS::AppSync::DataSource': { Name: appsyncGraphQlDataSourceNameFmt },
392
+ 'AWS::KMS::Key': { Arn: stdSlashResourceArnFmt },
393
+ };
394
+ function iamArnFmt(parts) {
395
+ // we skip region for IAM resources
396
+ return `arn:${parts.partition}:${parts.service}::${parts.account}:${parts.resourceType}/${parts.resourceName}`;
397
+ }
398
+ function s3ArnFmt(parts) {
399
+ // we skip account, region and resourceType for S3 resources
400
+ return `arn:${parts.partition}:${parts.service}:::${parts.resourceName}`;
401
+ }
402
+ function stdColonResourceArnFmt(parts) {
403
+ // this is a standard format for ARNs like: arn:aws:service:region:account:resourceType:resourceName
404
+ return `arn:${parts.partition}:${parts.service}:${parts.region}:${parts.account}:${parts.resourceType}:${parts.resourceName}`;
405
+ }
406
+ function stdSlashResourceArnFmt(parts) {
407
+ // this is a standard format for ARNs like: arn:aws:service:region:account:resourceType/resourceName
408
+ return `arn:${parts.partition}:${parts.service}:${parts.region}:${parts.account}:${parts.resourceType}/${parts.resourceName}`;
409
+ }
410
+ function appsyncGraphQlApiApiIdFmt(parts) {
411
+ // arn:aws:appsync:us-east-1:111111111111:apis/<apiId>
412
+ return parts.resourceName.split('/')[1];
413
+ }
414
+ function appsyncGraphQlFunctionIDFmt(parts) {
415
+ // arn:aws:appsync:us-east-1:111111111111:apis/<apiId>/functions/<functionId>
416
+ return parts.resourceName.split('/')[3];
417
+ }
418
+ function appsyncGraphQlDataSourceNameFmt(parts) {
419
+ // arn:aws:appsync:us-east-1:111111111111:apis/<apiId>/datasources/<name>
420
+ return parts.resourceName.split('/')[3];
421
+ }
422
+ async function asyncGlobalReplace(str, regex, cb) {
423
+ if (!regex.global) {
424
+ throw new api_1.ToolkitError('Regex must be created with /g flag');
425
+ }
426
+ const ret = new Array();
427
+ let start = 0;
428
+ while (true) {
429
+ const match = regex.exec(str);
430
+ if (!match) {
431
+ break;
432
+ }
433
+ ret.push(str.substring(start, match.index));
434
+ ret.push(await cb(match[1]));
435
+ start = regex.lastIndex;
436
+ }
437
+ ret.push(str.slice(start));
438
+ return ret.join('');
439
+ }
440
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"evaluate-cloudformation-template.js","sourceRoot":"","sources":["evaluate-cloudformation-template.ts"],"names":[],"mappings":"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","sourcesContent":["import type { CloudFormationStackArtifact } from '@aws-cdk/cx-api';\nimport type { Export, ListExportsCommandOutput, StackResourceSummary } from '@aws-sdk/client-cloudformation';\nimport type { SDK } from '../aws-auth';\nimport type { NestedStackTemplates } from './nested-stack-helpers';\nimport type { Template } from './stack-helpers';\nimport { ToolkitError } from '../../../../@aws-cdk/tmp-toolkit-helpers/src/api';\nimport { resourceMetadata } from '../../../../@aws-cdk/tmp-toolkit-helpers/src/api/resource-metadata';\nimport type { ResourceMetadata } from '../../../../@aws-cdk/tmp-toolkit-helpers/src/api/resource-metadata';\n\nexport interface ListStackResources {\n  listStackResources(): Promise<StackResourceSummary[]>;\n}\n\nexport class LazyListStackResources implements ListStackResources {\n  private stackResources: Promise<StackResourceSummary[]> | undefined;\n\n  constructor(\n    private readonly sdk: SDK,\n    private readonly stackName: string,\n  ) {\n  }\n\n  public async listStackResources(): Promise<StackResourceSummary[]> {\n    if (this.stackResources === undefined) {\n      this.stackResources = this.sdk.cloudFormation().listStackResources({\n        StackName: this.stackName,\n      });\n    }\n    return this.stackResources;\n  }\n}\n\nexport interface LookupExport {\n  lookupExport(name: string): Promise<Export | undefined>;\n}\n\nexport class LookupExportError extends Error {\n}\n\nexport class LazyLookupExport implements LookupExport {\n  private cachedExports: { [name: string]: Export } = {};\n\n  constructor(private readonly sdk: SDK) {\n  }\n\n  async lookupExport(name: string): Promise<Export | undefined> {\n    if (this.cachedExports[name]) {\n      return this.cachedExports[name];\n    }\n\n    for await (const cfnExport of this.listExports()) {\n      if (!cfnExport.Name) {\n        continue; // ignore any result that omits a name\n      }\n      this.cachedExports[cfnExport.Name] = cfnExport;\n\n      if (cfnExport.Name === name) {\n        return cfnExport;\n      }\n    }\n\n    return undefined; // export not found\n  }\n\n  // TODO: Paginate\n  private async *listExports() {\n    let nextToken: string | undefined = undefined;\n    while (true) {\n      const response: ListExportsCommandOutput = await this.sdk.cloudFormation().listExports({ NextToken: nextToken });\n      for (const cfnExport of response.Exports ?? []) {\n        yield cfnExport;\n      }\n\n      if (!response.NextToken) {\n        return;\n      }\n      nextToken = response.NextToken;\n    }\n  }\n}\n\nexport class CfnEvaluationException extends Error {\n}\n\nexport interface ResourceDefinition {\n  readonly LogicalId: string;\n  readonly Type: string;\n  readonly Properties: { [p: string]: any };\n}\n\nexport interface EvaluateCloudFormationTemplateProps {\n  readonly stackArtifact: CloudFormationStackArtifact;\n  readonly stackName?: string;\n  readonly template?: Template;\n  readonly parameters: { [parameterName: string]: string };\n  readonly account: string;\n  readonly region: string;\n  readonly partition: string;\n  readonly sdk: SDK;\n  readonly nestedStacks?: {\n    [nestedStackLogicalId: string]: NestedStackTemplates;\n  };\n}\n\nexport class EvaluateCloudFormationTemplate {\n  public readonly stackArtifact: CloudFormationStackArtifact;\n  private readonly stackName: string;\n  private readonly template: Template;\n  private readonly context: { [k: string]: any };\n  private readonly account: string;\n  private readonly region: string;\n  private readonly partition: string;\n  private readonly sdk: SDK;\n  private readonly nestedStacks: {\n    [nestedStackLogicalId: string]: NestedStackTemplates;\n  };\n  private readonly stackResources: ListStackResources;\n  private readonly lookupExport: LookupExport;\n\n  private cachedUrlSuffix: string | undefined;\n\n  constructor(props: EvaluateCloudFormationTemplateProps) {\n    this.stackArtifact = props.stackArtifact;\n    this.stackName = props.stackName ?? props.stackArtifact.stackName;\n    this.template = props.template ?? props.stackArtifact.template;\n    this.context = {\n      'AWS::AccountId': props.account,\n      'AWS::Region': props.region,\n      'AWS::Partition': props.partition,\n      ...props.parameters,\n    };\n    this.account = props.account;\n    this.region = props.region;\n    this.partition = props.partition;\n    this.sdk = props.sdk;\n\n    // We need names of nested stack so we can evaluate cross stack references\n    this.nestedStacks = props.nestedStacks ?? {};\n\n    // The current resources of the Stack.\n    // We need them to figure out the physical name of a resource in case it wasn't specified by the user.\n    // We fetch it lazily, to save a service call, in case all hotswapped resources have their physical names set.\n    this.stackResources = new LazyListStackResources(this.sdk, this.stackName);\n\n    // CloudFormation Exports lookup to be able to resolve Fn::ImportValue intrinsics in template\n    this.lookupExport = new LazyLookupExport(this.sdk);\n  }\n\n  // clones current EvaluateCloudFormationTemplate object, but updates the stack name\n  public async createNestedEvaluateCloudFormationTemplate(\n    stackName: string,\n    nestedTemplate: Template,\n    nestedStackParameters: { [parameterName: string]: any },\n  ) {\n    const evaluatedParams = await this.evaluateCfnExpression(nestedStackParameters);\n    return new EvaluateCloudFormationTemplate({\n      stackArtifact: this.stackArtifact,\n      stackName,\n      template: nestedTemplate,\n      parameters: evaluatedParams,\n      account: this.account,\n      region: this.region,\n      partition: this.partition,\n      sdk: this.sdk,\n      nestedStacks: this.nestedStacks,\n    });\n  }\n\n  public async establishResourcePhysicalName(\n    logicalId: string,\n    physicalNameInCfnTemplate: any,\n  ): Promise<string | undefined> {\n    if (physicalNameInCfnTemplate != null) {\n      try {\n        return await this.evaluateCfnExpression(physicalNameInCfnTemplate);\n      } catch (e) {\n        // If we can't evaluate the resource's name CloudFormation expression,\n        // just look it up in the currently deployed Stack\n        if (!(e instanceof CfnEvaluationException)) {\n          throw e;\n        }\n      }\n    }\n    return this.findPhysicalNameFor(logicalId);\n  }\n\n  public async findPhysicalNameFor(logicalId: string): Promise<string | undefined> {\n    const stackResources = await this.stackResources.listStackResources();\n    return stackResources.find((sr) => sr.LogicalResourceId === logicalId)?.PhysicalResourceId;\n  }\n\n  public async findLogicalIdForPhysicalName(physicalName: string): Promise<string | undefined> {\n    const stackResources = await this.stackResources.listStackResources();\n    return stackResources.find((sr) => sr.PhysicalResourceId === physicalName)?.LogicalResourceId;\n  }\n\n  public findReferencesTo(logicalId: string): Array<ResourceDefinition> {\n    const ret = new Array<ResourceDefinition>();\n    for (const [resourceLogicalId, resourceDef] of Object.entries(this.template?.Resources ?? {})) {\n      if (logicalId !== resourceLogicalId && this.references(logicalId, resourceDef)) {\n        ret.push({\n          ...(resourceDef as any),\n          LogicalId: resourceLogicalId,\n        });\n      }\n    }\n    return ret;\n  }\n\n  public async evaluateCfnExpression(cfnExpression: any): Promise<any> {\n    const self = this;\n    /**\n     * Evaluates CloudFormation intrinsic functions\n     *\n     * Note that supported intrinsic functions are documented in README.md -- please update\n     * list of supported functions when adding new evaluations\n     *\n     * See: https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/intrinsic-function-reference.html\n     */\n    class CfnIntrinsics {\n      public evaluateIntrinsic(intrinsic: Intrinsic): any {\n        const intrinsicFunc = (this as any)[intrinsic.name];\n        if (!intrinsicFunc) {\n          throw new CfnEvaluationException(`CloudFormation function ${intrinsic.name} is not supported`);\n        }\n\n        const argsAsArray = Array.isArray(intrinsic.args) ? intrinsic.args : [intrinsic.args];\n\n        return intrinsicFunc.apply(this, argsAsArray);\n      }\n\n      async 'Fn::Join'(separator: string, args: any[]): Promise<string> {\n        const evaluatedArgs = await self.evaluateCfnExpression(args);\n        return evaluatedArgs.join(separator);\n      }\n\n      async 'Fn::Split'(separator: string, args: any): Promise<string> {\n        const evaluatedArgs = await self.evaluateCfnExpression(args);\n        return evaluatedArgs.split(separator);\n      }\n\n      async 'Fn::Select'(index: number, args: any[]): Promise<string> {\n        const evaluatedArgs = await self.evaluateCfnExpression(args);\n        return evaluatedArgs[index];\n      }\n\n      async Ref(logicalId: string): Promise<string> {\n        const refTarget = await self.findRefTarget(logicalId);\n        if (refTarget) {\n          return refTarget;\n        } else {\n          throw new CfnEvaluationException(`Parameter or resource '${logicalId}' could not be found for evaluation`);\n        }\n      }\n\n      async 'Fn::GetAtt'(logicalId: string, attributeName: string): Promise<string> {\n        // ToDo handle the 'logicalId.attributeName' form of Fn::GetAtt\n        const attrValue = await self.findGetAttTarget(logicalId, attributeName);\n        if (attrValue) {\n          return attrValue;\n        } else {\n          throw new CfnEvaluationException(\n            `Attribute '${attributeName}' of resource '${logicalId}' could not be found for evaluation`,\n          );\n        }\n      }\n\n      async 'Fn::Sub'(template: string, explicitPlaceholders?: { [variable: string]: string }): Promise<string> {\n        const placeholders = explicitPlaceholders ? await self.evaluateCfnExpression(explicitPlaceholders) : {};\n\n        return asyncGlobalReplace(template, /\\${([^}]*)}/g, (key) => {\n          if (key in placeholders) {\n            return placeholders[key];\n          } else {\n            const splitKey = key.split('.');\n            return splitKey.length === 1 ? this.Ref(key) : this['Fn::GetAtt'](splitKey[0], splitKey.slice(1).join('.'));\n          }\n        });\n      }\n\n      async 'Fn::ImportValue'(name: string): Promise<string> {\n        const exported = await self.lookupExport.lookupExport(name);\n        if (!exported) {\n          throw new CfnEvaluationException(`Export '${name}' could not be found for evaluation`);\n        }\n        if (!exported.Value) {\n          throw new CfnEvaluationException(`Export '${name}' exists without a value`);\n        }\n        return exported.Value;\n      }\n    }\n\n    if (cfnExpression == null) {\n      return cfnExpression;\n    }\n\n    if (Array.isArray(cfnExpression)) {\n      // Small arrays in practice\n      // eslint-disable-next-line @cdklabs/promiseall-no-unbounded-parallelism\n      return Promise.all(cfnExpression.map((expr) => this.evaluateCfnExpression(expr)));\n    }\n\n    if (typeof cfnExpression === 'object') {\n      const intrinsic = this.parseIntrinsic(cfnExpression);\n      if (intrinsic) {\n        return new CfnIntrinsics().evaluateIntrinsic(intrinsic);\n      } else {\n        const ret: { [key: string]: any } = {};\n        for (const [key, val] of Object.entries(cfnExpression)) {\n          ret[key] = await this.evaluateCfnExpression(val);\n        }\n        return ret;\n      }\n    }\n\n    return cfnExpression;\n  }\n\n  public getResourceProperty(logicalId: string, propertyName: string): any {\n    return this.template.Resources?.[logicalId]?.Properties?.[propertyName];\n  }\n\n  public metadataFor(logicalId: string): ResourceMetadata | undefined {\n    return resourceMetadata(this.stackArtifact, logicalId);\n  }\n\n  private references(logicalId: string, templateElement: any): boolean {\n    if (typeof templateElement === 'string') {\n      return logicalId === templateElement;\n    }\n\n    if (templateElement == null) {\n      return false;\n    }\n\n    if (Array.isArray(templateElement)) {\n      return templateElement.some((el) => this.references(logicalId, el));\n    }\n\n    if (typeof templateElement === 'object') {\n      return Object.values(templateElement).some((el) => this.references(logicalId, el));\n    }\n\n    return false;\n  }\n\n  private parseIntrinsic(x: any): Intrinsic | undefined {\n    const keys = Object.keys(x);\n    if (keys.length === 1 && (keys[0].startsWith('Fn::') || keys[0] === 'Ref')) {\n      return {\n        name: keys[0],\n        args: x[keys[0]],\n      };\n    }\n    return undefined;\n  }\n\n  private async findRefTarget(logicalId: string): Promise<string | undefined> {\n    // first, check to see if the Ref is a Parameter who's value we have\n    if (logicalId === 'AWS::URLSuffix') {\n      if (!this.cachedUrlSuffix) {\n        this.cachedUrlSuffix = await this.sdk.getUrlSuffix(this.region);\n      }\n\n      return this.cachedUrlSuffix;\n    }\n\n    // Try finding the ref in the passed in parameters\n    const parameterTarget = this.context[logicalId];\n    if (parameterTarget) {\n      return parameterTarget;\n    }\n\n    // If not in the passed in parameters, see if there is a default value in the template parameter that was not passed in\n    const defaultParameterValue = this.template.Parameters?.[logicalId]?.Default;\n    if (defaultParameterValue) {\n      return defaultParameterValue;\n    }\n\n    // if it's not a Parameter, we need to search in the current Stack resources\n    return this.findGetAttTarget(logicalId);\n  }\n\n  private async findGetAttTarget(logicalId: string, attribute?: string): Promise<string | undefined> {\n    // Handle case where the attribute is referencing a stack output (used in nested stacks to share parameters)\n    // See https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/quickref-cloudformation.html#w2ab1c17c23c19b5\n    if (logicalId === 'Outputs' && attribute) {\n      return this.evaluateCfnExpression(this.template.Outputs[attribute]?.Value);\n    }\n\n    const stackResources = await this.stackResources.listStackResources();\n    const foundResource = stackResources.find((sr) => sr.LogicalResourceId === logicalId);\n    if (!foundResource) {\n      return undefined;\n    }\n\n    if (foundResource.ResourceType == 'AWS::CloudFormation::Stack' && attribute?.startsWith('Outputs.')) {\n      const dependantStack = this.findNestedStack(logicalId, this.nestedStacks);\n      if (!dependantStack || !dependantStack.physicalName) {\n        // this is a newly created nested stack and cannot be hotswapped\n        return undefined;\n      }\n      const evaluateCfnTemplate = await this.createNestedEvaluateCloudFormationTemplate(\n        dependantStack.physicalName,\n        dependantStack.generatedTemplate,\n        dependantStack.generatedTemplate.Parameters!,\n      );\n\n      // Split Outputs.<refName> into 'Outputs' and '<refName>' and recursively call evaluate\n      return evaluateCfnTemplate.evaluateCfnExpression({\n        'Fn::GetAtt': attribute.split(/\\.(.*)/s),\n      });\n    }\n    // now, we need to format the appropriate identifier depending on the resource type,\n    // and the requested attribute name\n    return this.formatResourceAttribute(foundResource, attribute);\n  }\n\n  private findNestedStack(\n    logicalId: string,\n    nestedStacks: {\n      [nestedStackLogicalId: string]: NestedStackTemplates;\n    },\n  ): NestedStackTemplates | undefined {\n    for (const nestedStackLogicalId of Object.keys(nestedStacks)) {\n      if (nestedStackLogicalId === logicalId) {\n        return nestedStacks[nestedStackLogicalId];\n      }\n      const checkInNestedChildStacks = this.findNestedStack(\n        logicalId,\n        nestedStacks[nestedStackLogicalId].nestedStackTemplates,\n      );\n      if (checkInNestedChildStacks) return checkInNestedChildStacks;\n    }\n    return undefined;\n  }\n\n  private formatResourceAttribute(resource: StackResourceSummary, attribute: string | undefined): string | undefined {\n    const physicalId = resource.PhysicalResourceId;\n\n    // no attribute means Ref expression, for which we use the physical ID directly\n    if (!attribute) {\n      return physicalId;\n    }\n\n    const resourceTypeFormats = RESOURCE_TYPE_ATTRIBUTES_FORMATS[resource.ResourceType!];\n    if (!resourceTypeFormats) {\n      throw new CfnEvaluationException(\n        `We don't support attributes of the '${resource.ResourceType}' resource. This is a CDK limitation. ` +\n          'Please report it at https://github.com/aws/aws-cdk/issues/new/choose',\n      );\n    }\n    const attributeFmtFunc = resourceTypeFormats[attribute];\n    if (!attributeFmtFunc) {\n      throw new CfnEvaluationException(\n        `We don't support the '${attribute}' attribute of the '${resource.ResourceType}' resource. This is a CDK limitation. ` +\n          'Please report it at https://github.com/aws/aws-cdk/issues/new/choose',\n      );\n    }\n    const service = this.getServiceOfResource(resource);\n    const resourceTypeArnPart = this.getResourceTypeArnPartOfResource(resource);\n    return attributeFmtFunc({\n      partition: this.partition,\n      service,\n      region: this.region,\n      account: this.account,\n      resourceType: resourceTypeArnPart,\n      resourceName: physicalId!,\n    });\n  }\n\n  private getServiceOfResource(resource: StackResourceSummary): string {\n    return resource.ResourceType!.split('::')[1].toLowerCase();\n  }\n\n  private getResourceTypeArnPartOfResource(resource: StackResourceSummary): string {\n    const resourceType = resource.ResourceType!;\n    const specialCaseResourceType = RESOURCE_TYPE_SPECIAL_NAMES[resourceType]?.resourceType;\n    return specialCaseResourceType\n      ? specialCaseResourceType\n      : // this is the default case\n      resourceType.split('::')[2].toLowerCase();\n  }\n}\n\ninterface ArnParts {\n  readonly partition: string;\n  readonly service: string;\n  readonly region: string;\n  readonly account: string;\n  readonly resourceType: string;\n  readonly resourceName: string;\n}\n\n/**\n * Usually, we deduce the names of the service and the resource type used to format the ARN from the CloudFormation resource type.\n * For a CFN type like AWS::Service::ResourceType, the second segment becomes the service name, and the third the resource type\n * (after converting both of them to lowercase).\n * However, some resource types break this simple convention, and we need to special-case them.\n * This map is for storing those cases.\n */\nconst RESOURCE_TYPE_SPECIAL_NAMES: {\n  [type: string]: { resourceType: string };\n} = {\n  'AWS::Events::EventBus': {\n    resourceType: 'event-bus',\n  },\n};\n\nconst RESOURCE_TYPE_ATTRIBUTES_FORMATS: {\n  [type: string]: { [attribute: string]: (parts: ArnParts) => string };\n} = {\n  'AWS::IAM::Role': { Arn: iamArnFmt },\n  'AWS::IAM::User': { Arn: iamArnFmt },\n  'AWS::IAM::Group': { Arn: iamArnFmt },\n  'AWS::S3::Bucket': { Arn: s3ArnFmt },\n  'AWS::Lambda::Function': { Arn: stdColonResourceArnFmt },\n  'AWS::Events::EventBus': {\n    Arn: stdSlashResourceArnFmt,\n    // the name attribute of the EventBus is the same as the Ref\n    Name: (parts) => parts.resourceName,\n  },\n  'AWS::DynamoDB::Table': { Arn: stdSlashResourceArnFmt },\n  'AWS::AppSync::GraphQLApi': { ApiId: appsyncGraphQlApiApiIdFmt },\n  'AWS::AppSync::FunctionConfiguration': {\n    FunctionId: appsyncGraphQlFunctionIDFmt,\n  },\n  'AWS::AppSync::DataSource': { Name: appsyncGraphQlDataSourceNameFmt },\n  'AWS::KMS::Key': { Arn: stdSlashResourceArnFmt },\n};\n\nfunction iamArnFmt(parts: ArnParts): string {\n  // we skip region for IAM resources\n  return `arn:${parts.partition}:${parts.service}::${parts.account}:${parts.resourceType}/${parts.resourceName}`;\n}\n\nfunction s3ArnFmt(parts: ArnParts): string {\n  // we skip account, region and resourceType for S3 resources\n  return `arn:${parts.partition}:${parts.service}:::${parts.resourceName}`;\n}\n\nfunction stdColonResourceArnFmt(parts: ArnParts): string {\n  // this is a standard format for ARNs like: arn:aws:service:region:account:resourceType:resourceName\n  return `arn:${parts.partition}:${parts.service}:${parts.region}:${parts.account}:${parts.resourceType}:${parts.resourceName}`;\n}\n\nfunction stdSlashResourceArnFmt(parts: ArnParts): string {\n  // this is a standard format for ARNs like: arn:aws:service:region:account:resourceType/resourceName\n  return `arn:${parts.partition}:${parts.service}:${parts.region}:${parts.account}:${parts.resourceType}/${parts.resourceName}`;\n}\n\nfunction appsyncGraphQlApiApiIdFmt(parts: ArnParts): string {\n  // arn:aws:appsync:us-east-1:111111111111:apis/<apiId>\n  return parts.resourceName.split('/')[1];\n}\n\nfunction appsyncGraphQlFunctionIDFmt(parts: ArnParts): string {\n  // arn:aws:appsync:us-east-1:111111111111:apis/<apiId>/functions/<functionId>\n  return parts.resourceName.split('/')[3];\n}\n\nfunction appsyncGraphQlDataSourceNameFmt(parts: ArnParts): string {\n  // arn:aws:appsync:us-east-1:111111111111:apis/<apiId>/datasources/<name>\n  return parts.resourceName.split('/')[3];\n}\n\ninterface Intrinsic {\n  readonly name: string;\n  readonly args: any;\n}\n\nasync function asyncGlobalReplace(str: string, regex: RegExp, cb: (x: string) => Promise<string>): Promise<string> {\n  if (!regex.global) {\n    throw new ToolkitError('Regex must be created with /g flag');\n  }\n\n  const ret = new Array<string>();\n  let start = 0;\n  while (true) {\n    const match = regex.exec(str);\n    if (!match) {\n      break;\n    }\n\n    ret.push(str.substring(start, match.index));\n    ret.push(await cb(match[1]));\n\n    start = regex.lastIndex;\n  }\n  ret.push(str.slice(start));\n\n  return ret.join('');\n}\n"]}
@@ -0,0 +1,4 @@
1
+ export * from './evaluate-cloudformation-template';
2
+ export * from './template-body-parameter';
3
+ export * from './nested-stack-helpers';
4
+ export * from './stack-helpers';
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./evaluate-cloudformation-template"), exports);
18
+ __exportStar(require("./template-body-parameter"), exports);
19
+ __exportStar(require("./nested-stack-helpers"), exports);
20
+ __exportStar(require("./stack-helpers"), exports);
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEscUVBQW1EO0FBQ25ELDREQUEwQztBQUMxQyx5REFBdUM7QUFDdkMsa0RBQWdDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9ldmFsdWF0ZS1jbG91ZGZvcm1hdGlvbi10ZW1wbGF0ZSc7XG5leHBvcnQgKiBmcm9tICcuL3RlbXBsYXRlLWJvZHktcGFyYW1ldGVyJztcbmV4cG9ydCAqIGZyb20gJy4vbmVzdGVkLXN0YWNrLWhlbHBlcnMnO1xuZXhwb3J0ICogZnJvbSAnLi9zdGFjay1oZWxwZXJzJztcbiJdfQ==