@aws-amplify/graphql-api-construct 1.4.3 → 1.5.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (229) hide show
  1. package/.jsii +202 -201
  2. package/API.md +7 -7
  3. package/CHANGELOG.md +12 -0
  4. package/README.md +210 -20
  5. package/lib/amplify-dynamodb-table-wrapper.js +1 -1
  6. package/lib/amplify-graphql-api.d.ts +0 -7
  7. package/lib/amplify-graphql-api.js +18 -76
  8. package/lib/amplify-graphql-definition.d.ts +1 -13
  9. package/lib/amplify-graphql-definition.js +27 -16
  10. package/lib/index.d.ts +1 -1
  11. package/lib/index.js +2 -2
  12. package/lib/internal/data-source-config.d.ts +14 -20
  13. package/lib/internal/data-source-config.js +110 -38
  14. package/lib/internal/model-type-name.d.ts +2 -2
  15. package/lib/internal/model-type-name.js +4 -4
  16. package/lib/{model-datasource-strategy.d.ts → model-datasource-strategy-types.d.ts} +17 -11
  17. package/lib/model-datasource-strategy-types.js +10 -0
  18. package/lib/sql-model-datasource-strategy.d.ts +1 -1
  19. package/lib/sql-model-datasource-strategy.js +4 -4
  20. package/lib/types.d.ts +1 -9
  21. package/lib/types.js +1 -1
  22. package/node_modules/@aws-amplify/graphql-auth-transformer/CHANGELOG.md +6 -0
  23. package/node_modules/@aws-amplify/graphql-auth-transformer/lib/graphql-auth-transformer.d.ts.map +1 -1
  24. package/node_modules/@aws-amplify/graphql-auth-transformer/lib/graphql-auth-transformer.js +6 -10
  25. package/node_modules/@aws-amplify/graphql-auth-transformer/lib/graphql-auth-transformer.js.map +1 -1
  26. package/node_modules/@aws-amplify/graphql-auth-transformer/lib/utils/validations.js +1 -1
  27. package/node_modules/@aws-amplify/graphql-auth-transformer/package.json +16 -12
  28. package/node_modules/@aws-amplify/graphql-default-value-transformer/CHANGELOG.md +6 -0
  29. package/node_modules/@aws-amplify/graphql-default-value-transformer/lib/graphql-default-value-transformer.d.ts.map +1 -1
  30. package/node_modules/@aws-amplify/graphql-default-value-transformer/lib/graphql-default-value-transformer.js +2 -7
  31. package/node_modules/@aws-amplify/graphql-default-value-transformer/lib/graphql-default-value-transformer.js.map +1 -1
  32. package/node_modules/@aws-amplify/graphql-default-value-transformer/package.json +13 -9
  33. package/node_modules/@aws-amplify/graphql-function-transformer/CHANGELOG.md +6 -0
  34. package/node_modules/@aws-amplify/graphql-function-transformer/lib/graphql-function-transformer.d.ts.map +1 -1
  35. package/node_modules/@aws-amplify/graphql-function-transformer/lib/graphql-function-transformer.js +7 -0
  36. package/node_modules/@aws-amplify/graphql-function-transformer/lib/graphql-function-transformer.js.map +1 -1
  37. package/node_modules/@aws-amplify/graphql-function-transformer/package.json +11 -7
  38. package/node_modules/@aws-amplify/graphql-http-transformer/CHANGELOG.md +4 -0
  39. package/node_modules/@aws-amplify/graphql-http-transformer/package.json +11 -7
  40. package/node_modules/@aws-amplify/graphql-index-transformer/CHANGELOG.md +6 -0
  41. package/node_modules/@aws-amplify/graphql-index-transformer/lib/graphql-primary-key-transformer.d.ts.map +1 -1
  42. package/node_modules/@aws-amplify/graphql-index-transformer/lib/graphql-primary-key-transformer.js +4 -4
  43. package/node_modules/@aws-amplify/graphql-index-transformer/lib/graphql-primary-key-transformer.js.map +1 -1
  44. package/node_modules/@aws-amplify/graphql-index-transformer/lib/resolvers/resolvers.d.ts +3 -5
  45. package/node_modules/@aws-amplify/graphql-index-transformer/lib/resolvers/resolvers.d.ts.map +1 -1
  46. package/node_modules/@aws-amplify/graphql-index-transformer/lib/resolvers/resolvers.js +12 -34
  47. package/node_modules/@aws-amplify/graphql-index-transformer/lib/resolvers/resolvers.js.map +1 -1
  48. package/node_modules/@aws-amplify/graphql-index-transformer/package.json +13 -9
  49. package/node_modules/@aws-amplify/graphql-maps-to-transformer/CHANGELOG.md +6 -0
  50. package/node_modules/@aws-amplify/graphql-maps-to-transformer/lib/assets/mapping-lambda.zip +0 -0
  51. package/node_modules/@aws-amplify/graphql-maps-to-transformer/lib/graphql-maps-to-transformer.d.ts.map +1 -1
  52. package/node_modules/@aws-amplify/graphql-maps-to-transformer/lib/graphql-maps-to-transformer.js +3 -4
  53. package/node_modules/@aws-amplify/graphql-maps-to-transformer/lib/graphql-maps-to-transformer.js.map +1 -1
  54. package/node_modules/@aws-amplify/graphql-maps-to-transformer/lib/graphql-refers-to-transformer.d.ts.map +1 -1
  55. package/node_modules/@aws-amplify/graphql-maps-to-transformer/lib/graphql-refers-to-transformer.js +3 -3
  56. package/node_modules/@aws-amplify/graphql-maps-to-transformer/lib/graphql-refers-to-transformer.js.map +1 -1
  57. package/node_modules/@aws-amplify/graphql-maps-to-transformer/package.json +16 -12
  58. package/node_modules/@aws-amplify/graphql-model-transformer/API.md +2 -2
  59. package/node_modules/@aws-amplify/graphql-model-transformer/CHANGELOG.md +7 -0
  60. package/node_modules/@aws-amplify/graphql-model-transformer/lib/graphql-model-transformer.d.ts +1 -3
  61. package/node_modules/@aws-amplify/graphql-model-transformer/lib/graphql-model-transformer.d.ts.map +1 -1
  62. package/node_modules/@aws-amplify/graphql-model-transformer/lib/graphql-model-transformer.js +61 -68
  63. package/node_modules/@aws-amplify/graphql-model-transformer/lib/graphql-model-transformer.js.map +1 -1
  64. package/node_modules/@aws-amplify/graphql-model-transformer/lib/rds-lambda.zip +0 -0
  65. package/node_modules/@aws-amplify/graphql-model-transformer/lib/rds-notification-lambda.zip +0 -0
  66. package/node_modules/@aws-amplify/graphql-model-transformer/lib/rds-patching-lambda.zip +0 -0
  67. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resolvers/rds/resolver.d.ts +8 -8
  68. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resolvers/rds/resolver.d.ts.map +1 -1
  69. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resolvers/rds/resolver.js +32 -36
  70. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resolvers/rds/resolver.js.map +1 -1
  71. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resources/rds-model-resource-generator.d.ts +3 -2
  72. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resources/rds-model-resource-generator.d.ts.map +1 -1
  73. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resources/rds-model-resource-generator.js +70 -34
  74. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resources/rds-model-resource-generator.js.map +1 -1
  75. package/node_modules/@aws-amplify/graphql-model-transformer/package.json +15 -10
  76. package/node_modules/@aws-amplify/graphql-predictions-transformer/CHANGELOG.md +4 -0
  77. package/node_modules/@aws-amplify/graphql-predictions-transformer/lib/predictionsLambdaFunction.zip +0 -0
  78. package/node_modules/@aws-amplify/graphql-predictions-transformer/package.json +11 -7
  79. package/node_modules/@aws-amplify/graphql-relational-transformer/API.md +2 -2
  80. package/node_modules/@aws-amplify/graphql-relational-transformer/CHANGELOG.md +6 -0
  81. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/graphql-belongs-to-transformer.d.ts.map +1 -1
  82. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/graphql-belongs-to-transformer.js +14 -7
  83. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/graphql-belongs-to-transformer.js.map +1 -1
  84. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/graphql-has-many-transformer.d.ts.map +1 -1
  85. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/graphql-has-many-transformer.js +6 -6
  86. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/graphql-has-many-transformer.js.map +1 -1
  87. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/graphql-has-one-transformer.js +6 -6
  88. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/graphql-has-one-transformer.js.map +1 -1
  89. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/graphql-many-to-many-transformer.d.ts.map +1 -1
  90. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/graphql-many-to-many-transformer.js +8 -1
  91. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/graphql-many-to-many-transformer.js.map +1 -1
  92. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/resolver/ddb-generator.d.ts.map +1 -1
  93. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/resolver/ddb-generator.js +5 -3
  94. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/resolver/ddb-generator.js.map +1 -1
  95. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/resolver/generator-factory.d.ts +2 -2
  96. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/resolver/generator-factory.d.ts.map +1 -1
  97. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/resolver/generator-factory.js.map +1 -1
  98. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/resolver/rds-generator.d.ts.map +1 -1
  99. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/resolver/rds-generator.js +18 -6
  100. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/resolver/rds-generator.js.map +1 -1
  101. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/utils.d.ts +18 -18
  102. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/utils.d.ts.map +1 -1
  103. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/utils.js +54 -54
  104. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/utils.js.map +1 -1
  105. package/node_modules/@aws-amplify/graphql-relational-transformer/package.json +14 -10
  106. package/node_modules/@aws-amplify/graphql-searchable-transformer/CHANGELOG.md +6 -0
  107. package/node_modules/@aws-amplify/graphql-searchable-transformer/lib/graphql-searchable-transformer.js +1 -1
  108. package/node_modules/@aws-amplify/graphql-searchable-transformer/lib/streaming-lambda.zip +0 -0
  109. package/node_modules/@aws-amplify/graphql-searchable-transformer/package.json +12 -8
  110. package/node_modules/@aws-amplify/graphql-sql-transformer/CHANGELOG.md +6 -0
  111. package/node_modules/@aws-amplify/graphql-sql-transformer/lib/graphql-sql-transformer.d.ts.map +1 -1
  112. package/node_modules/@aws-amplify/graphql-sql-transformer/lib/graphql-sql-transformer.js +31 -25
  113. package/node_modules/@aws-amplify/graphql-sql-transformer/lib/graphql-sql-transformer.js.map +1 -1
  114. package/node_modules/@aws-amplify/graphql-sql-transformer/package.json +12 -8
  115. package/node_modules/@aws-amplify/graphql-transformer/API.md +3 -17
  116. package/node_modules/@aws-amplify/graphql-transformer/CHANGELOG.md +4 -0
  117. package/node_modules/@aws-amplify/graphql-transformer/lib/graphql-transformer.d.ts +4 -14
  118. package/node_modules/@aws-amplify/graphql-transformer/lib/graphql-transformer.d.ts.map +1 -1
  119. package/node_modules/@aws-amplify/graphql-transformer/lib/graphql-transformer.js +8 -15
  120. package/node_modules/@aws-amplify/graphql-transformer/lib/graphql-transformer.js.map +1 -1
  121. package/node_modules/@aws-amplify/graphql-transformer/package.json +20 -16
  122. package/node_modules/@aws-amplify/graphql-transformer/src/graphql-transformer.ts +30 -57
  123. package/node_modules/@aws-amplify/graphql-transformer-core/API.md +97 -30
  124. package/node_modules/@aws-amplify/graphql-transformer-core/CHANGELOG.md +7 -0
  125. package/node_modules/@aws-amplify/graphql-transformer-core/lib/index.d.ts +3 -3
  126. package/node_modules/@aws-amplify/graphql-transformer-core/lib/index.d.ts.map +1 -1
  127. package/node_modules/@aws-amplify/graphql-transformer-core/lib/index.js +22 -10
  128. package/node_modules/@aws-amplify/graphql-transformer-core/lib/index.js.map +1 -1
  129. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformation/index.d.ts +1 -1
  130. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformation/index.d.ts.map +1 -1
  131. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformation/index.js +4 -2
  132. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformation/index.js.map +1 -1
  133. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformation/transform.d.ts +6 -12
  134. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformation/transform.d.ts.map +1 -1
  135. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformation/transform.js +4 -11
  136. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformation/transform.js.map +1 -1
  137. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformation/types.d.ts +0 -9
  138. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformation/types.d.ts.map +1 -1
  139. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformation/utils.d.ts +12 -10
  140. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformation/utils.d.ts.map +1 -1
  141. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformation/utils.js +94 -39
  142. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformation/utils.js.map +1 -1
  143. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformer-context/index.d.ts +10 -22
  144. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformer-context/index.d.ts.map +1 -1
  145. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformer-context/index.js +3 -7
  146. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformer-context/index.js.map +1 -1
  147. package/node_modules/@aws-amplify/graphql-transformer-core/lib/types/import-appsync-api-types.d.ts +1 -4
  148. package/node_modules/@aws-amplify/graphql-transformer-core/lib/types/import-appsync-api-types.d.ts.map +1 -1
  149. package/node_modules/@aws-amplify/graphql-transformer-core/lib/types/import-appsync-api-types.js +1 -4
  150. package/node_modules/@aws-amplify/graphql-transformer-core/lib/types/import-appsync-api-types.js.map +1 -1
  151. package/node_modules/@aws-amplify/graphql-transformer-core/lib/types/index.d.ts +2 -1
  152. package/node_modules/@aws-amplify/graphql-transformer-core/lib/types/index.d.ts.map +1 -1
  153. package/node_modules/@aws-amplify/graphql-transformer-core/lib/types/index.js +16 -4
  154. package/node_modules/@aws-amplify/graphql-transformer-core/lib/types/index.js.map +1 -1
  155. package/node_modules/@aws-amplify/graphql-transformer-core/lib/types/model-datasource-strategies.d.ts +7 -0
  156. package/node_modules/@aws-amplify/graphql-transformer-core/lib/types/model-datasource-strategies.d.ts.map +1 -0
  157. package/node_modules/@aws-amplify/graphql-transformer-core/lib/types/model-datasource-strategies.js +15 -0
  158. package/node_modules/@aws-amplify/graphql-transformer-core/lib/types/model-datasource-strategies.js.map +1 -0
  159. package/node_modules/@aws-amplify/graphql-transformer-core/lib/types/types.d.ts.map +1 -1
  160. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/graphql-utils.d.ts +16 -2
  161. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/graphql-utils.d.ts.map +1 -1
  162. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/graphql-utils.js +21 -5
  163. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/graphql-utils.js.map +1 -1
  164. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/index.d.ts +3 -4
  165. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/index.d.ts.map +1 -1
  166. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/index.js +5 -12
  167. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/index.js.map +1 -1
  168. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/model-datasource-strategy-utils.d.ts +11 -8
  169. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/model-datasource-strategy-utils.d.ts.map +1 -1
  170. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/model-datasource-strategy-utils.js +64 -52
  171. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/model-datasource-strategy-utils.js.map +1 -1
  172. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/rds-util.d.ts +0 -10
  173. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/rds-util.d.ts.map +1 -1
  174. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/rds-util.js +1 -58
  175. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/rds-util.js.map +1 -1
  176. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/resource-name.d.ts +22 -0
  177. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/resource-name.d.ts.map +1 -1
  178. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/resource-name.js +28 -1
  179. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/resource-name.js.map +1 -1
  180. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/schema-utils.d.ts +2 -2
  181. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/schema-utils.d.ts.map +1 -1
  182. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/schema-utils.js +7 -6
  183. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/schema-utils.js.map +1 -1
  184. package/node_modules/@aws-amplify/graphql-transformer-core/package.json +9 -5
  185. package/node_modules/@aws-amplify/graphql-transformer-interfaces/API.md +32 -68
  186. package/node_modules/@aws-amplify/graphql-transformer-interfaces/CHANGELOG.md +4 -0
  187. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/model-datasource/types.d.ts +11 -7
  188. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/model-datasource/types.d.ts.map +1 -1
  189. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/transformer-context/index.d.ts +1 -1
  190. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/transformer-context/index.d.ts.map +1 -1
  191. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/transformer-context/index.js +1 -3
  192. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/transformer-context/index.js.map +1 -1
  193. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/transformer-context/transformer-context-provider.d.ts +11 -18
  194. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/transformer-context/transformer-context-provider.d.ts.map +1 -1
  195. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/transformer-context/transformer-datasource-provider.d.ts +0 -15
  196. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/transformer-context/transformer-datasource-provider.d.ts.map +1 -1
  197. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/transformer-context/transformer-datasource-provider.js +1 -10
  198. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/transformer-context/transformer-datasource-provider.js.map +1 -1
  199. package/node_modules/@aws-amplify/graphql-transformer-interfaces/package.json +7 -3
  200. package/node_modules/@aws-amplify/graphql-transformer-interfaces/src/model-datasource/types.ts +50 -18
  201. package/node_modules/@aws-amplify/graphql-transformer-interfaces/src/transformer-context/index.ts +0 -6
  202. package/node_modules/@aws-amplify/graphql-transformer-interfaces/src/transformer-context/transformer-context-provider.ts +14 -21
  203. package/node_modules/@aws-amplify/graphql-transformer-interfaces/src/transformer-context/transformer-datasource-provider.ts +0 -43
  204. package/node_modules/@aws-amplify/graphql-transformer-interfaces/tsconfig.tsbuildinfo +1 -1
  205. package/node_modules/graphql-mapping-template/CHANGELOG.md +4 -0
  206. package/node_modules/graphql-mapping-template/LICENSE +201 -0
  207. package/node_modules/graphql-mapping-template/package.json +8 -3
  208. package/node_modules/graphql-transformer-common/API.md +0 -15
  209. package/node_modules/graphql-transformer-common/CHANGELOG.md +6 -0
  210. package/node_modules/graphql-transformer-common/LICENSE +201 -0
  211. package/node_modules/graphql-transformer-common/lib/ResourceConstants.d.ts +0 -15
  212. package/node_modules/graphql-transformer-common/lib/ResourceConstants.d.ts.map +1 -1
  213. package/node_modules/graphql-transformer-common/lib/ResourceConstants.js +0 -15
  214. package/node_modules/graphql-transformer-common/lib/ResourceConstants.js.map +1 -1
  215. package/node_modules/graphql-transformer-common/package.json +8 -3
  216. package/package.json +24 -19
  217. package/src/amplify-graphql-api.ts +19 -91
  218. package/src/amplify-graphql-definition.ts +41 -17
  219. package/src/index.ts +1 -1
  220. package/src/internal/data-source-config.ts +146 -52
  221. package/src/internal/model-type-name.ts +3 -2
  222. package/src/{model-datasource-strategy.ts → model-datasource-strategy-types.ts} +20 -12
  223. package/src/sql-model-datasource-strategy.ts +3 -3
  224. package/src/types.ts +1 -9
  225. package/lib/model-datasource-strategy.js +0 -10
  226. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/provision-strategy-utils.d.ts +0 -3
  227. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/provision-strategy-utils.d.ts.map +0 -1
  228. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/provision-strategy-utils.js +0 -15
  229. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/provision-strategy-utils.js.map +0 -1
@@ -11,12 +11,10 @@ const aws_s3_assets_1 = require("aws-cdk-lib/aws-s3-assets");
11
11
  const backend_output_storage_1 = require("@aws-amplify/backend-output-storage");
12
12
  const backend_output_schemas_1 = require("@aws-amplify/backend-output-schemas");
13
13
  const aws_appsync_1 = require("aws-cdk-lib/aws-appsync");
14
- const graphql_transformer_core_1 = require("@aws-amplify/graphql-transformer-core");
15
14
  const user_defined_slots_1 = require("./internal/user-defined-slots");
16
15
  const internal_1 = require("./internal");
17
- const data_source_config_1 = require("./internal/data-source-config");
18
16
  const construct_tree_1 = require("./internal/construct-tree");
19
- const sql_model_datasource_strategy_1 = require("./sql-model-datasource-strategy");
17
+ const data_source_config_1 = require("./internal/data-source-config");
20
18
  /**
21
19
  * L3 Construct which invokes the Amplify Transformer Pattern over an input Graphql Schema.
22
20
  *
@@ -63,7 +61,10 @@ class AmplifyGraphqlApi extends constructs_1.Construct {
63
61
  this.stackType = 'api-AppSync';
64
62
  validateNoOtherAmplifyGraphqlApiInStack(this);
65
63
  const { definition, authorizationModes, conflictResolution, functionSlots, transformerPlugins, predictionsBucket, stackMappings, translationBehavior, functionNameMap, outputStorageStrategy, } = props;
66
- new backend_output_storage_1.AttributionMetadataStorage().storeAttributionMetadata(aws_cdk_lib_1.Stack.of(scope), this.stackType, path.join(__dirname, '..', 'package.json'));
64
+ const dataSources = getMetadataDataSources(definition);
65
+ new backend_output_storage_1.AttributionMetadataStorage().storeAttributionMetadata(aws_cdk_lib_1.Stack.of(scope), this.stackType, path.join(__dirname, '..', 'package.json'), {
66
+ dataSources,
67
+ });
67
68
  const { authConfig, authSynthParameters } = (0, internal_1.convertAuthorizationModesToTransformerAuthConfig)(authorizationModes);
68
69
  (0, user_defined_slots_1.validateFunctionSlots)(functionSlots ?? []);
69
70
  const separatedFunctionSlots = (0, user_defined_slots_1.separateSlots)([...(functionSlots ?? []), ...definition.functionSlots]);
@@ -75,7 +76,7 @@ class AmplifyGraphqlApi extends constructs_1.Construct {
75
76
  throw new Error(`or cdk --context env must have a length <= 8, found ${amplifyEnvironmentName}`);
76
77
  }
77
78
  const assetManager = new internal_1.AssetManager();
78
- let executeTransformConfig = {
79
+ const executeTransformConfig = {
79
80
  scope: this,
80
81
  nestedStackProvider: {
81
82
  provide: (nestedStackScope, name) => new aws_cdk_lib_1.NestedStack(nestedStackScope, name),
@@ -105,27 +106,11 @@ class AmplifyGraphqlApi extends constructs_1.Construct {
105
106
  ...internal_1.defaultTranslationBehavior,
106
107
  ...(translationBehavior ?? {}),
107
108
  },
108
- // Adds a modelToDataSourceMap field/value
109
- ...(0, data_source_config_1.parseDataSourceConfig)(definition.dataSourceStrategies),
109
+ // CDK construct uses a custom resource. We'll define this explicitly here to remind ourselves that this value is unused in the CDK
110
+ // construct flow
111
+ rdsLayerMapping: undefined,
112
+ ...(0, data_source_config_1.getDataSourceStrategiesProvider)(definition),
110
113
  };
111
- // TODO: Normalize all of this once we start using strategies internally. Right now the data source configuration (VPC, connection info,
112
- // etc) is separate from the DataSourceType, and singular
113
- const customSqlDataSourceStrategies = (0, data_source_config_1.mapInterfaceCustomSqlStrategiesToImplementationStrategies)(definition.customSqlDataSourceStrategies);
114
- if (customSqlDataSourceStrategies.length > 0) {
115
- executeTransformConfig = {
116
- ...executeTransformConfig,
117
- customSqlDataSourceStrategies,
118
- };
119
- }
120
- // TODO: Update this to support multiple definitions; right now we assume only one SQL data source type
121
- const modelStrategies = Object.values(definition.dataSourceStrategies).filter(sql_model_datasource_strategy_1.isSQLLambdaModelDataSourceStrategy);
122
- const customSqlStrategies = definition.customSqlDataSourceStrategies?.map((css) => css.strategy) ?? [];
123
- for (const strategy of [...modelStrategies, ...customSqlStrategies]) {
124
- if ((0, sql_model_datasource_strategy_1.isSQLLambdaModelDataSourceStrategy)(strategy)) {
125
- executeTransformConfig = this.extendTransformConfig(executeTransformConfig, strategy);
126
- break;
127
- }
128
- }
129
114
  (0, graphql_transformer_1.executeTransform)(executeTransformConfig);
130
115
  this.codegenAssets = new internal_1.CodegenAssets(this, 'AmplifyCodegenAssets', { modelSchema: definition.schema });
131
116
  this.resources = (0, internal_1.getGeneratedResources)(this);
@@ -137,55 +122,6 @@ class AmplifyGraphqlApi extends constructs_1.Construct {
137
122
  this.realtimeUrl = this.resources.cfnResources.cfnGraphqlApi.attrRealtimeUrl;
138
123
  this.apiKey = this.resources.cfnResources.cfnApiKey?.attrApiKey;
139
124
  }
140
- /**
141
- * Extends executeTransformConfig with fields for provisioning a SQL Lambda
142
- * @param executeTransformConfig the executeTransformConfig to extend
143
- * @param strategy the SQLLambdaModelDataSourceStrategy containing the SQL connection values to add to the transform config
144
- * @returns the extended configuration that includes SQL DB connection information
145
- */
146
- extendTransformConfig(executeTransformConfig, strategy) {
147
- const extendedConfig = { ...executeTransformConfig };
148
- if (strategy.customSqlStatements) {
149
- extendedConfig.customQueries = new Map(Object.entries(strategy.customSqlStatements));
150
- }
151
- const dbSecrets = new Map();
152
- let dbSecretDbTypeKey;
153
- switch (strategy.dbType) {
154
- case 'MYSQL':
155
- dbSecretDbTypeKey = graphql_transformer_core_1.MYSQL_DB_TYPE;
156
- break;
157
- case 'POSTGRES':
158
- dbSecretDbTypeKey = graphql_transformer_core_1.POSTGRES_DB_TYPE;
159
- break;
160
- default:
161
- throw new Error(`Unsupported binding type ${strategy.dbType}`);
162
- }
163
- dbSecrets.set(dbSecretDbTypeKey, {
164
- username: strategy.dbConnectionConfig.usernameSsmPath,
165
- password: strategy.dbConnectionConfig.passwordSsmPath,
166
- host: strategy.dbConnectionConfig.hostnameSsmPath,
167
- // Cast through `any` to allow the SSM Path string to be used on a type expecting a number. This flow expects the incoming value to be
168
- // a string containing the SSM path.
169
- port: strategy.dbConnectionConfig.portSsmPath,
170
- database: strategy.dbConnectionConfig.databaseNameSsmPath,
171
- });
172
- extendedConfig.datasourceSecretParameterLocations = dbSecrets;
173
- if (strategy.vpcConfiguration) {
174
- const subnetAvailabilityZoneConfig = strategy.vpcConfiguration.subnetAvailabilityZoneConfig.map((saz) => ({
175
- subnetId: saz.subnetId,
176
- availabilityZone: saz.availabilityZone,
177
- }));
178
- extendedConfig.sqlLambdaVpcConfig = {
179
- vpcId: strategy.vpcConfiguration.vpcId,
180
- securityGroupIds: strategy.vpcConfiguration.securityGroupIds,
181
- subnetAvailabilityZoneConfig,
182
- };
183
- }
184
- if (strategy.sqlLambdaProvisionedConcurrencyConfig) {
185
- extendedConfig.sqlLambdaProvisionedConcurrencyConfig = strategy.sqlLambdaProvisionedConcurrencyConfig;
186
- }
187
- return extendedConfig;
188
- }
189
125
  /**
190
126
  * Stores graphql api output to be used for client config generation
191
127
  * @param outputStorageStrategy Strategy to store construct outputs. If no strategy is provided a default strategy will be used.
@@ -323,7 +259,7 @@ class AmplifyGraphqlApi extends constructs_1.Construct {
323
259
  }
324
260
  exports.AmplifyGraphqlApi = AmplifyGraphqlApi;
325
261
  _a = JSII_RTTI_SYMBOL_1;
326
- AmplifyGraphqlApi[_a] = { fqn: "@aws-amplify/graphql-api-construct.AmplifyGraphqlApi", version: "1.4.3" };
262
+ AmplifyGraphqlApi[_a] = { fqn: "@aws-amplify/graphql-api-construct.AmplifyGraphqlApi", version: "1.5.0" };
327
263
  /**
328
264
  * Given the provided scope, walk the node tree, and throw an exception if any other AmplifyGraphqlApi constructs
329
265
  * are found in the stack.
@@ -341,4 +277,10 @@ const validateNoOtherAmplifyGraphqlApiInStack = (scope) => {
341
277
  throw new Error('Only one AmplifyGraphqlApi is expected in a stack');
342
278
  }
343
279
  };
344
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"amplify-graphql-api.js","sourceRoot":"","sources":["../src/amplify-graphql-api.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport { Construct } from 'constructs';\nimport { ExecuteTransformConfig, executeTransform } from '@aws-amplify/graphql-transformer';\nimport { NestedStack, Stack } from 'aws-cdk-lib';\nimport { Asset } from 'aws-cdk-lib/aws-s3-assets';\nimport { AssetProps } from '@aws-amplify/graphql-transformer-interfaces';\nimport { AttributionMetadataStorage, StackMetadataBackendOutputStorageStrategy } from '@aws-amplify/backend-output-storage';\nimport { graphqlOutputKey } from '@aws-amplify/backend-output-schemas';\nimport type { GraphqlOutput, AwsAppsyncAuthenticationType } from '@aws-amplify/backend-output-schemas';\nimport {\n  AppsyncFunction,\n  DataSourceOptions,\n  DynamoDbDataSource,\n  ElasticsearchDataSource,\n  EventBridgeDataSource,\n  ExtendedResolverProps,\n  HttpDataSource,\n  HttpDataSourceOptions,\n  LambdaDataSource,\n  NoneDataSource,\n  OpenSearchDataSource,\n  RdsDataSource,\n  Resolver,\n} from 'aws-cdk-lib/aws-appsync';\nimport { ITable } from 'aws-cdk-lib/aws-dynamodb';\nimport { IDomain } from 'aws-cdk-lib/aws-elasticsearch';\nimport { IDomain as IOpenSearchDomain } from 'aws-cdk-lib/aws-opensearchservice';\nimport { IEventBus } from 'aws-cdk-lib/aws-events';\nimport { IFunction } from 'aws-cdk-lib/aws-lambda';\nimport { IServerlessCluster } from 'aws-cdk-lib/aws-rds';\nimport { ISecret } from 'aws-cdk-lib/aws-secretsmanager';\nimport { MYSQL_DB_TYPE, POSTGRES_DB_TYPE, RDSConnectionSecrets } from '@aws-amplify/graphql-transformer-core';\nimport { parseUserDefinedSlots, validateFunctionSlots, separateSlots } from './internal/user-defined-slots';\nimport type {\n  AmplifyGraphqlApiResources,\n  AmplifyGraphqlApiProps,\n  FunctionSlot,\n  IBackendOutputStorageStrategy,\n  AddFunctionProps,\n  ConflictResolution,\n} from './types';\nimport {\n  convertAuthorizationModesToTransformerAuthConfig,\n  convertToResolverConfig,\n  defaultTranslationBehavior,\n  AssetManager,\n  getGeneratedResources,\n  getGeneratedFunctionSlots,\n  CodegenAssets,\n  getAdditionalAuthenticationTypes,\n} from './internal';\nimport { mapInterfaceCustomSqlStrategiesToImplementationStrategies, parseDataSourceConfig } from './internal/data-source-config';\nimport { getStackForScope, walkAndProcessNodes } from './internal/construct-tree';\nimport { SQLLambdaModelDataSourceStrategy } from './model-datasource-strategy';\nimport { isSQLLambdaModelDataSourceStrategy } from './sql-model-datasource-strategy';\n\n/**\n * L3 Construct which invokes the Amplify Transformer Pattern over an input Graphql Schema.\n *\n * This can be used to quickly define appsync apis which support full CRUD+List and Subscriptions, relationships,\n * auth, search over data, the ability to inject custom business logic and query/mutation operations, and connect to ML services.\n *\n * For more information, refer to the docs links below:\n * Data Modeling - https://docs.amplify.aws/cli/graphql/data-modeling/\n * Authorization - https://docs.amplify.aws/cli/graphql/authorization-rules/\n * Custom Business Logic - https://docs.amplify.aws/cli/graphql/custom-business-logic/\n * Search - https://docs.amplify.aws/cli/graphql/search-and-result-aggregations/\n * ML Services - https://docs.amplify.aws/cli/graphql/connect-to-machine-learning-services/\n *\n * For a full reference of the supported custom graphql directives - https://docs.amplify.aws/cli/graphql/directives-reference/\n *\n * The output of this construct is a mapping of L2 or L1 resources generated by the transformer, which generally follow the access pattern\n *\n * ```typescript\n *   const api = new AmplifyGraphQlApi(this, 'api', { <params> });\n *   // Access L2 resources under `.resources`\n *   api.resources.tables[\"Todo\"].tableArn;\n *\n *   // Access L1 resources under `.resources.cfnResources`\n *   api.resources.cfnResources.cfnGraphqlApi.xrayEnabled = true;\n *   Object.values(api.resources.cfnResources.cfnTables).forEach(table => {\n *     table.pointInTimeRecoverySpecification = { pointInTimeRecoveryEnabled: false };\n *   });\n * ```\n * `resources.<ResourceType>.<ResourceName>` - you can then perform any CDK action on these resulting resoureces.\n */\nexport class AmplifyGraphqlApi extends Construct {\n  /**\n   * Generated L1 and L2 CDK resources.\n   */\n  public readonly resources: AmplifyGraphqlApiResources;\n\n  /**\n   * Generated assets required for codegen steps. Persisted in order to render as part of the output strategy.\n   */\n  private readonly codegenAssets: CodegenAssets;\n\n  /**\n   * Resolvers generated by the transform process, persisted on the side in order to facilitate pulling a manifest\n   * for the purposes of inspecting and producing overrides.\n   */\n  public readonly generatedFunctionSlots: FunctionSlot[];\n\n  /**\n   * Graphql URL For the generated API. May be a CDK Token.\n   */\n  public readonly graphqlUrl: string;\n\n  /**\n   * Realtime URL For the generated API. May be a CDK Token.\n   */\n  public readonly realtimeUrl: string;\n\n  /**\n   * Generated Api Key if generated. May be a CDK Token.\n   */\n  public readonly apiKey: string | undefined;\n\n  /**\n   * Generated Api Id. May be a CDK Token.\n   */\n  public readonly apiId: string;\n\n  /**\n   * Conflict resolution setting\n   */\n  private readonly conflictResolution: ConflictResolution | undefined;\n\n  /**\n   * Be very careful editing this value. This is the string that is used to identify graphql stacks in BI metrics\n   */\n  private readonly stackType = 'api-AppSync';\n\n  /**\n   * New AmplifyGraphqlApi construct, this will create an appsync api with authorization, a schema, and all necessary resolvers, functions,\n   * and datasources.\n   * @param scope the scope to create this construct within.\n   * @param id the id to use for this api.\n   * @param props the properties used to configure the generated api.\n   */\n  constructor(scope: Construct, id: string, props: AmplifyGraphqlApiProps) {\n    super(scope, id);\n\n    validateNoOtherAmplifyGraphqlApiInStack(this);\n\n    const {\n      definition,\n      authorizationModes,\n      conflictResolution,\n      functionSlots,\n      transformerPlugins,\n      predictionsBucket,\n      stackMappings,\n      translationBehavior,\n      functionNameMap,\n      outputStorageStrategy,\n    } = props;\n\n    new AttributionMetadataStorage().storeAttributionMetadata(Stack.of(scope), this.stackType, path.join(__dirname, '..', 'package.json'));\n\n    const { authConfig, authSynthParameters } = convertAuthorizationModesToTransformerAuthConfig(authorizationModes);\n\n    validateFunctionSlots(functionSlots ?? []);\n    const separatedFunctionSlots = separateSlots([...(functionSlots ?? []), ...definition.functionSlots]);\n\n    // Allow amplifyEnvironmentName to be retrieve from context, and use value 'NONE' if no value can be found.\n    // amplifyEnvironmentName is required for logical id suffixing, as well as Exports from the nested stacks.\n    // Allow export so customers can reuse the env in their own references downstream.\n    const amplifyEnvironmentName = this.node.tryGetContext('amplifyEnvironmentName') ?? 'NONE';\n    if (amplifyEnvironmentName.length > 8) {\n      throw new Error(`or cdk --context env must have a length <= 8, found ${amplifyEnvironmentName}`);\n    }\n\n    const assetManager = new AssetManager();\n\n    let executeTransformConfig: ExecuteTransformConfig = {\n      scope: this,\n      nestedStackProvider: {\n        provide: (nestedStackScope: Construct, name: string) => new NestedStack(nestedStackScope, name),\n      },\n      assetProvider: {\n        provide: (assetScope: Construct, assetId: string, assetProps: AssetProps) =>\n          new Asset(assetScope, assetId, { path: assetManager.addAsset(assetProps.fileName, assetProps.fileContent) }),\n      },\n      synthParameters: {\n        amplifyEnvironmentName: amplifyEnvironmentName,\n        apiName: props.apiName ?? id,\n        ...authSynthParameters,\n      },\n      schema: definition.schema,\n      userDefinedSlots: parseUserDefinedSlots(separatedFunctionSlots),\n      transformersFactoryArgs: {\n        customTransformers: transformerPlugins ?? [],\n        ...(predictionsBucket ? { storageConfig: { bucketName: predictionsBucket.bucketName } } : {}),\n        functionNameMap: {\n          ...definition.referencedLambdaFunctions,\n          ...functionNameMap,\n        },\n      },\n      authConfig,\n      stackMapping: stackMappings ?? {},\n      resolverConfig: conflictResolution ? convertToResolverConfig(conflictResolution) : undefined,\n      transformParameters: {\n        ...defaultTranslationBehavior,\n        ...(translationBehavior ?? {}),\n      },\n\n      // Adds a modelToDataSourceMap field/value\n      ...parseDataSourceConfig(definition.dataSourceStrategies),\n    };\n\n    // TODO: Normalize all of this once we start using strategies internally. Right now the data source configuration (VPC, connection info,\n    // etc) is separate from the DataSourceType, and singular\n    const customSqlDataSourceStrategies = mapInterfaceCustomSqlStrategiesToImplementationStrategies(\n      definition.customSqlDataSourceStrategies,\n    );\n    if (customSqlDataSourceStrategies.length > 0) {\n      executeTransformConfig = {\n        ...executeTransformConfig,\n        customSqlDataSourceStrategies,\n      };\n    }\n\n    // TODO: Update this to support multiple definitions; right now we assume only one SQL data source type\n    const modelStrategies = Object.values(definition.dataSourceStrategies).filter(isSQLLambdaModelDataSourceStrategy);\n    const customSqlStrategies = definition.customSqlDataSourceStrategies?.map((css) => css.strategy) ?? [];\n    for (const strategy of [...modelStrategies, ...customSqlStrategies]) {\n      if (isSQLLambdaModelDataSourceStrategy(strategy)) {\n        executeTransformConfig = this.extendTransformConfig(executeTransformConfig, strategy);\n        break;\n      }\n    }\n\n    executeTransform(executeTransformConfig);\n\n    this.codegenAssets = new CodegenAssets(this, 'AmplifyCodegenAssets', { modelSchema: definition.schema });\n\n    this.resources = getGeneratedResources(this);\n    this.conflictResolution = conflictResolution;\n    this.generatedFunctionSlots = getGeneratedFunctionSlots(assetManager.resolverAssets);\n    this.storeOutput(outputStorageStrategy);\n\n    this.apiId = this.resources.cfnResources.cfnGraphqlApi.attrApiId;\n    this.graphqlUrl = this.resources.cfnResources.cfnGraphqlApi.attrGraphQlUrl;\n    this.realtimeUrl = this.resources.cfnResources.cfnGraphqlApi.attrRealtimeUrl;\n    this.apiKey = this.resources.cfnResources.cfnApiKey?.attrApiKey;\n  }\n\n  /**\n   * Extends executeTransformConfig with fields for provisioning a SQL Lambda\n   * @param executeTransformConfig the executeTransformConfig to extend\n   * @param strategy the SQLLambdaModelDataSourceStrategy containing the SQL connection values to add to the transform config\n   * @returns the extended configuration that includes SQL DB connection information\n   */\n  private extendTransformConfig(\n    executeTransformConfig: ExecuteTransformConfig,\n    strategy: SQLLambdaModelDataSourceStrategy,\n  ): ExecuteTransformConfig {\n    const extendedConfig = { ...executeTransformConfig };\n\n    if (strategy.customSqlStatements) {\n      extendedConfig.customQueries = new Map(Object.entries(strategy.customSqlStatements));\n    }\n\n    const dbSecrets: Map<string, RDSConnectionSecrets> = new Map();\n    let dbSecretDbTypeKey: string;\n    switch (strategy.dbType) {\n      case 'MYSQL':\n        dbSecretDbTypeKey = MYSQL_DB_TYPE;\n        break;\n      case 'POSTGRES':\n        dbSecretDbTypeKey = POSTGRES_DB_TYPE;\n        break;\n      default:\n        throw new Error(`Unsupported binding type ${strategy.dbType}`);\n    }\n    dbSecrets.set(dbSecretDbTypeKey, {\n      username: strategy.dbConnectionConfig.usernameSsmPath,\n      password: strategy.dbConnectionConfig.passwordSsmPath,\n      host: strategy.dbConnectionConfig.hostnameSsmPath,\n      // Cast through `any` to allow the SSM Path string to be used on a type expecting a number. This flow expects the incoming value to be\n      // a string containing the SSM path.\n      port: strategy.dbConnectionConfig.portSsmPath as any,\n      database: strategy.dbConnectionConfig.databaseNameSsmPath,\n    });\n    extendedConfig.datasourceSecretParameterLocations = dbSecrets;\n\n    if (strategy.vpcConfiguration) {\n      const subnetAvailabilityZoneConfig = strategy.vpcConfiguration.subnetAvailabilityZoneConfig.map(\n        (saz): { subnetId: string; availabilityZone: string } => ({\n          subnetId: saz.subnetId,\n          availabilityZone: saz.availabilityZone,\n        }),\n      );\n      extendedConfig.sqlLambdaVpcConfig = {\n        vpcId: strategy.vpcConfiguration.vpcId,\n        securityGroupIds: strategy.vpcConfiguration.securityGroupIds,\n        subnetAvailabilityZoneConfig,\n      };\n    }\n\n    if (strategy.sqlLambdaProvisionedConcurrencyConfig) {\n      extendedConfig.sqlLambdaProvisionedConcurrencyConfig = strategy.sqlLambdaProvisionedConcurrencyConfig;\n    }\n\n    return extendedConfig;\n  }\n\n  /**\n   * Stores graphql api output to be used for client config generation\n   * @param outputStorageStrategy Strategy to store construct outputs. If no strategy is provided a default strategy will be used.\n   */\n  private storeOutput(\n    outputStorageStrategy: IBackendOutputStorageStrategy = new StackMetadataBackendOutputStorageStrategy(Stack.of(this)),\n  ): void {\n    const stack = Stack.of(this);\n    const output: GraphqlOutput = {\n      version: '1',\n      payload: {\n        awsAppsyncApiId: this.resources.cfnResources.cfnGraphqlApi.attrApiId,\n        awsAppsyncApiEndpoint: this.resources.cfnResources.cfnGraphqlApi.attrGraphQlUrl,\n        awsAppsyncAuthenticationType: this.resources.cfnResources.cfnGraphqlApi.authenticationType as AwsAppsyncAuthenticationType,\n        awsAppsyncRegion: stack.region,\n        amplifyApiModelSchemaS3Uri: this.codegenAssets.modelSchemaS3Uri,\n      },\n    };\n\n    if (this.resources.cfnResources.cfnApiKey) {\n      output.payload.awsAppsyncApiKey = this.resources.cfnResources.cfnApiKey.attrApiKey;\n    }\n\n    const additionalAuthTypes = getAdditionalAuthenticationTypes(this.resources.cfnResources.cfnGraphqlApi);\n    if (additionalAuthTypes) {\n      output.payload.awsAppsyncAdditionalAuthenticationTypes = additionalAuthTypes;\n    }\n\n    if (this.conflictResolution?.project?.handlerType) {\n      output.payload.awsAppsyncConflictResolutionMode = this.conflictResolution?.project?.handlerType;\n    }\n\n    outputStorageStrategy.addBackendOutputEntry(graphqlOutputKey, output);\n  }\n\n  /**\n   * The following are proxy methods to the L2 IGraphqlApi interface, to facilitate easier use of the L3 without needing\n   * to access the underlying resources.\n   */\n\n  /**\n   * Add a new DynamoDB data source to this API. This is a proxy method to the L2 GraphqlApi Construct.\n   * @param id The data source's id.\n   * @param table The DynamoDB table backing this data source.\n   * @param options The optional configuration for this data source.\n   * @returns the generated data source.\n   */\n  public addDynamoDbDataSource(id: string, table: ITable, options?: DataSourceOptions): DynamoDbDataSource {\n    return this.resources.graphqlApi.addDynamoDbDataSource(id, table, options);\n  }\n\n  /**\n   * Add a new elasticsearch data source to this API. This is a proxy method to the L2 GraphqlApi Construct.\n   * @deprecated use `addOpenSearchDataSource`\n   * @param id The data source's id.\n   * @param domain The elasticsearch domain for this data source.\n   * @param options The optional configuration for this data source.\n   * @returns the generated data source.\n   */\n  public addElasticsearchDataSource(id: string, domain: IDomain, options?: DataSourceOptions): ElasticsearchDataSource {\n    return this.resources.graphqlApi.addElasticsearchDataSource(id, domain, options);\n  }\n\n  /**\n   * Add an EventBridge data source to this api. This is a proxy method to the L2 GraphqlApi Construct.\n   * @param id The data source's id.\n   * @param eventBus The EventBridge EventBus on which to put events.\n   * @param options The optional configuration for this data source.\n   */\n  public addEventBridgeDataSource(id: string, eventBus: IEventBus, options?: DataSourceOptions): EventBridgeDataSource {\n    return this.resources.graphqlApi.addEventBridgeDataSource(id, eventBus, options);\n  }\n\n  /**\n   * Add a new http data source to this API. This is a proxy method to the L2 GraphqlApi Construct.\n   * @param id The data source's id.\n   * @param endpoint The http endpoint.\n   * @param options The optional configuration for this data source.\n   * @returns the generated data source.\n   */\n  public addHttpDataSource(id: string, endpoint: string, options?: HttpDataSourceOptions): HttpDataSource {\n    return this.resources.graphqlApi.addHttpDataSource(id, endpoint, options);\n  }\n\n  /**\n   * Add a new Lambda data source to this API. This is a proxy method to the L2 GraphqlApi Construct.\n   * @param id The data source's id.\n   * @param lambdaFunction The Lambda function to call to interact with this data source.\n   * @param options The optional configuration for this data source.\n   * @returns the generated data source.\n   */\n  public addLambdaDataSource(id: string, lambdaFunction: IFunction, options?: DataSourceOptions): LambdaDataSource {\n    return this.resources.graphqlApi.addLambdaDataSource(id, lambdaFunction, options);\n  }\n\n  /**\n   * Add a new dummy data source to this API. This is a proxy method to the L2 GraphqlApi Construct.\n   * Useful for pipeline resolvers and for backend changes that don't require a data source.\n   * @param id The data source's id.\n   * @param options The optional configuration for this data source.\n   * @returns the generated data source.\n   */\n  public addNoneDataSource(id: string, options?: DataSourceOptions): NoneDataSource {\n    return this.resources.graphqlApi.addNoneDataSource(id, options);\n  }\n\n  /**\n   * dd a new OpenSearch data source to this API. This is a proxy method to the L2 GraphqlApi Construct.\n   * @param id The data source's id.\n   * @param domain The OpenSearch domain for this data source.\n   * @param options The optional configuration for this data source.\n   * @returns the generated data source.\n   */\n  public addOpenSearchDataSource(id: string, domain: IOpenSearchDomain, options?: DataSourceOptions): OpenSearchDataSource {\n    return this.resources.graphqlApi.addOpenSearchDataSource(id, domain, options);\n  }\n\n  /**\n   * Add a new Rds data source to this API. This is a proxy method to the L2 GraphqlApi Construct.\n   * @param id The data source's id.\n   * @param serverlessCluster The serverless cluster to interact with this data source.\n   * @param secretStore The secret store that contains the username and password for the serverless cluster.\n   * @param databaseName The optional name of the database to use within the cluster.\n   * @param options The optional configuration for this data source.\n   * @returns the generated data source.\n   */\n  public addRdsDataSource(\n    id: string,\n    serverlessCluster: IServerlessCluster,\n    secretStore: ISecret,\n    databaseName?: string,\n    options?: DataSourceOptions,\n  ): RdsDataSource {\n    return this.resources.graphqlApi.addRdsDataSource(id, serverlessCluster, secretStore, databaseName, options);\n  }\n\n  /**\n   * Add a resolver to the api. This is a proxy method to the L2 GraphqlApi Construct.\n   * @param id The resolver's id.\n   * @param props the resolver properties.\n   * @returns the generated resolver.\n   */\n  public addResolver(id: string, props: ExtendedResolverProps): Resolver {\n    return this.resources.graphqlApi.createResolver(id, props);\n  }\n\n  /**\n   * Add an appsync function to the api.\n   * @param id the function's id.\n   * @returns the generated appsync function.\n   */\n  public addFunction(id: string, props: AddFunctionProps): AppsyncFunction {\n    return new AppsyncFunction(this, id, {\n      api: this.resources.graphqlApi,\n      ...props,\n    });\n  }\n}\n\n/**\n * Given the provided scope, walk the node tree, and throw an exception if any other AmplifyGraphqlApi constructs\n * are found in the stack.\n * @param scope the scope this construct is created in.\n */\nconst validateNoOtherAmplifyGraphqlApiInStack = (scope: Construct): void => {\n  const rootStack = getStackForScope(scope, true);\n\n  let wasOtherAmplifyGraphlApiFound = false;\n  walkAndProcessNodes(rootStack, (node: Construct) => {\n    if (node instanceof AmplifyGraphqlApi && scope !== node) {\n      wasOtherAmplifyGraphlApiFound = true;\n    }\n  });\n\n  if (wasOtherAmplifyGraphlApiFound) {\n    throw new Error('Only one AmplifyGraphqlApi is expected in a stack');\n  }\n};\n"]}
280
+ const getMetadataDataSources = (definition) => {
281
+ const dataSourceDbTypes = Object.values(definition.dataSourceStrategies).map((strategy) => strategy.dbType.toLocaleLowerCase());
282
+ const customSqlDbTypes = (definition.customSqlDataSourceStrategies ?? []).map((strategy) => strategy.strategy.dbType.toLocaleLowerCase());
283
+ const dataSources = [...new Set([...dataSourceDbTypes, ...customSqlDbTypes])].sort();
284
+ return dataSources.join(',');
285
+ };
286
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"amplify-graphql-api.js","sourceRoot":"","sources":["../src/amplify-graphql-api.ts"],"names":[],"mappings":";;;;;AAAA,6BAA6B;AAC7B,2CAAuC;AACvC,0EAA4F;AAC5F,6CAAiD;AACjD,6DAAkD;AAElD,gFAA4H;AAC5H,gFAAuE;AAEvE,yDAciC;AAQjC,sEAA4G;AAU5G,yCASoB;AACpB,8DAAkF;AAClF,sEAAgF;AAEhF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BG;AACH,MAAa,iBAAkB,SAAQ,sBAAS;IA+C9C;;;;;;OAMG;IACH,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA6B;QACrE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAbnB;;WAEG;QACc,cAAS,GAAG,aAAa,CAAC;QAYzC,uCAAuC,CAAC,IAAI,CAAC,CAAC;QAE9C,MAAM,EACJ,UAAU,EACV,kBAAkB,EAClB,kBAAkB,EAClB,aAAa,EACb,kBAAkB,EAClB,iBAAiB,EACjB,aAAa,EACb,mBAAmB,EACnB,eAAe,EACf,qBAAqB,GACtB,GAAG,KAAK,CAAC;QAEV,MAAM,WAAW,GAAG,sBAAsB,CAAC,UAAU,CAAC,CAAC;QAEvD,IAAI,mDAA0B,EAAE,CAAC,wBAAwB,CAAC,mBAAK,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,EAAE,cAAc,CAAC,EAAE;YACrI,WAAW;SACZ,CAAC,CAAC;QAEH,MAAM,EAAE,UAAU,EAAE,mBAAmB,EAAE,GAAG,IAAA,2DAAgD,EAAC,kBAAkB,CAAC,CAAC;QAEjH,IAAA,0CAAqB,EAAC,aAAa,IAAI,EAAE,CAAC,CAAC;QAC3C,MAAM,sBAAsB,GAAG,IAAA,kCAAa,EAAC,CAAC,GAAG,CAAC,aAAa,IAAI,EAAE,CAAC,EAAE,GAAG,UAAU,CAAC,aAAa,CAAC,CAAC,CAAC;QAEtG,2GAA2G;QAC3G,0GAA0G;QAC1G,kFAAkF;QAClF,MAAM,sBAAsB,GAAG,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,wBAAwB,CAAC,IAAI,MAAM,CAAC;QAC3F,IAAI,sBAAsB,CAAC,MAAM,GAAG,CAAC,EAAE;YACrC,MAAM,IAAI,KAAK,CAAC,uDAAuD,sBAAsB,EAAE,CAAC,CAAC;SAClG;QAED,MAAM,YAAY,GAAG,IAAI,uBAAY,EAAE,CAAC;QAExC,MAAM,sBAAsB,GAA2B;YACrD,KAAK,EAAE,IAAI;YACX,mBAAmB,EAAE;gBACnB,OAAO,EAAE,CAAC,gBAA2B,EAAE,IAAY,EAAE,EAAE,CAAC,IAAI,yBAAW,CAAC,gBAAgB,EAAE,IAAI,CAAC;aAChG;YACD,aAAa,EAAE;gBACb,OAAO,EAAE,CAAC,UAAqB,EAAE,OAAe,EAAE,UAAsB,EAAE,EAAE,CAC1E,IAAI,qBAAK,CAAC,UAAU,EAAE,OAAO,EAAE,EAAE,IAAI,EAAE,YAAY,CAAC,QAAQ,CAAC,UAAU,CAAC,QAAQ,EAAE,UAAU,CAAC,WAAW,CAAC,EAAE,CAAC;aAC/G;YACD,eAAe,EAAE;gBACf,sBAAsB,EAAE,sBAAsB;gBAC9C,OAAO,EAAE,KAAK,CAAC,OAAO,IAAI,EAAE;gBAC5B,GAAG,mBAAmB;aACvB;YACD,MAAM,EAAE,UAAU,CAAC,MAAM;YACzB,gBAAgB,EAAE,IAAA,0CAAqB,EAAC,sBAAsB,CAAC;YAC/D,uBAAuB,EAAE;gBACvB,kBAAkB,EAAE,kBAAkB,IAAI,EAAE;gBAC5C,GAAG,CAAC,iBAAiB,CAAC,CAAC,CAAC,EAAE,aAAa,EAAE,EAAE,UAAU,EAAE,iBAAiB,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;gBAC7F,eAAe,EAAE;oBACf,GAAG,UAAU,CAAC,yBAAyB;oBACvC,GAAG,eAAe;iBACnB;aACF;YACD,UAAU;YACV,YAAY,EAAE,aAAa,IAAI,EAAE;YACjC,cAAc,EAAE,kBAAkB,CAAC,CAAC,CAAC,IAAA,kCAAuB,EAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC,SAAS;YAC5F,mBAAmB,EAAE;gBACnB,GAAG,qCAA0B;gBAC7B,GAAG,CAAC,mBAAmB,IAAI,EAAE,CAAC;aAC/B;YACD,mIAAmI;YACnI,iBAAiB;YACjB,eAAe,EAAE,SAAS;YAC1B,GAAG,IAAA,oDAA+B,EAAC,UAAU,CAAC;SAC/C,CAAC;QAEF,IAAA,sCAAgB,EAAC,sBAAsB,CAAC,CAAC;QAEzC,IAAI,CAAC,aAAa,GAAG,IAAI,wBAAa,CAAC,IAAI,EAAE,sBAAsB,EAAE,EAAE,WAAW,EAAE,UAAU,CAAC,MAAM,EAAE,CAAC,CAAC;QAEzG,IAAI,CAAC,SAAS,GAAG,IAAA,gCAAqB,EAAC,IAAI,CAAC,CAAC;QAC7C,IAAI,CAAC,kBAAkB,GAAG,kBAAkB,CAAC;QAC7C,IAAI,CAAC,sBAAsB,GAAG,IAAA,oCAAyB,EAAC,YAAY,CAAC,cAAc,CAAC,CAAC;QACrF,IAAI,CAAC,WAAW,CAAC,qBAAqB,CAAC,CAAC;QAExC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,aAAa,CAAC,SAAS,CAAC;QACjE,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,aAAa,CAAC,cAAc,CAAC;QAC3E,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,aAAa,CAAC,eAAe,CAAC;QAC7E,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,SAAS,EAAE,UAAU,CAAC;IAClE,CAAC;IAED;;;OAGG;IACK,WAAW,CACjB,wBAAuD,IAAI,kEAAyC,CAAC,mBAAK,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;QAEpH,MAAM,KAAK,GAAG,mBAAK,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;QAC7B,MAAM,MAAM,GAAkB;YAC5B,OAAO,EAAE,GAAG;YACZ,OAAO,EAAE;gBACP,eAAe,EAAE,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,aAAa,CAAC,SAAS;gBACpE,qBAAqB,EAAE,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,aAAa,CAAC,cAAc;gBAC/E,4BAA4B,EAAE,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,aAAa,CAAC,kBAAkD;gBAC1H,gBAAgB,EAAE,KAAK,CAAC,MAAM;gBAC9B,0BAA0B,EAAE,IAAI,CAAC,aAAa,CAAC,gBAAgB;aAChE;SACF,CAAC;QAEF,IAAI,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,SAAS,EAAE;YACzC,MAAM,CAAC,OAAO,CAAC,gBAAgB,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,SAAS,CAAC,UAAU,CAAC;SACpF;QAED,MAAM,mBAAmB,GAAG,IAAA,2CAAgC,EAAC,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;QACxG,IAAI,mBAAmB,EAAE;YACvB,MAAM,CAAC,OAAO,CAAC,uCAAuC,GAAG,mBAAmB,CAAC;SAC9E;QAED,IAAI,IAAI,CAAC,kBAAkB,EAAE,OAAO,EAAE,WAAW,EAAE;YACjD,MAAM,CAAC,OAAO,CAAC,gCAAgC,GAAG,IAAI,CAAC,kBAAkB,EAAE,OAAO,EAAE,WAAW,CAAC;SACjG;QAED,qBAAqB,CAAC,qBAAqB,CAAC,yCAAgB,EAAE,MAAM,CAAC,CAAC;IACxE,CAAC;IAED;;;OAGG;IAEH;;;;;;OAMG;IACI,qBAAqB,CAAC,EAAU,EAAE,KAAa,EAAE,OAA2B;QACjF,OAAO,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,qBAAqB,CAAC,EAAE,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;IAC7E,CAAC;IAED;;;;;;;OAOG;IACI,0BAA0B,CAAC,EAAU,EAAE,MAAe,EAAE,OAA2B;QACxF,OAAO,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,0BAA0B,CAAC,EAAE,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;IACnF,CAAC;IAED;;;;;OAKG;IACI,wBAAwB,CAAC,EAAU,EAAE,QAAmB,EAAE,OAA2B;QAC1F,OAAO,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,wBAAwB,CAAC,EAAE,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;IACnF,CAAC;IAED;;;;;;OAMG;IACI,iBAAiB,CAAC,EAAU,EAAE,QAAgB,EAAE,OAA+B;QACpF,OAAO,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,iBAAiB,CAAC,EAAE,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;IAC5E,CAAC;IAED;;;;;;OAMG;IACI,mBAAmB,CAAC,EAAU,EAAE,cAAyB,EAAE,OAA2B;QAC3F,OAAO,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,mBAAmB,CAAC,EAAE,EAAE,cAAc,EAAE,OAAO,CAAC,CAAC;IACpF,CAAC;IAED;;;;;;OAMG;IACI,iBAAiB,CAAC,EAAU,EAAE,OAA2B;QAC9D,OAAO,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,iBAAiB,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC;IAClE,CAAC;IAED;;;;;;OAMG;IACI,uBAAuB,CAAC,EAAU,EAAE,MAAyB,EAAE,OAA2B;QAC/F,OAAO,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,uBAAuB,CAAC,EAAE,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;IAChF,CAAC;IAED;;;;;;;;OAQG;IACI,gBAAgB,CACrB,EAAU,EACV,iBAAqC,EACrC,WAAoB,EACpB,YAAqB,EACrB,OAA2B;QAE3B,OAAO,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,gBAAgB,CAAC,EAAE,EAAE,iBAAiB,EAAE,WAAW,EAAE,YAAY,EAAE,OAAO,CAAC,CAAC;IAC/G,CAAC;IAED;;;;;OAKG;IACI,WAAW,CAAC,EAAU,EAAE,KAA4B;QACzD,OAAO,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,cAAc,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC;IAC7D,CAAC;IAED;;;;OAIG;IACI,WAAW,CAAC,EAAU,EAAE,KAAuB;QACpD,OAAO,IAAI,6BAAe,CAAC,IAAI,EAAE,EAAE,EAAE;YACnC,GAAG,EAAE,IAAI,CAAC,SAAS,CAAC,UAAU;YAC9B,GAAG,KAAK;SACT,CAAC,CAAC;IACL,CAAC;;AA7SH,8CA8SC;;;AAED;;;;GAIG;AACH,MAAM,uCAAuC,GAAG,CAAC,KAAgB,EAAQ,EAAE;IACzE,MAAM,SAAS,GAAG,IAAA,iCAAgB,EAAC,KAAK,EAAE,IAAI,CAAC,CAAC;IAEhD,IAAI,6BAA6B,GAAG,KAAK,CAAC;IAC1C,IAAA,oCAAmB,EAAC,SAAS,EAAE,CAAC,IAAe,EAAE,EAAE;QACjD,IAAI,IAAI,YAAY,iBAAiB,IAAI,KAAK,KAAK,IAAI,EAAE;YACvD,6BAA6B,GAAG,IAAI,CAAC;SACtC;IACH,CAAC,CAAC,CAAC;IAEH,IAAI,6BAA6B,EAAE;QACjC,MAAM,IAAI,KAAK,CAAC,mDAAmD,CAAC,CAAC;KACtE;AACH,CAAC,CAAC;AAEF,MAAM,sBAAsB,GAAG,CAAC,UAAqC,EAAU,EAAE;IAC/E,MAAM,iBAAiB,GAAG,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,oBAAoB,CAAC,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,iBAAiB,EAAE,CAAC,CAAC;IAChI,MAAM,gBAAgB,GAAG,CAAC,UAAU,CAAC,6BAA6B,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,MAAM,CAAC,iBAAiB,EAAE,CAAC,CAAC;IAC1I,MAAM,WAAW,GAAG,CAAC,GAAG,IAAI,GAAG,CAAC,CAAC,GAAG,iBAAiB,EAAE,GAAG,gBAAgB,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;IACrF,OAAO,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AAC/B,CAAC,CAAC","sourcesContent":["import * as path from 'path';\nimport { Construct } from 'constructs';\nimport { ExecuteTransformConfig, executeTransform } from '@aws-amplify/graphql-transformer';\nimport { NestedStack, Stack } from 'aws-cdk-lib';\nimport { Asset } from 'aws-cdk-lib/aws-s3-assets';\nimport { AssetProps } from '@aws-amplify/graphql-transformer-interfaces';\nimport { AttributionMetadataStorage, StackMetadataBackendOutputStorageStrategy } from '@aws-amplify/backend-output-storage';\nimport { graphqlOutputKey } from '@aws-amplify/backend-output-schemas';\nimport type { GraphqlOutput, AwsAppsyncAuthenticationType } from '@aws-amplify/backend-output-schemas';\nimport {\n  AppsyncFunction,\n  DataSourceOptions,\n  DynamoDbDataSource,\n  ElasticsearchDataSource,\n  EventBridgeDataSource,\n  ExtendedResolverProps,\n  HttpDataSource,\n  HttpDataSourceOptions,\n  LambdaDataSource,\n  NoneDataSource,\n  OpenSearchDataSource,\n  RdsDataSource,\n  Resolver,\n} from 'aws-cdk-lib/aws-appsync';\nimport { ITable } from 'aws-cdk-lib/aws-dynamodb';\nimport { IDomain } from 'aws-cdk-lib/aws-elasticsearch';\nimport { IDomain as IOpenSearchDomain } from 'aws-cdk-lib/aws-opensearchservice';\nimport { IEventBus } from 'aws-cdk-lib/aws-events';\nimport { IFunction } from 'aws-cdk-lib/aws-lambda';\nimport { IServerlessCluster } from 'aws-cdk-lib/aws-rds';\nimport { ISecret } from 'aws-cdk-lib/aws-secretsmanager';\nimport { parseUserDefinedSlots, validateFunctionSlots, separateSlots } from './internal/user-defined-slots';\nimport type {\n  AmplifyGraphqlApiResources,\n  AmplifyGraphqlApiProps,\n  FunctionSlot,\n  IBackendOutputStorageStrategy,\n  AddFunctionProps,\n  ConflictResolution,\n  IAmplifyGraphqlDefinition,\n} from './types';\nimport {\n  convertAuthorizationModesToTransformerAuthConfig,\n  convertToResolverConfig,\n  defaultTranslationBehavior,\n  AssetManager,\n  getGeneratedResources,\n  getGeneratedFunctionSlots,\n  CodegenAssets,\n  getAdditionalAuthenticationTypes,\n} from './internal';\nimport { getStackForScope, walkAndProcessNodes } from './internal/construct-tree';\nimport { getDataSourceStrategiesProvider } from './internal/data-source-config';\n\n/**\n * L3 Construct which invokes the Amplify Transformer Pattern over an input Graphql Schema.\n *\n * This can be used to quickly define appsync apis which support full CRUD+List and Subscriptions, relationships,\n * auth, search over data, the ability to inject custom business logic and query/mutation operations, and connect to ML services.\n *\n * For more information, refer to the docs links below:\n * Data Modeling - https://docs.amplify.aws/cli/graphql/data-modeling/\n * Authorization - https://docs.amplify.aws/cli/graphql/authorization-rules/\n * Custom Business Logic - https://docs.amplify.aws/cli/graphql/custom-business-logic/\n * Search - https://docs.amplify.aws/cli/graphql/search-and-result-aggregations/\n * ML Services - https://docs.amplify.aws/cli/graphql/connect-to-machine-learning-services/\n *\n * For a full reference of the supported custom graphql directives - https://docs.amplify.aws/cli/graphql/directives-reference/\n *\n * The output of this construct is a mapping of L2 or L1 resources generated by the transformer, which generally follow the access pattern\n *\n * ```typescript\n *   const api = new AmplifyGraphQlApi(this, 'api', { <params> });\n *   // Access L2 resources under `.resources`\n *   api.resources.tables[\"Todo\"].tableArn;\n *\n *   // Access L1 resources under `.resources.cfnResources`\n *   api.resources.cfnResources.cfnGraphqlApi.xrayEnabled = true;\n *   Object.values(api.resources.cfnResources.cfnTables).forEach(table => {\n *     table.pointInTimeRecoverySpecification = { pointInTimeRecoveryEnabled: false };\n *   });\n * ```\n * `resources.<ResourceType>.<ResourceName>` - you can then perform any CDK action on these resulting resoureces.\n */\nexport class AmplifyGraphqlApi extends Construct {\n  /**\n   * Generated L1 and L2 CDK resources.\n   */\n  public readonly resources: AmplifyGraphqlApiResources;\n\n  /**\n   * Generated assets required for codegen steps. Persisted in order to render as part of the output strategy.\n   */\n  private readonly codegenAssets: CodegenAssets;\n\n  /**\n   * Resolvers generated by the transform process, persisted on the side in order to facilitate pulling a manifest\n   * for the purposes of inspecting and producing overrides.\n   */\n  public readonly generatedFunctionSlots: FunctionSlot[];\n\n  /**\n   * Graphql URL For the generated API. May be a CDK Token.\n   */\n  public readonly graphqlUrl: string;\n\n  /**\n   * Realtime URL For the generated API. May be a CDK Token.\n   */\n  public readonly realtimeUrl: string;\n\n  /**\n   * Generated Api Key if generated. May be a CDK Token.\n   */\n  public readonly apiKey: string | undefined;\n\n  /**\n   * Generated Api Id. May be a CDK Token.\n   */\n  public readonly apiId: string;\n\n  /**\n   * Conflict resolution setting\n   */\n  private readonly conflictResolution: ConflictResolution | undefined;\n\n  /**\n   * Be very careful editing this value. This is the string that is used to identify graphql stacks in BI metrics\n   */\n  private readonly stackType = 'api-AppSync';\n\n  /**\n   * New AmplifyGraphqlApi construct, this will create an appsync api with authorization, a schema, and all necessary resolvers, functions,\n   * and datasources.\n   * @param scope the scope to create this construct within.\n   * @param id the id to use for this api.\n   * @param props the properties used to configure the generated api.\n   */\n  constructor(scope: Construct, id: string, props: AmplifyGraphqlApiProps) {\n    super(scope, id);\n\n    validateNoOtherAmplifyGraphqlApiInStack(this);\n\n    const {\n      definition,\n      authorizationModes,\n      conflictResolution,\n      functionSlots,\n      transformerPlugins,\n      predictionsBucket,\n      stackMappings,\n      translationBehavior,\n      functionNameMap,\n      outputStorageStrategy,\n    } = props;\n\n    const dataSources = getMetadataDataSources(definition);\n\n    new AttributionMetadataStorage().storeAttributionMetadata(Stack.of(scope), this.stackType, path.join(__dirname, '..', 'package.json'), {\n      dataSources,\n    });\n\n    const { authConfig, authSynthParameters } = convertAuthorizationModesToTransformerAuthConfig(authorizationModes);\n\n    validateFunctionSlots(functionSlots ?? []);\n    const separatedFunctionSlots = separateSlots([...(functionSlots ?? []), ...definition.functionSlots]);\n\n    // Allow amplifyEnvironmentName to be retrieve from context, and use value 'NONE' if no value can be found.\n    // amplifyEnvironmentName is required for logical id suffixing, as well as Exports from the nested stacks.\n    // Allow export so customers can reuse the env in their own references downstream.\n    const amplifyEnvironmentName = this.node.tryGetContext('amplifyEnvironmentName') ?? 'NONE';\n    if (amplifyEnvironmentName.length > 8) {\n      throw new Error(`or cdk --context env must have a length <= 8, found ${amplifyEnvironmentName}`);\n    }\n\n    const assetManager = new AssetManager();\n\n    const executeTransformConfig: ExecuteTransformConfig = {\n      scope: this,\n      nestedStackProvider: {\n        provide: (nestedStackScope: Construct, name: string) => new NestedStack(nestedStackScope, name),\n      },\n      assetProvider: {\n        provide: (assetScope: Construct, assetId: string, assetProps: AssetProps) =>\n          new Asset(assetScope, assetId, { path: assetManager.addAsset(assetProps.fileName, assetProps.fileContent) }),\n      },\n      synthParameters: {\n        amplifyEnvironmentName: amplifyEnvironmentName,\n        apiName: props.apiName ?? id,\n        ...authSynthParameters,\n      },\n      schema: definition.schema,\n      userDefinedSlots: parseUserDefinedSlots(separatedFunctionSlots),\n      transformersFactoryArgs: {\n        customTransformers: transformerPlugins ?? [],\n        ...(predictionsBucket ? { storageConfig: { bucketName: predictionsBucket.bucketName } } : {}),\n        functionNameMap: {\n          ...definition.referencedLambdaFunctions,\n          ...functionNameMap,\n        },\n      },\n      authConfig,\n      stackMapping: stackMappings ?? {},\n      resolverConfig: conflictResolution ? convertToResolverConfig(conflictResolution) : undefined,\n      transformParameters: {\n        ...defaultTranslationBehavior,\n        ...(translationBehavior ?? {}),\n      },\n      // CDK construct uses a custom resource. We'll define this explicitly here to remind ourselves that this value is unused in the CDK\n      // construct flow\n      rdsLayerMapping: undefined,\n      ...getDataSourceStrategiesProvider(definition),\n    };\n\n    executeTransform(executeTransformConfig);\n\n    this.codegenAssets = new CodegenAssets(this, 'AmplifyCodegenAssets', { modelSchema: definition.schema });\n\n    this.resources = getGeneratedResources(this);\n    this.conflictResolution = conflictResolution;\n    this.generatedFunctionSlots = getGeneratedFunctionSlots(assetManager.resolverAssets);\n    this.storeOutput(outputStorageStrategy);\n\n    this.apiId = this.resources.cfnResources.cfnGraphqlApi.attrApiId;\n    this.graphqlUrl = this.resources.cfnResources.cfnGraphqlApi.attrGraphQlUrl;\n    this.realtimeUrl = this.resources.cfnResources.cfnGraphqlApi.attrRealtimeUrl;\n    this.apiKey = this.resources.cfnResources.cfnApiKey?.attrApiKey;\n  }\n\n  /**\n   * Stores graphql api output to be used for client config generation\n   * @param outputStorageStrategy Strategy to store construct outputs. If no strategy is provided a default strategy will be used.\n   */\n  private storeOutput(\n    outputStorageStrategy: IBackendOutputStorageStrategy = new StackMetadataBackendOutputStorageStrategy(Stack.of(this)),\n  ): void {\n    const stack = Stack.of(this);\n    const output: GraphqlOutput = {\n      version: '1',\n      payload: {\n        awsAppsyncApiId: this.resources.cfnResources.cfnGraphqlApi.attrApiId,\n        awsAppsyncApiEndpoint: this.resources.cfnResources.cfnGraphqlApi.attrGraphQlUrl,\n        awsAppsyncAuthenticationType: this.resources.cfnResources.cfnGraphqlApi.authenticationType as AwsAppsyncAuthenticationType,\n        awsAppsyncRegion: stack.region,\n        amplifyApiModelSchemaS3Uri: this.codegenAssets.modelSchemaS3Uri,\n      },\n    };\n\n    if (this.resources.cfnResources.cfnApiKey) {\n      output.payload.awsAppsyncApiKey = this.resources.cfnResources.cfnApiKey.attrApiKey;\n    }\n\n    const additionalAuthTypes = getAdditionalAuthenticationTypes(this.resources.cfnResources.cfnGraphqlApi);\n    if (additionalAuthTypes) {\n      output.payload.awsAppsyncAdditionalAuthenticationTypes = additionalAuthTypes;\n    }\n\n    if (this.conflictResolution?.project?.handlerType) {\n      output.payload.awsAppsyncConflictResolutionMode = this.conflictResolution?.project?.handlerType;\n    }\n\n    outputStorageStrategy.addBackendOutputEntry(graphqlOutputKey, output);\n  }\n\n  /**\n   * The following are proxy methods to the L2 IGraphqlApi interface, to facilitate easier use of the L3 without needing\n   * to access the underlying resources.\n   */\n\n  /**\n   * Add a new DynamoDB data source to this API. This is a proxy method to the L2 GraphqlApi Construct.\n   * @param id The data source's id.\n   * @param table The DynamoDB table backing this data source.\n   * @param options The optional configuration for this data source.\n   * @returns the generated data source.\n   */\n  public addDynamoDbDataSource(id: string, table: ITable, options?: DataSourceOptions): DynamoDbDataSource {\n    return this.resources.graphqlApi.addDynamoDbDataSource(id, table, options);\n  }\n\n  /**\n   * Add a new elasticsearch data source to this API. This is a proxy method to the L2 GraphqlApi Construct.\n   * @deprecated use `addOpenSearchDataSource`\n   * @param id The data source's id.\n   * @param domain The elasticsearch domain for this data source.\n   * @param options The optional configuration for this data source.\n   * @returns the generated data source.\n   */\n  public addElasticsearchDataSource(id: string, domain: IDomain, options?: DataSourceOptions): ElasticsearchDataSource {\n    return this.resources.graphqlApi.addElasticsearchDataSource(id, domain, options);\n  }\n\n  /**\n   * Add an EventBridge data source to this api. This is a proxy method to the L2 GraphqlApi Construct.\n   * @param id The data source's id.\n   * @param eventBus The EventBridge EventBus on which to put events.\n   * @param options The optional configuration for this data source.\n   */\n  public addEventBridgeDataSource(id: string, eventBus: IEventBus, options?: DataSourceOptions): EventBridgeDataSource {\n    return this.resources.graphqlApi.addEventBridgeDataSource(id, eventBus, options);\n  }\n\n  /**\n   * Add a new http data source to this API. This is a proxy method to the L2 GraphqlApi Construct.\n   * @param id The data source's id.\n   * @param endpoint The http endpoint.\n   * @param options The optional configuration for this data source.\n   * @returns the generated data source.\n   */\n  public addHttpDataSource(id: string, endpoint: string, options?: HttpDataSourceOptions): HttpDataSource {\n    return this.resources.graphqlApi.addHttpDataSource(id, endpoint, options);\n  }\n\n  /**\n   * Add a new Lambda data source to this API. This is a proxy method to the L2 GraphqlApi Construct.\n   * @param id The data source's id.\n   * @param lambdaFunction The Lambda function to call to interact with this data source.\n   * @param options The optional configuration for this data source.\n   * @returns the generated data source.\n   */\n  public addLambdaDataSource(id: string, lambdaFunction: IFunction, options?: DataSourceOptions): LambdaDataSource {\n    return this.resources.graphqlApi.addLambdaDataSource(id, lambdaFunction, options);\n  }\n\n  /**\n   * Add a new dummy data source to this API. This is a proxy method to the L2 GraphqlApi Construct.\n   * Useful for pipeline resolvers and for backend changes that don't require a data source.\n   * @param id The data source's id.\n   * @param options The optional configuration for this data source.\n   * @returns the generated data source.\n   */\n  public addNoneDataSource(id: string, options?: DataSourceOptions): NoneDataSource {\n    return this.resources.graphqlApi.addNoneDataSource(id, options);\n  }\n\n  /**\n   * dd a new OpenSearch data source to this API. This is a proxy method to the L2 GraphqlApi Construct.\n   * @param id The data source's id.\n   * @param domain The OpenSearch domain for this data source.\n   * @param options The optional configuration for this data source.\n   * @returns the generated data source.\n   */\n  public addOpenSearchDataSource(id: string, domain: IOpenSearchDomain, options?: DataSourceOptions): OpenSearchDataSource {\n    return this.resources.graphqlApi.addOpenSearchDataSource(id, domain, options);\n  }\n\n  /**\n   * Add a new Rds data source to this API. This is a proxy method to the L2 GraphqlApi Construct.\n   * @param id The data source's id.\n   * @param serverlessCluster The serverless cluster to interact with this data source.\n   * @param secretStore The secret store that contains the username and password for the serverless cluster.\n   * @param databaseName The optional name of the database to use within the cluster.\n   * @param options The optional configuration for this data source.\n   * @returns the generated data source.\n   */\n  public addRdsDataSource(\n    id: string,\n    serverlessCluster: IServerlessCluster,\n    secretStore: ISecret,\n    databaseName?: string,\n    options?: DataSourceOptions,\n  ): RdsDataSource {\n    return this.resources.graphqlApi.addRdsDataSource(id, serverlessCluster, secretStore, databaseName, options);\n  }\n\n  /**\n   * Add a resolver to the api. This is a proxy method to the L2 GraphqlApi Construct.\n   * @param id The resolver's id.\n   * @param props the resolver properties.\n   * @returns the generated resolver.\n   */\n  public addResolver(id: string, props: ExtendedResolverProps): Resolver {\n    return this.resources.graphqlApi.createResolver(id, props);\n  }\n\n  /**\n   * Add an appsync function to the api.\n   * @param id the function's id.\n   * @returns the generated appsync function.\n   */\n  public addFunction(id: string, props: AddFunctionProps): AppsyncFunction {\n    return new AppsyncFunction(this, id, {\n      api: this.resources.graphqlApi,\n      ...props,\n    });\n  }\n}\n\n/**\n * Given the provided scope, walk the node tree, and throw an exception if any other AmplifyGraphqlApi constructs\n * are found in the stack.\n * @param scope the scope this construct is created in.\n */\nconst validateNoOtherAmplifyGraphqlApiInStack = (scope: Construct): void => {\n  const rootStack = getStackForScope(scope, true);\n\n  let wasOtherAmplifyGraphlApiFound = false;\n  walkAndProcessNodes(rootStack, (node: Construct) => {\n    if (node instanceof AmplifyGraphqlApi && scope !== node) {\n      wasOtherAmplifyGraphlApiFound = true;\n    }\n  });\n\n  if (wasOtherAmplifyGraphlApiFound) {\n    throw new Error('Only one AmplifyGraphqlApi is expected in a stack');\n  }\n};\n\nconst getMetadataDataSources = (definition: IAmplifyGraphqlDefinition): string => {\n  const dataSourceDbTypes = Object.values(definition.dataSourceStrategies).map((strategy) => strategy.dbType.toLocaleLowerCase());\n  const customSqlDbTypes = (definition.customSqlDataSourceStrategies ?? []).map((strategy) => strategy.strategy.dbType.toLocaleLowerCase());\n  const dataSources = [...new Set([...dataSourceDbTypes, ...customSqlDbTypes])].sort();\n  return dataSources.join(',');\n};\n"]}
@@ -1,5 +1,5 @@
1
1
  import { IAmplifyGraphqlDefinition } from './types';
2
- import { ModelDataSourceStrategy } from './model-datasource-strategy';
2
+ import { ModelDataSourceStrategy } from './model-datasource-strategy-types';
3
3
  export declare const DEFAULT_MODEL_DATA_SOURCE_STRATEGY: ModelDataSourceStrategy;
4
4
  /**
5
5
  * Class exposing utilities to produce IAmplifyGraphqlDefinition objects given various inputs.
@@ -7,13 +7,9 @@ export declare const DEFAULT_MODEL_DATA_SOURCE_STRATEGY: ModelDataSourceStrategy
7
7
  export declare class AmplifyGraphqlDefinition {
8
8
  /**
9
9
  * Produce a schema definition from a string input.
10
- *
11
- * **NOTE** The 'dataSourceStrategy' configuration option is in preview and is not recommended to use with production systems.
12
- *
13
10
  * @param schema the graphql input as a string
14
11
  * @param dataSourceStrategy the provisioning definition for datasources that resolve `@model`s and custom SQL statements in this schema.
15
12
  * The DynamoDB from CloudFormation will be used by default.
16
- * @experimental dataSourceStrategy
17
13
  * @returns a fully formed amplify graphql definition
18
14
  */
19
15
  static fromString(schema: string, dataSourceStrategy?: ModelDataSourceStrategy): IAmplifyGraphqlDefinition;
@@ -25,10 +21,6 @@ export declare class AmplifyGraphqlDefinition {
25
21
  static fromFiles(...filePaths: string[]): IAmplifyGraphqlDefinition;
26
22
  /**
27
23
  * Convert one or more appsync SchemaFile objects into an Amplify Graphql Schema
28
- *
29
- * **NOTE** This API is in preview and is not recommended to use with production systems.
30
- *
31
- * @experimental
32
24
  * @param filePaths one or more paths to the graphql files to process
33
25
  * @param dataSourceStrategy the provisioning definition for datasources that resolve `@model`s in this schema. The DynamoDB from
34
26
  * CloudFormation will be used by default.
@@ -37,10 +29,6 @@ export declare class AmplifyGraphqlDefinition {
37
29
  static fromFilesAndStrategy(filePaths: string | string[], dataSourceStrategy?: ModelDataSourceStrategy): IAmplifyGraphqlDefinition;
38
30
  /**
39
31
  * Combines multiple IAmplifyGraphqlDefinitions into a single definition.
40
- *
41
- * **NOTE** This API is in preview and is not recommended to use with production systems.
42
- *
43
- * @experimental
44
32
  * @param definitions the definitions to combine
45
33
  */
46
34
  static combine(definitions: IAmplifyGraphqlDefinition[]): IAmplifyGraphqlDefinition;
@@ -5,6 +5,7 @@ exports.AmplifyGraphqlDefinition = exports.DEFAULT_MODEL_DATA_SOURCE_STRATEGY =
5
5
  const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
6
  const os = require("os");
7
7
  const aws_appsync_1 = require("aws-cdk-lib/aws-appsync");
8
+ const graphql_transformer_core_1 = require("@aws-amplify/graphql-transformer-core");
8
9
  const internal_1 = require("./internal");
9
10
  const data_source_config_1 = require("./internal/data-source-config");
10
11
  exports.DEFAULT_MODEL_DATA_SOURCE_STRATEGY = {
@@ -17,21 +18,18 @@ exports.DEFAULT_MODEL_DATA_SOURCE_STRATEGY = {
17
18
  class AmplifyGraphqlDefinition {
18
19
  /**
19
20
  * Produce a schema definition from a string input.
20
- *
21
- * **NOTE** The 'dataSourceStrategy' configuration option is in preview and is not recommended to use with production systems.
22
- *
23
21
  * @param schema the graphql input as a string
24
22
  * @param dataSourceStrategy the provisioning definition for datasources that resolve `@model`s and custom SQL statements in this schema.
25
23
  * The DynamoDB from CloudFormation will be used by default.
26
- * @experimental dataSourceStrategy
27
24
  * @returns a fully formed amplify graphql definition
28
25
  */
29
26
  static fromString(schema, dataSourceStrategy = exports.DEFAULT_MODEL_DATA_SOURCE_STRATEGY) {
27
+ (0, data_source_config_1.validateDataSourceStrategy)(dataSourceStrategy);
30
28
  return {
31
29
  schema,
32
30
  functionSlots: [],
33
31
  referencedLambdaFunctions: {},
34
- dataSourceStrategies: (0, internal_1.constructDataSourceStrategyMap)(schema, dataSourceStrategy),
32
+ dataSourceStrategies: (0, internal_1.constructDataSourceStrategies)(schema, dataSourceStrategy),
35
33
  customSqlDataSourceStrategies: (0, data_source_config_1.constructCustomSqlDataSourceStrategies)(schema, dataSourceStrategy),
36
34
  };
37
35
  }
@@ -49,10 +47,6 @@ class AmplifyGraphqlDefinition {
49
47
  }
50
48
  /**
51
49
  * Convert one or more appsync SchemaFile objects into an Amplify Graphql Schema
52
- *
53
- * **NOTE** This API is in preview and is not recommended to use with production systems.
54
- *
55
- * @experimental
56
50
  * @param filePaths one or more paths to the graphql files to process
57
51
  * @param dataSourceStrategy the provisioning definition for datasources that resolve `@model`s in this schema. The DynamoDB from
58
52
  * CloudFormation will be used by default.
@@ -67,10 +61,6 @@ class AmplifyGraphqlDefinition {
67
61
  }
68
62
  /**
69
63
  * Combines multiple IAmplifyGraphqlDefinitions into a single definition.
70
- *
71
- * **NOTE** This API is in preview and is not recommended to use with production systems.
72
- *
73
- * @experimental
74
64
  * @param definitions the definitions to combine
75
65
  */
76
66
  static combine(definitions) {
@@ -80,15 +70,36 @@ class AmplifyGraphqlDefinition {
80
70
  if (definitions.length === 1) {
81
71
  return definitions[0];
82
72
  }
73
+ // A strategy will be present multiple times in a given definition: once per model. We'll create a unique list per definition to ensure
74
+ // no reuse across definitions.
75
+ let combinedStrategyNames = [];
76
+ for (const definition of definitions) {
77
+ const definitionStrategyNames = new Set();
78
+ for (const strategy of Object.values(definition.dataSourceStrategies)) {
79
+ if (!(0, graphql_transformer_core_1.isSqlStrategy)(strategy)) {
80
+ continue;
81
+ }
82
+ const strategyName = strategy.name;
83
+ if (combinedStrategyNames.includes(strategyName)) {
84
+ throw new Error(`The SQL-based ModelDataSourceStrategy '${strategyName}' was found in multiple definitions, but a strategy name cannot be ` +
85
+ "shared between definitions. To specify a SQL-based API with schemas across multiple files, use 'fromFilesAndStrategy'");
86
+ }
87
+ definitionStrategyNames.add(strategyName);
88
+ }
89
+ combinedStrategyNames = [...combinedStrategyNames, ...definitionStrategyNames];
90
+ }
91
+ const customSqlDataSourceStrategies = definitions.reduce((acc, cur) => [...acc, ...(cur.customSqlDataSourceStrategies ?? [])], []);
92
+ const mergedSchema = (0, data_source_config_1.schemaByMergingDefinitions)(definitions);
83
93
  return {
84
- schema: definitions.map((def) => def.schema).join(os.EOL),
94
+ schema: mergedSchema,
85
95
  functionSlots: [],
86
96
  referencedLambdaFunctions: definitions.reduce((acc, cur) => ({ ...acc, ...cur.referencedLambdaFunctions }), {}),
87
97
  dataSourceStrategies: definitions.reduce((acc, cur) => ({ ...acc, ...cur.dataSourceStrategies }), {}),
98
+ customSqlDataSourceStrategies,
88
99
  };
89
100
  }
90
101
  }
91
102
  exports.AmplifyGraphqlDefinition = AmplifyGraphqlDefinition;
92
103
  _a = JSII_RTTI_SYMBOL_1;
93
- AmplifyGraphqlDefinition[_a] = { fqn: "@aws-amplify/graphql-api-construct.AmplifyGraphqlDefinition", version: "1.4.3" };
94
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"amplify-graphql-definition.js","sourceRoot":"","sources":["../src/amplify-graphql-definition.ts"],"names":[],"mappings":";;;;;AAAA,yBAAyB;AACzB,yDAAqD;AAErD,yCAA4D;AAE5D,sEAAuF;AAE1E,QAAA,kCAAkC,GAA4B;IACzE,MAAM,EAAE,UAAU;IAClB,iBAAiB,EAAE,SAAS;CAC7B,CAAC;AAEF;;GAEG;AACH,MAAa,wBAAwB;IACnC;;;;;;;;;;OAUG;IACH,MAAM,CAAC,UAAU,CACf,MAAc,EACd,qBAA8C,0CAAkC;QAEhF,OAAO;YACL,MAAM;YACN,aAAa,EAAE,EAAE;YACjB,yBAAyB,EAAE,EAAE;YAC7B,oBAAoB,EAAE,IAAA,yCAA8B,EAAC,MAAM,EAAE,kBAAkB,CAAC;YAChF,6BAA6B,EAAE,IAAA,2DAAsC,EAAC,MAAM,EAAE,kBAAkB,CAAC;SAClG,CAAC;IACJ,CAAC;IAED;;;;OAIG;IACH,MAAM,CAAC,SAAS,CAAC,GAAG,SAAmB;QACrC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;YAC7B,SAAS,GAAG,CAAC,SAAS,CAAC,CAAC;SACzB;QACD,MAAM,MAAM,GAAG,SAAS,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,IAAI,wBAAU,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;QACjG,OAAO,wBAAwB,CAAC,UAAU,CAAC,MAAM,EAAE,0CAAkC,CAAC,CAAC;IACzF,CAAC;IAED;;;;;;;;;;OAUG;IACH,MAAM,CAAC,oBAAoB,CACzB,SAA4B,EAC5B,qBAA8C,0CAAkC;QAEhF,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;YAC7B,SAAS,GAAG,CAAC,SAAS,CAAC,CAAC;SACzB;QACD,MAAM,MAAM,GAAG,SAAS,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,IAAI,wBAAU,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;QACjG,OAAO,wBAAwB,CAAC,UAAU,CAAC,MAAM,EAAE,kBAAkB,CAAC,CAAC;IACzE,CAAC;IAED;;;;;;;OAOG;IACH,MAAM,CAAC,OAAO,CAAC,WAAwC;QACrD,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE;YAC5B,MAAM,IAAI,KAAK,CAAC,qDAAqD,CAAC,CAAC;SACxE;QACD,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE;YAC5B,OAAO,WAAW,CAAC,CAAC,CAAC,CAAC;SACvB;QACD,OAAO;YACL,MAAM,EAAE,WAAW,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC;YACzD,aAAa,EAAE,EAAE;YACjB,yBAAyB,EAAE,WAAW,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,CAAC,yBAAyB,EAAE,CAAC,EAAE,EAAE,CAAC;YAC/G,oBAAoB,EAAE,WAAW,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,CAAC,oBAAoB,EAAE,CAAC,EAAE,EAAE,CAAC;SACtG,CAAC;IACJ,CAAC;;AAjFH,4DAkFC","sourcesContent":["import * as os from 'os';\nimport { SchemaFile } from 'aws-cdk-lib/aws-appsync';\nimport { IAmplifyGraphqlDefinition } from './types';\nimport { constructDataSourceStrategyMap } from './internal';\nimport { ModelDataSourceStrategy } from './model-datasource-strategy';\nimport { constructCustomSqlDataSourceStrategies } from './internal/data-source-config';\n\nexport const DEFAULT_MODEL_DATA_SOURCE_STRATEGY: ModelDataSourceStrategy = {\n  dbType: 'DYNAMODB',\n  provisionStrategy: 'DEFAULT',\n};\n\n/**\n * Class exposing utilities to produce IAmplifyGraphqlDefinition objects given various inputs.\n */\nexport class AmplifyGraphqlDefinition {\n  /**\n   * Produce a schema definition from a string input.\n   *\n   * **NOTE** The 'dataSourceStrategy' configuration option is in preview and is not recommended to use with production systems.\n   *\n   * @param schema the graphql input as a string\n   * @param dataSourceStrategy the provisioning definition for datasources that resolve `@model`s and custom SQL statements in this schema.\n   * The DynamoDB from CloudFormation will be used by default.\n   * @experimental dataSourceStrategy\n   * @returns a fully formed amplify graphql definition\n   */\n  static fromString(\n    schema: string,\n    dataSourceStrategy: ModelDataSourceStrategy = DEFAULT_MODEL_DATA_SOURCE_STRATEGY,\n  ): IAmplifyGraphqlDefinition {\n    return {\n      schema,\n      functionSlots: [],\n      referencedLambdaFunctions: {},\n      dataSourceStrategies: constructDataSourceStrategyMap(schema, dataSourceStrategy),\n      customSqlDataSourceStrategies: constructCustomSqlDataSourceStrategies(schema, dataSourceStrategy),\n    };\n  }\n\n  /**\n   * Convert one or more appsync SchemaFile objects into an Amplify Graphql Schema, binding them to a DynamoDB data source.\n   * @param filePaths one or more paths to the graphql files to process\n   * @returns a fully formed amplify graphql definition, whose models will be resolved by DynamoDB tables created during deployment.\n   */\n  static fromFiles(...filePaths: string[]): IAmplifyGraphqlDefinition {\n    if (!Array.isArray(filePaths)) {\n      filePaths = [filePaths];\n    }\n    const schema = filePaths.map((filePath) => new SchemaFile({ filePath }).definition).join(os.EOL);\n    return AmplifyGraphqlDefinition.fromString(schema, DEFAULT_MODEL_DATA_SOURCE_STRATEGY);\n  }\n\n  /**\n   * Convert one or more appsync SchemaFile objects into an Amplify Graphql Schema\n   *\n   * **NOTE** This API is in preview and is not recommended to use with production systems.\n   *\n   * @experimental\n   * @param filePaths one or more paths to the graphql files to process\n   * @param dataSourceStrategy the provisioning definition for datasources that resolve `@model`s in this schema. The DynamoDB from\n   * CloudFormation will be used by default.\n   * @returns a fully formed amplify graphql definition\n   */\n  static fromFilesAndStrategy(\n    filePaths: string | string[],\n    dataSourceStrategy: ModelDataSourceStrategy = DEFAULT_MODEL_DATA_SOURCE_STRATEGY,\n  ): IAmplifyGraphqlDefinition {\n    if (!Array.isArray(filePaths)) {\n      filePaths = [filePaths];\n    }\n    const schema = filePaths.map((filePath) => new SchemaFile({ filePath }).definition).join(os.EOL);\n    return AmplifyGraphqlDefinition.fromString(schema, dataSourceStrategy);\n  }\n\n  /**\n   * Combines multiple IAmplifyGraphqlDefinitions into a single definition.\n   *\n   * **NOTE** This API is in preview and is not recommended to use with production systems.\n   *\n   * @experimental\n   * @param definitions the definitions to combine\n   */\n  static combine(definitions: IAmplifyGraphqlDefinition[]): IAmplifyGraphqlDefinition {\n    if (definitions.length === 0) {\n      throw new Error('The definitions of amplify GraphQL cannot be empty.');\n    }\n    if (definitions.length === 1) {\n      return definitions[0];\n    }\n    return {\n      schema: definitions.map((def) => def.schema).join(os.EOL),\n      functionSlots: [],\n      referencedLambdaFunctions: definitions.reduce((acc, cur) => ({ ...acc, ...cur.referencedLambdaFunctions }), {}),\n      dataSourceStrategies: definitions.reduce((acc, cur) => ({ ...acc, ...cur.dataSourceStrategies }), {}),\n    };\n  }\n}\n"]}
104
+ AmplifyGraphqlDefinition[_a] = { fqn: "@aws-amplify/graphql-api-construct.AmplifyGraphqlDefinition", version: "1.5.0" };
105
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"amplify-graphql-definition.js","sourceRoot":"","sources":["../src/amplify-graphql-definition.ts"],"names":[],"mappings":";;;;;AAAA,yBAAyB;AACzB,yDAAqD;AACrD,oFAAsE;AAEtE,yCAA2D;AAE3D,sEAIuC;AAE1B,QAAA,kCAAkC,GAA4B;IACzE,MAAM,EAAE,UAAU;IAClB,iBAAiB,EAAE,SAAS;CAC7B,CAAC;AAEF;;GAEG;AACH,MAAa,wBAAwB;IACnC;;;;;;OAMG;IACH,MAAM,CAAC,UAAU,CACf,MAAc,EACd,qBAA8C,0CAAkC;QAEhF,IAAA,+CAA0B,EAAC,kBAAkB,CAAC,CAAC;QAC/C,OAAO;YACL,MAAM;YACN,aAAa,EAAE,EAAE;YACjB,yBAAyB,EAAE,EAAE;YAC7B,oBAAoB,EAAE,IAAA,wCAA6B,EAAC,MAAM,EAAE,kBAAkB,CAAC;YAC/E,6BAA6B,EAAE,IAAA,2DAAsC,EAAC,MAAM,EAAE,kBAAkB,CAAC;SAClG,CAAC;IACJ,CAAC;IAED;;;;OAIG;IACH,MAAM,CAAC,SAAS,CAAC,GAAG,SAAmB;QACrC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;YAC7B,SAAS,GAAG,CAAC,SAAS,CAAC,CAAC;SACzB;QACD,MAAM,MAAM,GAAG,SAAS,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,IAAI,wBAAU,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;QACjG,OAAO,wBAAwB,CAAC,UAAU,CAAC,MAAM,EAAE,0CAAkC,CAAC,CAAC;IACzF,CAAC;IAED;;;;;;OAMG;IACH,MAAM,CAAC,oBAAoB,CACzB,SAA4B,EAC5B,qBAA8C,0CAAkC;QAEhF,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;YAC7B,SAAS,GAAG,CAAC,SAAS,CAAC,CAAC;SACzB;QACD,MAAM,MAAM,GAAG,SAAS,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,IAAI,wBAAU,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;QACjG,OAAO,wBAAwB,CAAC,UAAU,CAAC,MAAM,EAAE,kBAAkB,CAAC,CAAC;IACzE,CAAC;IAED;;;OAGG;IACH,MAAM,CAAC,OAAO,CAAC,WAAwC;QACrD,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE;YAC5B,MAAM,IAAI,KAAK,CAAC,qDAAqD,CAAC,CAAC;SACxE;QACD,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE;YAC5B,OAAO,WAAW,CAAC,CAAC,CAAC,CAAC;SACvB;QAED,uIAAuI;QACvI,+BAA+B;QAC/B,IAAI,qBAAqB,GAAa,EAAE,CAAC;QACzC,KAAK,MAAM,UAAU,IAAI,WAAW,EAAE;YACpC,MAAM,uBAAuB,GAAG,IAAI,GAAG,EAAU,CAAC;YAClD,KAAK,MAAM,QAAQ,IAAI,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,oBAAoB,CAAC,EAAE;gBACrE,IAAI,CAAC,IAAA,wCAAa,EAAC,QAAQ,CAAC,EAAE;oBAC5B,SAAS;iBACV;gBACD,MAAM,YAAY,GAAG,QAAQ,CAAC,IAAI,CAAC;gBACnC,IAAI,qBAAqB,CAAC,QAAQ,CAAC,YAAY,CAAC,EAAE;oBAChD,MAAM,IAAI,KAAK,CACb,0CAA0C,YAAY,qEAAqE;wBACzH,uHAAuH,CAC1H,CAAC;iBACH;gBACD,uBAAuB,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;aAC3C;YACD,qBAAqB,GAAG,CAAC,GAAG,qBAAqB,EAAE,GAAG,uBAAuB,CAAC,CAAC;SAChF;QAED,MAAM,6BAA6B,GAAG,WAAW,CAAC,MAAM,CACtD,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC,GAAG,GAAG,EAAE,GAAG,CAAC,GAAG,CAAC,6BAA6B,IAAI,EAAE,CAAC,CAAC,EACpE,EAAmC,CACpC,CAAC;QAEF,MAAM,YAAY,GAAG,IAAA,+CAA0B,EAAC,WAAW,CAAC,CAAC;QAE7D,OAAO;YACL,MAAM,EAAE,YAAY;YACpB,aAAa,EAAE,EAAE;YACjB,yBAAyB,EAAE,WAAW,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,CAAC,yBAAyB,EAAE,CAAC,EAAE,EAAE,CAAC;YAC/G,oBAAoB,EAAE,WAAW,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,CAAC,oBAAoB,EAAE,CAAC,EAAE,EAAE,CAAC;YACrG,6BAA6B;SAC9B,CAAC;IACJ,CAAC;;AApGH,4DAqGC","sourcesContent":["import * as os from 'os';\nimport { SchemaFile } from 'aws-cdk-lib/aws-appsync';\nimport { isSqlStrategy } from '@aws-amplify/graphql-transformer-core';\nimport { IAmplifyGraphqlDefinition } from './types';\nimport { constructDataSourceStrategies } from './internal';\nimport { CustomSqlDataSourceStrategy, ModelDataSourceStrategy } from './model-datasource-strategy-types';\nimport {\n  constructCustomSqlDataSourceStrategies,\n  schemaByMergingDefinitions,\n  validateDataSourceStrategy,\n} from './internal/data-source-config';\n\nexport const DEFAULT_MODEL_DATA_SOURCE_STRATEGY: ModelDataSourceStrategy = {\n  dbType: 'DYNAMODB',\n  provisionStrategy: 'DEFAULT',\n};\n\n/**\n * Class exposing utilities to produce IAmplifyGraphqlDefinition objects given various inputs.\n */\nexport class AmplifyGraphqlDefinition {\n  /**\n   * Produce a schema definition from a string input.\n   * @param schema the graphql input as a string\n   * @param dataSourceStrategy the provisioning definition for datasources that resolve `@model`s and custom SQL statements in this schema.\n   * The DynamoDB from CloudFormation will be used by default.\n   * @returns a fully formed amplify graphql definition\n   */\n  static fromString(\n    schema: string,\n    dataSourceStrategy: ModelDataSourceStrategy = DEFAULT_MODEL_DATA_SOURCE_STRATEGY,\n  ): IAmplifyGraphqlDefinition {\n    validateDataSourceStrategy(dataSourceStrategy);\n    return {\n      schema,\n      functionSlots: [],\n      referencedLambdaFunctions: {},\n      dataSourceStrategies: constructDataSourceStrategies(schema, dataSourceStrategy),\n      customSqlDataSourceStrategies: constructCustomSqlDataSourceStrategies(schema, dataSourceStrategy),\n    };\n  }\n\n  /**\n   * Convert one or more appsync SchemaFile objects into an Amplify Graphql Schema, binding them to a DynamoDB data source.\n   * @param filePaths one or more paths to the graphql files to process\n   * @returns a fully formed amplify graphql definition, whose models will be resolved by DynamoDB tables created during deployment.\n   */\n  static fromFiles(...filePaths: string[]): IAmplifyGraphqlDefinition {\n    if (!Array.isArray(filePaths)) {\n      filePaths = [filePaths];\n    }\n    const schema = filePaths.map((filePath) => new SchemaFile({ filePath }).definition).join(os.EOL);\n    return AmplifyGraphqlDefinition.fromString(schema, DEFAULT_MODEL_DATA_SOURCE_STRATEGY);\n  }\n\n  /**\n   * Convert one or more appsync SchemaFile objects into an Amplify Graphql Schema\n   * @param filePaths one or more paths to the graphql files to process\n   * @param dataSourceStrategy the provisioning definition for datasources that resolve `@model`s in this schema. The DynamoDB from\n   * CloudFormation will be used by default.\n   * @returns a fully formed amplify graphql definition\n   */\n  static fromFilesAndStrategy(\n    filePaths: string | string[],\n    dataSourceStrategy: ModelDataSourceStrategy = DEFAULT_MODEL_DATA_SOURCE_STRATEGY,\n  ): IAmplifyGraphqlDefinition {\n    if (!Array.isArray(filePaths)) {\n      filePaths = [filePaths];\n    }\n    const schema = filePaths.map((filePath) => new SchemaFile({ filePath }).definition).join(os.EOL);\n    return AmplifyGraphqlDefinition.fromString(schema, dataSourceStrategy);\n  }\n\n  /**\n   * Combines multiple IAmplifyGraphqlDefinitions into a single definition.\n   * @param definitions the definitions to combine\n   */\n  static combine(definitions: IAmplifyGraphqlDefinition[]): IAmplifyGraphqlDefinition {\n    if (definitions.length === 0) {\n      throw new Error('The definitions of amplify GraphQL cannot be empty.');\n    }\n    if (definitions.length === 1) {\n      return definitions[0];\n    }\n\n    // A strategy will be present multiple times in a given definition: once per model. We'll create a unique list per definition to ensure\n    // no reuse across definitions.\n    let combinedStrategyNames: string[] = [];\n    for (const definition of definitions) {\n      const definitionStrategyNames = new Set<string>();\n      for (const strategy of Object.values(definition.dataSourceStrategies)) {\n        if (!isSqlStrategy(strategy)) {\n          continue;\n        }\n        const strategyName = strategy.name;\n        if (combinedStrategyNames.includes(strategyName)) {\n          throw new Error(\n            `The SQL-based ModelDataSourceStrategy '${strategyName}' was found in multiple definitions, but a strategy name cannot be ` +\n              \"shared between definitions. To specify a SQL-based API with schemas across multiple files, use 'fromFilesAndStrategy'\",\n          );\n        }\n        definitionStrategyNames.add(strategyName);\n      }\n      combinedStrategyNames = [...combinedStrategyNames, ...definitionStrategyNames];\n    }\n\n    const customSqlDataSourceStrategies = definitions.reduce(\n      (acc, cur) => [...acc, ...(cur.customSqlDataSourceStrategies ?? [])],\n      [] as CustomSqlDataSourceStrategy[],\n    );\n\n    const mergedSchema = schemaByMergingDefinitions(definitions);\n\n    return {\n      schema: mergedSchema,\n      functionSlots: [],\n      referencedLambdaFunctions: definitions.reduce((acc, cur) => ({ ...acc, ...cur.referencedLambdaFunctions }), {}),\n      dataSourceStrategies: definitions.reduce((acc, cur) => ({ ...acc, ...cur.dataSourceStrategies }), {}),\n      customSqlDataSourceStrategies,\n    };\n  }\n}\n"]}
package/lib/index.d.ts CHANGED
@@ -3,4 +3,4 @@ export { AmplifyGraphqlApi } from './amplify-graphql-api';
3
3
  export { AmplifyGraphqlDefinition } from './amplify-graphql-definition';
4
4
  export { AmplifyDynamoDbTableWrapper, TimeToLiveSpecification, ProvisionedThroughput, SSESpecification, SSEType, StreamSpecification, } from './amplify-dynamodb-table-wrapper';
5
5
  export { SQLLambdaModelDataSourceStrategyFactory } from './sql-model-datasource-strategy';
6
- export * from './model-datasource-strategy';
6
+ export * from './model-datasource-strategy-types';
package/lib/index.js CHANGED
@@ -24,5 +24,5 @@ Object.defineProperty(exports, "AmplifyDynamoDbTableWrapper", { enumerable: true
24
24
  Object.defineProperty(exports, "SSEType", { enumerable: true, get: function () { return amplify_dynamodb_table_wrapper_1.SSEType; } });
25
25
  var sql_model_datasource_strategy_1 = require("./sql-model-datasource-strategy");
26
26
  Object.defineProperty(exports, "SQLLambdaModelDataSourceStrategyFactory", { enumerable: true, get: function () { return sql_model_datasource_strategy_1.SQLLambdaModelDataSourceStrategyFactory; } });
27
- __exportStar(require("./model-datasource-strategy"), exports);
28
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFrQ0EsNkRBQTBEO0FBQWpELHdIQUFBLGlCQUFpQixPQUFBO0FBQzFCLDJFQUF3RTtBQUEvRCxzSUFBQSx3QkFBd0IsT0FBQTtBQUNqQyxtRkFPMEM7QUFOeEMsNklBQUEsMkJBQTJCLE9BQUE7QUFJM0IseUhBQUEsT0FBTyxPQUFBO0FBR1QsaUZBQTBGO0FBQWpGLHdKQUFBLHVDQUF1QyxPQUFBO0FBQ2hELDhEQUE0QyIsInNvdXJjZXNDb250ZW50IjpbIi8qIEFUVEVOVElPTlxuICpcbiAqIElmIHlvdSBtb2RpZnkgdGhpcyBmaWxlIHlvdSBtdXN0IGFsc28gbW9kaWZ5IHBhY2thZ2VzL2FtcGxpZnktZGF0YS1jb25zdHJ1Y3Qvc3JjL2luZGV4LnRzIHRvIGhhdmUgdGhlIHNhbWUgZXhwb3J0c1xuICovXG5leHBvcnQgdHlwZSB7XG4gIElBTUF1dGhvcml6YXRpb25Db25maWcsXG4gIFVzZXJQb29sQXV0aG9yaXphdGlvbkNvbmZpZyxcbiAgT0lEQ0F1dGhvcml6YXRpb25Db25maWcsXG4gIEFwaUtleUF1dGhvcml6YXRpb25Db25maWcsXG4gIExhbWJkYUF1dGhvcml6YXRpb25Db25maWcsXG4gIEF1dGhvcml6YXRpb25Nb2RlcyxcbiAgUGFydGlhbFRyYW5zbGF0aW9uQmVoYXZpb3IsXG4gIEFtcGxpZnlHcmFwaHFsQXBpUHJvcHMsXG4gIEFtcGxpZnlHcmFwaHFsQXBpUmVzb3VyY2VzLFxuICBBbXBsaWZ5R3JhcGhxbEFwaUNmblJlc291cmNlcyxcbiAgRnVuY3Rpb25TbG90QmFzZSxcbiAgTXV0YXRpb25GdW5jdGlvblNsb3QsXG4gIFF1ZXJ5RnVuY3Rpb25TbG90LFxuICBTdWJzY3JpcHRpb25GdW5jdGlvblNsb3QsXG4gIEZ1bmN0aW9uU2xvdCxcbiAgRnVuY3Rpb25TbG90T3ZlcnJpZGUsXG4gIENvbmZsaWN0UmVzb2x1dGlvbixcbiAgQ29uZmxpY3REZXRlY3Rpb25UeXBlLFxuICBPcHRpbWlzdGljQ29uZmxpY3RSZXNvbHV0aW9uU3RyYXRlZ3ksXG4gIEN1c3RvbUNvbmZsaWN0UmVzb2x1dGlvblN0cmF0ZWd5LFxuICBBdXRvbWVyZ2VDb25mbGljdFJlc29sdXRpb25TdHJhdGVneSxcbiAgQ29uZmxpY3RSZXNvbHV0aW9uU3RyYXRlZ3lCYXNlLFxuICBDb25mbGljdFJlc29sdXRpb25TdHJhdGVneSxcbiAgVHJhbnNsYXRpb25CZWhhdmlvcixcbiAgSUFtcGxpZnlHcmFwaHFsRGVmaW5pdGlvbixcbiAgSUJhY2tlbmRPdXRwdXRTdG9yYWdlU3RyYXRlZ3ksXG4gIElCYWNrZW5kT3V0cHV0RW50cnksXG4gIEFkZEZ1bmN0aW9uUHJvcHMsXG59IGZyb20gJy4vdHlwZXMnO1xuZXhwb3J0IHsgQW1wbGlmeUdyYXBocWxBcGkgfSBmcm9tICcuL2FtcGxpZnktZ3JhcGhxbC1hcGknO1xuZXhwb3J0IHsgQW1wbGlmeUdyYXBocWxEZWZpbml0aW9uIH0gZnJvbSAnLi9hbXBsaWZ5LWdyYXBocWwtZGVmaW5pdGlvbic7XG5leHBvcnQge1xuICBBbXBsaWZ5RHluYW1vRGJUYWJsZVdyYXBwZXIsXG4gIFRpbWVUb0xpdmVTcGVjaWZpY2F0aW9uLFxuICBQcm92aXNpb25lZFRocm91Z2hwdXQsXG4gIFNTRVNwZWNpZmljYXRpb24sXG4gIFNTRVR5cGUsXG4gIFN0cmVhbVNwZWNpZmljYXRpb24sXG59IGZyb20gJy4vYW1wbGlmeS1keW5hbW9kYi10YWJsZS13cmFwcGVyJztcbmV4cG9ydCB7IFNRTExhbWJkYU1vZGVsRGF0YVNvdXJjZVN0cmF0ZWd5RmFjdG9yeSB9IGZyb20gJy4vc3FsLW1vZGVsLWRhdGFzb3VyY2Utc3RyYXRlZ3knO1xuZXhwb3J0ICogZnJvbSAnLi9tb2RlbC1kYXRhc291cmNlLXN0cmF0ZWd5JztcbiJdfQ==
27
+ __exportStar(require("./model-datasource-strategy-types"), exports);
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFrQ0EsNkRBQTBEO0FBQWpELHdIQUFBLGlCQUFpQixPQUFBO0FBQzFCLDJFQUF3RTtBQUEvRCxzSUFBQSx3QkFBd0IsT0FBQTtBQUNqQyxtRkFPMEM7QUFOeEMsNklBQUEsMkJBQTJCLE9BQUE7QUFJM0IseUhBQUEsT0FBTyxPQUFBO0FBR1QsaUZBQTBGO0FBQWpGLHdKQUFBLHVDQUF1QyxPQUFBO0FBQ2hELG9FQUFrRCIsInNvdXJjZXNDb250ZW50IjpbIi8qIEFUVEVOVElPTlxuICpcbiAqIElmIHlvdSBtb2RpZnkgdGhpcyBmaWxlIHlvdSBtdXN0IGFsc28gbW9kaWZ5IHBhY2thZ2VzL2FtcGxpZnktZGF0YS1jb25zdHJ1Y3Qvc3JjL2luZGV4LnRzIHRvIGhhdmUgdGhlIHNhbWUgZXhwb3J0c1xuICovXG5leHBvcnQgdHlwZSB7XG4gIElBTUF1dGhvcml6YXRpb25Db25maWcsXG4gIFVzZXJQb29sQXV0aG9yaXphdGlvbkNvbmZpZyxcbiAgT0lEQ0F1dGhvcml6YXRpb25Db25maWcsXG4gIEFwaUtleUF1dGhvcml6YXRpb25Db25maWcsXG4gIExhbWJkYUF1dGhvcml6YXRpb25Db25maWcsXG4gIEF1dGhvcml6YXRpb25Nb2RlcyxcbiAgUGFydGlhbFRyYW5zbGF0aW9uQmVoYXZpb3IsXG4gIEFtcGxpZnlHcmFwaHFsQXBpUHJvcHMsXG4gIEFtcGxpZnlHcmFwaHFsQXBpUmVzb3VyY2VzLFxuICBBbXBsaWZ5R3JhcGhxbEFwaUNmblJlc291cmNlcyxcbiAgRnVuY3Rpb25TbG90QmFzZSxcbiAgTXV0YXRpb25GdW5jdGlvblNsb3QsXG4gIFF1ZXJ5RnVuY3Rpb25TbG90LFxuICBTdWJzY3JpcHRpb25GdW5jdGlvblNsb3QsXG4gIEZ1bmN0aW9uU2xvdCxcbiAgRnVuY3Rpb25TbG90T3ZlcnJpZGUsXG4gIENvbmZsaWN0UmVzb2x1dGlvbixcbiAgQ29uZmxpY3REZXRlY3Rpb25UeXBlLFxuICBPcHRpbWlzdGljQ29uZmxpY3RSZXNvbHV0aW9uU3RyYXRlZ3ksXG4gIEN1c3RvbUNvbmZsaWN0UmVzb2x1dGlvblN0cmF0ZWd5LFxuICBBdXRvbWVyZ2VDb25mbGljdFJlc29sdXRpb25TdHJhdGVneSxcbiAgQ29uZmxpY3RSZXNvbHV0aW9uU3RyYXRlZ3lCYXNlLFxuICBDb25mbGljdFJlc29sdXRpb25TdHJhdGVneSxcbiAgVHJhbnNsYXRpb25CZWhhdmlvcixcbiAgSUFtcGxpZnlHcmFwaHFsRGVmaW5pdGlvbixcbiAgSUJhY2tlbmRPdXRwdXRTdG9yYWdlU3RyYXRlZ3ksXG4gIElCYWNrZW5kT3V0cHV0RW50cnksXG4gIEFkZEZ1bmN0aW9uUHJvcHMsXG59IGZyb20gJy4vdHlwZXMnO1xuZXhwb3J0IHsgQW1wbGlmeUdyYXBocWxBcGkgfSBmcm9tICcuL2FtcGxpZnktZ3JhcGhxbC1hcGknO1xuZXhwb3J0IHsgQW1wbGlmeUdyYXBocWxEZWZpbml0aW9uIH0gZnJvbSAnLi9hbXBsaWZ5LWdyYXBocWwtZGVmaW5pdGlvbic7XG5leHBvcnQge1xuICBBbXBsaWZ5RHluYW1vRGJUYWJsZVdyYXBwZXIsXG4gIFRpbWVUb0xpdmVTcGVjaWZpY2F0aW9uLFxuICBQcm92aXNpb25lZFRocm91Z2hwdXQsXG4gIFNTRVNwZWNpZmljYXRpb24sXG4gIFNTRVR5cGUsXG4gIFN0cmVhbVNwZWNpZmljYXRpb24sXG59IGZyb20gJy4vYW1wbGlmeS1keW5hbW9kYi10YWJsZS13cmFwcGVyJztcbmV4cG9ydCB7IFNRTExhbWJkYU1vZGVsRGF0YVNvdXJjZVN0cmF0ZWd5RmFjdG9yeSB9IGZyb20gJy4vc3FsLW1vZGVsLWRhdGFzb3VyY2Utc3RyYXRlZ3knO1xuZXhwb3J0ICogZnJvbSAnLi9tb2RlbC1kYXRhc291cmNlLXN0cmF0ZWd5LXR5cGVzJztcbiJdfQ==
@@ -1,13 +1,6 @@
1
- import { CustomSqlDataSourceStrategy as ImplementationCustomSqlDataSourceStrategy, DataSourceType } from '@aws-amplify/graphql-transformer-interfaces';
2
- import { CustomSqlDataSourceStrategy as InterfaceCustomSqlDataSourceStrategy, ModelDataSourceStrategy } from '../model-datasource-strategy';
3
- type DataSourceConfig = {
4
- modelToDatasourceMap: Map<string, DataSourceType>;
5
- };
6
- /**
7
- * An internal helper to convert from a map of model-to-ModelDataSourceStrategies to the map of model-to-DataSourceTypes that internal
8
- * transform processing requires. TODO: We can remove this once we refactor the internals to use ModelDataSourceStrategies natively.
9
- */
10
- export declare const parseDataSourceConfig: (dataSourceDefinitionMap: Record<string, ModelDataSourceStrategy>) => DataSourceConfig;
1
+ import { DataSourceStrategiesProvider } from '@aws-amplify/graphql-transformer-interfaces';
2
+ import { CustomSqlDataSourceStrategy as ConstructCustomSqlDataSourceStrategy, ModelDataSourceStrategy as ConstructModelDataSourceStrategy } from '../model-datasource-strategy-types';
3
+ import { IAmplifyGraphqlDefinition } from '../types';
11
4
  /**
12
5
  * Creates an interface flavor of customSqlDataSourceStrategies from a factory method's schema and data source. Internally, this function
13
6
  * scans the fields of `Query` and `Mutation` looking for fields annotated with the `@sql` directive and designates the specified
@@ -15,16 +8,17 @@ export declare const parseDataSourceConfig: (dataSourceDefinitionMap: Record<str
15
8
  *
16
9
  * Note that we do not scan for `Subscription` fields: `@sql` directives are not allowed on those, and it wouldn't make sense to do so
17
10
  * anyway, since subscriptions are processed from an incoming Mutation, not as the result of a direct datasource access.
18
- *
19
- * TODO: Reword this when we refactor to use Strategies throughout the implementation rather than DataSources.
20
11
  */
21
- export declare const constructCustomSqlDataSourceStrategies: (schema: string, dataSourceStrategy: ModelDataSourceStrategy) => InterfaceCustomSqlDataSourceStrategy[];
12
+ export declare const constructCustomSqlDataSourceStrategies: (schema: string, dataSourceStrategy: ConstructModelDataSourceStrategy) => ConstructCustomSqlDataSourceStrategy[];
22
13
  /**
23
- * We currently use a different type structure to model strategies in the interface than we do in the implementation. This maps the
24
- * interface CustomSqlDataSourceStrategy (which uses SQLLambdaModelDataSourceStrategy) to the implementation flavor (which uses
25
- * DataSourceType).
26
- *
27
- * TODO: Remove this once we refactor the internals to use strategies rather than DataSourceTypes
14
+ * Extracts the data source provider from the definition. This jumps through some hoops to avoid changing the public interface. If we decide
15
+ * to change the public interface to simplify the structure, then this process gets a lot simpler.
16
+ */
17
+ export declare const getDataSourceStrategiesProvider: (definition: IAmplifyGraphqlDefinition) => DataSourceStrategiesProvider;
18
+ /**
19
+ * Creates a new schema by merging the individual schemas contained in the definitions, combining fields of the Query and Mutation types in
20
+ * individual definitions into a single combined definition. Adding directives to `Query` and `Mutation` types participating in a
21
+ * combination is not supported (the behavior is undefined whether those directives are migrated).
28
22
  */
29
- export declare const mapInterfaceCustomSqlStrategiesToImplementationStrategies: (strategies?: InterfaceCustomSqlDataSourceStrategy[]) => ImplementationCustomSqlDataSourceStrategy[];
30
- export {};
23
+ export declare const schemaByMergingDefinitions: (definitions: IAmplifyGraphqlDefinition[]) => string;
24
+ export declare const validateDataSourceStrategy: (strategy: ConstructModelDataSourceStrategy) => void;