@aws-amplify/graphql-api-construct 1.5.7-implicit-fields.0 → 1.6.0-secrets-manager.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (111) hide show
  1. package/.jsii +147 -36
  2. package/API.md +13 -1
  3. package/CHANGELOG.md +3 -5
  4. package/README.md +75 -17
  5. package/lib/amplify-dynamodb-table-wrapper.js +1 -1
  6. package/lib/amplify-graphql-api.js +1 -1
  7. package/lib/amplify-graphql-definition.js +1 -1
  8. package/lib/internal/data-source-config.js +37 -4
  9. package/lib/model-datasource-strategy-types.d.ts +25 -1
  10. package/lib/model-datasource-strategy-types.js +1 -1
  11. package/lib/sql-model-datasource-strategy.d.ts +13 -1
  12. package/lib/sql-model-datasource-strategy.js +26 -4
  13. package/node_modules/@aws-amplify/graphql-auth-transformer/CHANGELOG.md +1 -12
  14. package/node_modules/@aws-amplify/graphql-auth-transformer/lib/graphql-auth-transformer.d.ts.map +1 -1
  15. package/node_modules/@aws-amplify/graphql-auth-transformer/lib/graphql-auth-transformer.js +1 -32
  16. package/node_modules/@aws-amplify/graphql-auth-transformer/lib/graphql-auth-transformer.js.map +1 -1
  17. package/node_modules/@aws-amplify/graphql-auth-transformer/package.json +14 -20
  18. package/node_modules/@aws-amplify/graphql-default-value-transformer/CHANGELOG.md +1 -7
  19. package/node_modules/@aws-amplify/graphql-default-value-transformer/package.json +9 -15
  20. package/node_modules/@aws-amplify/graphql-function-transformer/CHANGELOG.md +1 -5
  21. package/node_modules/@aws-amplify/graphql-function-transformer/package.json +8 -14
  22. package/node_modules/@aws-amplify/graphql-http-transformer/CHANGELOG.md +1 -5
  23. package/node_modules/@aws-amplify/graphql-http-transformer/package.json +8 -14
  24. package/node_modules/@aws-amplify/graphql-index-transformer/CHANGELOG.md +1 -5
  25. package/node_modules/@aws-amplify/graphql-index-transformer/package.json +9 -15
  26. package/node_modules/@aws-amplify/graphql-maps-to-transformer/CHANGELOG.md +1 -5
  27. package/node_modules/@aws-amplify/graphql-maps-to-transformer/lib/assets/mapping-lambda.zip +0 -0
  28. package/node_modules/@aws-amplify/graphql-maps-to-transformer/package.json +14 -16
  29. package/node_modules/@aws-amplify/graphql-model-transformer/CHANGELOG.md +3 -11
  30. package/node_modules/@aws-amplify/graphql-model-transformer/lib/graphql-model-transformer.d.ts.map +1 -1
  31. package/node_modules/@aws-amplify/graphql-model-transformer/lib/graphql-model-transformer.js +5 -5
  32. package/node_modules/@aws-amplify/graphql-model-transformer/lib/graphql-model-transformer.js.map +1 -1
  33. package/node_modules/@aws-amplify/graphql-model-transformer/lib/graphql-types/common.d.ts.map +1 -1
  34. package/node_modules/@aws-amplify/graphql-model-transformer/lib/graphql-types/common.js +0 -15
  35. package/node_modules/@aws-amplify/graphql-model-transformer/lib/graphql-types/common.js.map +1 -1
  36. package/node_modules/@aws-amplify/graphql-model-transformer/lib/rds-lambda.zip +0 -0
  37. package/node_modules/@aws-amplify/graphql-model-transformer/lib/rds-notification-lambda.zip +0 -0
  38. package/node_modules/@aws-amplify/graphql-model-transformer/lib/rds-patching-lambda.zip +0 -0
  39. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resolvers/rds/resolver.d.ts +5 -1
  40. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resolvers/rds/resolver.d.ts.map +1 -1
  41. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resolvers/rds/resolver.js +71 -26
  42. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resolvers/rds/resolver.js.map +1 -1
  43. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resources/rds-model-resource-generator.d.ts.map +1 -1
  44. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resources/rds-model-resource-generator.js +21 -7
  45. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resources/rds-model-resource-generator.js.map +1 -1
  46. package/node_modules/@aws-amplify/graphql-model-transformer/package.json +11 -17
  47. package/node_modules/@aws-amplify/graphql-predictions-transformer/CHANGELOG.md +1 -5
  48. package/node_modules/@aws-amplify/graphql-predictions-transformer/lib/predictionsLambdaFunction.zip +0 -0
  49. package/node_modules/@aws-amplify/graphql-predictions-transformer/package.json +8 -14
  50. package/node_modules/@aws-amplify/graphql-relational-transformer/CHANGELOG.md +1 -11
  51. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/schema.d.ts.map +1 -1
  52. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/schema.js +0 -10
  53. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/schema.js.map +1 -1
  54. package/node_modules/@aws-amplify/graphql-relational-transformer/package.json +11 -17
  55. package/node_modules/@aws-amplify/graphql-searchable-transformer/CHANGELOG.md +1 -7
  56. package/node_modules/@aws-amplify/graphql-searchable-transformer/lib/streaming-lambda.zip +0 -0
  57. package/node_modules/@aws-amplify/graphql-searchable-transformer/package.json +9 -15
  58. package/node_modules/@aws-amplify/graphql-sql-transformer/CHANGELOG.md +1 -5
  59. package/node_modules/@aws-amplify/graphql-sql-transformer/package.json +10 -16
  60. package/node_modules/@aws-amplify/graphql-transformer/CHANGELOG.md +3 -5
  61. package/node_modules/@aws-amplify/graphql-transformer/package.json +17 -23
  62. package/node_modules/@aws-amplify/graphql-transformer-core/API.md +0 -12
  63. package/node_modules/@aws-amplify/graphql-transformer-core/CHANGELOG.md +1 -11
  64. package/node_modules/@aws-amplify/graphql-transformer-core/lib/index.d.ts +1 -1
  65. package/node_modules/@aws-amplify/graphql-transformer-core/lib/index.d.ts.map +1 -1
  66. package/node_modules/@aws-amplify/graphql-transformer-core/lib/index.js +2 -6
  67. package/node_modules/@aws-amplify/graphql-transformer-core/lib/index.js.map +1 -1
  68. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformer-context/output.d.ts +0 -2
  69. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformer-context/output.d.ts.map +1 -1
  70. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformer-context/output.js +0 -14
  71. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformer-context/output.js.map +1 -1
  72. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/index.d.ts +1 -1
  73. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/index.d.ts.map +1 -1
  74. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/index.js +1 -5
  75. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/index.js.map +1 -1
  76. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/model-util.d.ts +0 -4
  77. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/model-util.d.ts.map +1 -1
  78. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/model-util.js +1 -18
  79. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/model-util.js.map +1 -1
  80. package/node_modules/@aws-amplify/graphql-transformer-core/package.json +8 -14
  81. package/node_modules/@aws-amplify/graphql-transformer-interfaces/API.md +27 -5
  82. package/node_modules/@aws-amplify/graphql-transformer-interfaces/CHANGELOG.md +2 -2
  83. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/model-datasource/types.d.ts +12 -1
  84. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/model-datasource/types.d.ts.map +1 -1
  85. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/model-datasource/types.js +22 -0
  86. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/model-datasource/types.js.map +1 -1
  87. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/transformer-context/transformer-context-output-provider.d.ts +0 -2
  88. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/transformer-context/transformer-context-output-provider.d.ts.map +1 -1
  89. package/node_modules/@aws-amplify/graphql-transformer-interfaces/package.json +2 -8
  90. package/node_modules/@aws-amplify/graphql-transformer-interfaces/src/model-datasource/types.ts +76 -1
  91. package/node_modules/@aws-amplify/graphql-transformer-interfaces/src/transformer-context/transformer-context-output-provider.ts +0 -4
  92. package/node_modules/@aws-amplify/graphql-transformer-interfaces/tsconfig.tsbuildinfo +1 -1
  93. package/node_modules/graphql-mapping-template/CHANGELOG.md +0 -4
  94. package/node_modules/graphql-mapping-template/package.json +5 -12
  95. package/node_modules/graphql-transformer-common/API.md +0 -14
  96. package/node_modules/graphql-transformer-common/CHANGELOG.md +0 -10
  97. package/node_modules/graphql-transformer-common/lib/index.d.ts +0 -1
  98. package/node_modules/graphql-transformer-common/lib/index.d.ts.map +1 -1
  99. package/node_modules/graphql-transformer-common/lib/index.js +0 -1
  100. package/node_modules/graphql-transformer-common/lib/index.js.map +1 -1
  101. package/node_modules/graphql-transformer-common/package.json +6 -13
  102. package/package.json +21 -27
  103. package/src/internal/data-source-config.ts +42 -9
  104. package/src/model-datasource-strategy-types.ts +33 -1
  105. package/src/sql-model-datasource-strategy.ts +32 -1
  106. package/node_modules/graphql-mapping-template/LICENSE +0 -201
  107. package/node_modules/graphql-transformer-common/LICENSE +0 -201
  108. package/node_modules/graphql-transformer-common/lib/TypescriptSchemaConstants.d.ts +0 -13
  109. package/node_modules/graphql-transformer-common/lib/TypescriptSchemaConstants.d.ts.map +0 -1
  110. package/node_modules/graphql-transformer-common/lib/TypescriptSchemaConstants.js +0 -16
  111. package/node_modules/graphql-transformer-common/lib/TypescriptSchemaConstants.js.map +0 -1
package/API.md CHANGED
@@ -340,7 +340,19 @@ export class SQLLambdaModelDataSourceStrategyFactory {
340
340
  }
341
341
 
342
342
  // @public
343
- export interface SqlModelDataSourceDbConnectionConfig {
343
+ export type SqlModelDataSourceDbConnectionConfig = SqlModelDataSourceSecretsManagerDbConnectionConfig | SqlModelDataSourceSsmDbConnectionConfig;
344
+
345
+ // @public
346
+ export interface SqlModelDataSourceSecretsManagerDbConnectionConfig {
347
+ readonly databaseName: string;
348
+ readonly hostname: string;
349
+ readonly keyArn?: string;
350
+ readonly port: number;
351
+ readonly secretArn: string;
352
+ }
353
+
354
+ // @public
355
+ export interface SqlModelDataSourceSsmDbConnectionConfig {
344
356
  readonly databaseNameSsmPath: string;
345
357
  readonly hostnameSsmPath: string;
346
358
  readonly passwordSsmPath: string;
package/CHANGELOG.md CHANGED
@@ -3,13 +3,11 @@
3
3
  All notable changes to this project will be documented in this file.
4
4
  See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
5
5
 
6
- ## [1.5.7-implicit-fields.0](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-api-construct@1.5.6...@aws-amplify/graphql-api-construct@1.5.7-implicit-fields.0) (2024-02-07)
6
+ # [1.6.0-secrets-manager.0](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-api-construct@1.5.5...@aws-amplify/graphql-api-construct@1.6.0-secrets-manager.0) (2024-02-21)
7
7
 
8
- **Note:** Version bump only for package @aws-amplify/graphql-api-construct
9
-
10
- ## [1.5.6](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-api-construct@1.5.5...@aws-amplify/graphql-api-construct@1.5.6) (2024-02-05)
8
+ ### Features
11
9
 
12
- **Note:** Version bump only for package @aws-amplify/graphql-api-construct
10
+ - add secrets manager support for sql lambda auth ([#2103](https://github.com/aws-amplify/amplify-category-api/issues/2103)) ([fde423b](https://github.com/aws-amplify/amplify-category-api/commit/fde423bba09403c6bfd6788cc63546d629d756b6))
13
11
 
14
12
  ## [1.5.5](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-api-construct@1.5.4...@aws-amplify/graphql-api-construct@1.5.5) (2024-01-30)
15
13
 
package/README.md CHANGED
@@ -2623,7 +2623,7 @@ const sQLLambdaModelDataSourceStrategy: SQLLambdaModelDataSourceStrategy = { ...
2623
2623
 
2624
2624
  | **Name** | **Type** | **Description** |
2625
2625
  | --- | --- | --- |
2626
- | <code><a href="#@aws-amplify/graphql-api-construct.SQLLambdaModelDataSourceStrategy.property.dbConnectionConfig">dbConnectionConfig</a></code> | <code><a href="#@aws-amplify/graphql-api-construct.SqlModelDataSourceDbConnectionConfig">SqlModelDataSourceDbConnectionConfig</a></code> | The parameters the Lambda data source will use to connect to the database. |
2626
+ | <code><a href="#@aws-amplify/graphql-api-construct.SQLLambdaModelDataSourceStrategy.property.dbConnectionConfig">dbConnectionConfig</a></code> | <code><a href="#@aws-amplify/graphql-api-construct.SqlModelDataSourceSecretsManagerDbConnectionConfig">SqlModelDataSourceSecretsManagerDbConnectionConfig</a> \| <a href="#@aws-amplify/graphql-api-construct.SqlModelDataSourceSsmDbConnectionConfig">SqlModelDataSourceSsmDbConnectionConfig</a></code> | The parameters the Lambda data source will use to connect to the database. |
2627
2627
  | <code><a href="#@aws-amplify/graphql-api-construct.SQLLambdaModelDataSourceStrategy.property.dbType">dbType</a></code> | <code>string</code> | The type of the SQL database used to process model operations for this definition. |
2628
2628
  | <code><a href="#@aws-amplify/graphql-api-construct.SQLLambdaModelDataSourceStrategy.property.name">name</a></code> | <code>string</code> | The name of the strategy. |
2629
2629
  | <code><a href="#@aws-amplify/graphql-api-construct.SQLLambdaModelDataSourceStrategy.property.customSqlStatements">customSqlStatements</a></code> | <code>{[ key: string ]: string}</code> | Custom SQL statements. |
@@ -2635,10 +2635,10 @@ const sQLLambdaModelDataSourceStrategy: SQLLambdaModelDataSourceStrategy = { ...
2635
2635
  ##### `dbConnectionConfig`<sup>Required</sup> <a name="dbConnectionConfig" id="@aws-amplify/graphql-api-construct.SQLLambdaModelDataSourceStrategy.property.dbConnectionConfig"></a>
2636
2636
 
2637
2637
  ```typescript
2638
- public readonly dbConnectionConfig: SqlModelDataSourceDbConnectionConfig;
2638
+ public readonly dbConnectionConfig: SqlModelDataSourceSecretsManagerDbConnectionConfig | SqlModelDataSourceSsmDbConnectionConfig;
2639
2639
  ```
2640
2640
 
2641
- - *Type:* <a href="#@aws-amplify/graphql-api-construct.SqlModelDataSourceDbConnectionConfig">SqlModelDataSourceDbConnectionConfig</a>
2641
+ - *Type:* <a href="#@aws-amplify/graphql-api-construct.SqlModelDataSourceSecretsManagerDbConnectionConfig">SqlModelDataSourceSecretsManagerDbConnectionConfig</a> | <a href="#@aws-amplify/graphql-api-construct.SqlModelDataSourceSsmDbConnectionConfig">SqlModelDataSourceSsmDbConnectionConfig</a>
2642
2642
 
2643
2643
  The parameters the Lambda data source will use to connect to the database.
2644
2644
 
@@ -2710,33 +2710,91 @@ The configuration of the VPC into which to install the Lambda.
2710
2710
 
2711
2711
  ---
2712
2712
 
2713
- ### SqlModelDataSourceDbConnectionConfig <a name="SqlModelDataSourceDbConnectionConfig" id="@aws-amplify/graphql-api-construct.SqlModelDataSourceDbConnectionConfig"></a>
2713
+ ### SqlModelDataSourceSecretsManagerDbConnectionConfig <a name="SqlModelDataSourceSecretsManagerDbConnectionConfig" id="@aws-amplify/graphql-api-construct.SqlModelDataSourceSecretsManagerDbConnectionConfig"></a>
2714
+
2715
+ #### Initializer <a name="Initializer" id="@aws-amplify/graphql-api-construct.SqlModelDataSourceSecretsManagerDbConnectionConfig.Initializer"></a>
2716
+
2717
+ ```typescript
2718
+ import { SqlModelDataSourceSecretsManagerDbConnectionConfig } from '@aws-amplify/graphql-api-construct'
2719
+
2720
+ const sqlModelDataSourceSecretsManagerDbConnectionConfig: SqlModelDataSourceSecretsManagerDbConnectionConfig = { ... }
2721
+ ```
2722
+
2723
+ #### Properties <a name="Properties" id="Properties"></a>
2724
+
2725
+ | **Name** | **Type** | **Description** |
2726
+ | --- | --- | --- |
2727
+ | <code><a href="#@aws-amplify/graphql-api-construct.SqlModelDataSourceSecretsManagerDbConnectionConfig.property.databaseName">databaseName</a></code> | <code>string</code> | database name. |
2728
+ | <code><a href="#@aws-amplify/graphql-api-construct.SqlModelDataSourceSecretsManagerDbConnectionConfig.property.port">port</a></code> | <code>number</code> | port number of the database proxy, cluster, or instance. |
2729
+ | <code><a href="#@aws-amplify/graphql-api-construct.SqlModelDataSourceSecretsManagerDbConnectionConfig.property.secretArn">secretArn</a></code> | <code>string</code> | The arn of the managed secret with username, password, and hostname to use when connecting to the database. |
2730
+
2731
+ ---
2732
+
2733
+ ##### `databaseName`<sup>Required</sup> <a name="databaseName" id="@aws-amplify/graphql-api-construct.SqlModelDataSourceSecretsManagerDbConnectionConfig.property.databaseName"></a>
2734
+
2735
+ ```typescript
2736
+ public readonly databaseName: string;
2737
+ ```
2738
+
2739
+ - *Type:* string
2740
+
2741
+ database name.
2742
+
2743
+ ---
2744
+
2745
+ ##### `port`<sup>Required</sup> <a name="port" id="@aws-amplify/graphql-api-construct.SqlModelDataSourceSecretsManagerDbConnectionConfig.property.port"></a>
2746
+
2747
+ ```typescript
2748
+ public readonly port: number;
2749
+ ```
2750
+
2751
+ - *Type:* number
2752
+
2753
+ port number of the database proxy, cluster, or instance.
2754
+
2755
+ ---
2756
+
2757
+ ##### `secretArn`<sup>Required</sup> <a name="secretArn" id="@aws-amplify/graphql-api-construct.SqlModelDataSourceSecretsManagerDbConnectionConfig.property.secretArn"></a>
2758
+
2759
+ ```typescript
2760
+ public readonly secretArn: string;
2761
+ ```
2762
+
2763
+ - *Type:* string
2764
+
2765
+ The arn of the managed secret with username, password, and hostname to use when connecting to the database.
2766
+
2767
+ *
2768
+
2769
+ ---
2770
+
2771
+ ### SqlModelDataSourceSsmDbConnectionConfig <a name="SqlModelDataSourceSsmDbConnectionConfig" id="@aws-amplify/graphql-api-construct.SqlModelDataSourceSsmDbConnectionConfig"></a>
2714
2772
 
2715
2773
  The Secure Systems Manager parameter paths the Lambda data source will use to connect to the database.
2716
2774
 
2717
2775
  These parameters are retrieved from Secure Systems Manager in the same region as the Lambda.
2718
2776
 
2719
- #### Initializer <a name="Initializer" id="@aws-amplify/graphql-api-construct.SqlModelDataSourceDbConnectionConfig.Initializer"></a>
2777
+ #### Initializer <a name="Initializer" id="@aws-amplify/graphql-api-construct.SqlModelDataSourceSsmDbConnectionConfig.Initializer"></a>
2720
2778
 
2721
2779
  ```typescript
2722
- import { SqlModelDataSourceDbConnectionConfig } from '@aws-amplify/graphql-api-construct'
2780
+ import { SqlModelDataSourceSsmDbConnectionConfig } from '@aws-amplify/graphql-api-construct'
2723
2781
 
2724
- const sqlModelDataSourceDbConnectionConfig: SqlModelDataSourceDbConnectionConfig = { ... }
2782
+ const sqlModelDataSourceSsmDbConnectionConfig: SqlModelDataSourceSsmDbConnectionConfig = { ... }
2725
2783
  ```
2726
2784
 
2727
2785
  #### Properties <a name="Properties" id="Properties"></a>
2728
2786
 
2729
2787
  | **Name** | **Type** | **Description** |
2730
2788
  | --- | --- | --- |
2731
- | <code><a href="#@aws-amplify/graphql-api-construct.SqlModelDataSourceDbConnectionConfig.property.databaseNameSsmPath">databaseNameSsmPath</a></code> | <code>string</code> | The Secure Systems Manager parameter containing the database name. |
2732
- | <code><a href="#@aws-amplify/graphql-api-construct.SqlModelDataSourceDbConnectionConfig.property.hostnameSsmPath">hostnameSsmPath</a></code> | <code>string</code> | The Secure Systems Manager parameter containing the hostname of the database. |
2733
- | <code><a href="#@aws-amplify/graphql-api-construct.SqlModelDataSourceDbConnectionConfig.property.passwordSsmPath">passwordSsmPath</a></code> | <code>string</code> | The Secure Systems Manager parameter containing the password to use when connecting to the database. |
2734
- | <code><a href="#@aws-amplify/graphql-api-construct.SqlModelDataSourceDbConnectionConfig.property.portSsmPath">portSsmPath</a></code> | <code>string</code> | The Secure Systems Manager parameter containing the port number of the database proxy, cluster, or instance. |
2735
- | <code><a href="#@aws-amplify/graphql-api-construct.SqlModelDataSourceDbConnectionConfig.property.usernameSsmPath">usernameSsmPath</a></code> | <code>string</code> | The Secure Systems Manager parameter containing the username to use when connecting to the database. |
2789
+ | <code><a href="#@aws-amplify/graphql-api-construct.SqlModelDataSourceSsmDbConnectionConfig.property.databaseNameSsmPath">databaseNameSsmPath</a></code> | <code>string</code> | The Secure Systems Manager parameter containing the database name. |
2790
+ | <code><a href="#@aws-amplify/graphql-api-construct.SqlModelDataSourceSsmDbConnectionConfig.property.hostnameSsmPath">hostnameSsmPath</a></code> | <code>string</code> | The Secure Systems Manager parameter containing the hostname of the database. |
2791
+ | <code><a href="#@aws-amplify/graphql-api-construct.SqlModelDataSourceSsmDbConnectionConfig.property.passwordSsmPath">passwordSsmPath</a></code> | <code>string</code> | The Secure Systems Manager parameter containing the password to use when connecting to the database. |
2792
+ | <code><a href="#@aws-amplify/graphql-api-construct.SqlModelDataSourceSsmDbConnectionConfig.property.portSsmPath">portSsmPath</a></code> | <code>string</code> | The Secure Systems Manager parameter containing the port number of the database proxy, cluster, or instance. |
2793
+ | <code><a href="#@aws-amplify/graphql-api-construct.SqlModelDataSourceSsmDbConnectionConfig.property.usernameSsmPath">usernameSsmPath</a></code> | <code>string</code> | The Secure Systems Manager parameter containing the username to use when connecting to the database. |
2736
2794
 
2737
2795
  ---
2738
2796
 
2739
- ##### `databaseNameSsmPath`<sup>Required</sup> <a name="databaseNameSsmPath" id="@aws-amplify/graphql-api-construct.SqlModelDataSourceDbConnectionConfig.property.databaseNameSsmPath"></a>
2797
+ ##### `databaseNameSsmPath`<sup>Required</sup> <a name="databaseNameSsmPath" id="@aws-amplify/graphql-api-construct.SqlModelDataSourceSsmDbConnectionConfig.property.databaseNameSsmPath"></a>
2740
2798
 
2741
2799
  ```typescript
2742
2800
  public readonly databaseNameSsmPath: string;
@@ -2748,7 +2806,7 @@ The Secure Systems Manager parameter containing the database name.
2748
2806
 
2749
2807
  ---
2750
2808
 
2751
- ##### `hostnameSsmPath`<sup>Required</sup> <a name="hostnameSsmPath" id="@aws-amplify/graphql-api-construct.SqlModelDataSourceDbConnectionConfig.property.hostnameSsmPath"></a>
2809
+ ##### `hostnameSsmPath`<sup>Required</sup> <a name="hostnameSsmPath" id="@aws-amplify/graphql-api-construct.SqlModelDataSourceSsmDbConnectionConfig.property.hostnameSsmPath"></a>
2752
2810
 
2753
2811
  ```typescript
2754
2812
  public readonly hostnameSsmPath: string;
@@ -2763,7 +2821,7 @@ of a database proxy, cluster, or instance.
2763
2821
 
2764
2822
  ---
2765
2823
 
2766
- ##### `passwordSsmPath`<sup>Required</sup> <a name="passwordSsmPath" id="@aws-amplify/graphql-api-construct.SqlModelDataSourceDbConnectionConfig.property.passwordSsmPath"></a>
2824
+ ##### `passwordSsmPath`<sup>Required</sup> <a name="passwordSsmPath" id="@aws-amplify/graphql-api-construct.SqlModelDataSourceSsmDbConnectionConfig.property.passwordSsmPath"></a>
2767
2825
 
2768
2826
  ```typescript
2769
2827
  public readonly passwordSsmPath: string;
@@ -2775,7 +2833,7 @@ The Secure Systems Manager parameter containing the password to use when connect
2775
2833
 
2776
2834
  ---
2777
2835
 
2778
- ##### `portSsmPath`<sup>Required</sup> <a name="portSsmPath" id="@aws-amplify/graphql-api-construct.SqlModelDataSourceDbConnectionConfig.property.portSsmPath"></a>
2836
+ ##### `portSsmPath`<sup>Required</sup> <a name="portSsmPath" id="@aws-amplify/graphql-api-construct.SqlModelDataSourceSsmDbConnectionConfig.property.portSsmPath"></a>
2779
2837
 
2780
2838
  ```typescript
2781
2839
  public readonly portSsmPath: string;
@@ -2787,7 +2845,7 @@ The Secure Systems Manager parameter containing the port number of the database
2787
2845
 
2788
2846
  ---
2789
2847
 
2790
- ##### `usernameSsmPath`<sup>Required</sup> <a name="usernameSsmPath" id="@aws-amplify/graphql-api-construct.SqlModelDataSourceDbConnectionConfig.property.usernameSsmPath"></a>
2848
+ ##### `usernameSsmPath`<sup>Required</sup> <a name="usernameSsmPath" id="@aws-amplify/graphql-api-construct.SqlModelDataSourceSsmDbConnectionConfig.property.usernameSsmPath"></a>
2791
2849
 
2792
2850
  ```typescript
2793
2851
  public readonly usernameSsmPath: string;
@@ -98,5 +98,5 @@ class AmplifyDynamoDbTableWrapper {
98
98
  }
99
99
  exports.AmplifyDynamoDbTableWrapper = AmplifyDynamoDbTableWrapper;
100
100
  _a = JSII_RTTI_SYMBOL_1;
101
- AmplifyDynamoDbTableWrapper[_a] = { fqn: "@aws-amplify/graphql-api-construct.AmplifyDynamoDbTableWrapper", version: "1.5.7-implicit-fields.0" };
101
+ AmplifyDynamoDbTableWrapper[_a] = { fqn: "@aws-amplify/graphql-api-construct.AmplifyDynamoDbTableWrapper", version: "1.6.0-secrets-manager.0" };
102
102
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"amplify-dynamodb-table-wrapper.js","sourceRoot":"","sources":["../src/amplify-dynamodb-table-wrapper.ts"],"names":[],"mappings":";;;;;AAAA,6CAA0C;AAG1C,MAAM,oCAAoC,GAAG,8BAA8B,CAAC;AAgC5E;;;GAGG;AACH,IAAY,OAEX;AAFD,WAAY,OAAO;IACjB,sBAAW,CAAA;AACb,CAAC,EAFW,OAAO,uBAAP,OAAO,QAElB;AA2CD;;;;;;;GAOG;AACH,MAAa,2BAA2B;IACtC;;;;OAIG;IACH,MAAM,CAAC,8BAA8B,CAAC,CAAM;QAC1C,OAAO,CAAC,YAAY,yBAAW,IAAI,CAAC,CAAC,eAAe,KAAK,oCAAoC,CAAC;IAChG,CAAC;IAED;;;OAGG;IACH,YAA6B,QAAqB;QAArB,aAAQ,GAAR,QAAQ,CAAa;QAChD,IAAI,QAAQ,CAAC,eAAe,KAAK,oCAAoC,EAAE;YACrE,MAAM,IAAI,KAAK,CAAC,8BAA8B,oCAAoC,sCAAsC,CAAC,CAAC;SAC3H;IACH,CAAC;IAED;;OAEG;IACH,IAAI,WAAW,CAAC,WAAwB;QACtC,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,aAAa,EAAE,WAAW,CAAC,CAAC;IAChE,CAAC;IAED;;OAEG;IACH,IAAI,mBAAmB,CAAC,uBAAgD;QACtE,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,yBAAyB,EAAE,uBAAuB,CAAC,CAAC;IACxF,CAAC;IAED;;OAEG;IACH,IAAI,0BAA0B,CAAC,0BAAmC;QAChE,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,kCAAkC,EAAE,EAAE,0BAA0B,EAAE,CAAC,CAAC;IACxG,CAAC;IAED;;OAEG;IACH,IAAI,qBAAqB,CAAC,qBAA4C;QACpE,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,uBAAuB,EAAE,qBAAqB,CAAC,CAAC;IACpF,CAAC;IAED;;;;OAIG;IACH,4CAA4C,CAAC,SAAiB,EAAE,qBAA4C;QAC1G,MAAM,IAAI,GAA2C,MAAM,CAAC,OAAO,CAChE,IAAI,CAAC,QAAgB,CAAC,YAAY,EAAE,UAAU,EAAE,sBAAsB,IAAI,EAAE,CAC9E,CAAC;QACF,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,EAAE,EAAE,CAAC,SAAS,KAAK,SAAS,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC,QAAQ,CAAC,CAAC;QACnH,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE;YAC1B,MAAM,IAAI,KAAK,CAAC,mBAAmB,SAAS,gCAAgC,CAAC,CAAC;SAC/E;QACD,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,0BAA0B,SAAS,CAAC,CAAC,CAAC,wBAAwB,EAAE,qBAAqB,CAAC,CAAC;IAC3H,CAAC;IAED;;OAEG;IACH,IAAI,mBAAmB,CAAC,mBAAwC;QAC9D,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,qBAAqB,EAAE,mBAAmB,CAAC,CAAC;IAChF,CAAC;IAED;;OAEG;IACH,IAAI,gBAAgB,CAAC,gBAAkC;QACrD,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,kBAAkB,EAAE,gBAAgB,CAAC,CAAC;IAC1E,CAAC;IAED;;OAEG;IACH,IAAI,yBAAyB,CAAC,yBAAkC;QAC9D,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,2BAA2B,EAAE,yBAAyB,CAAC,CAAC;IAC5F,CAAC;;AAnFH,kEAoFC","sourcesContent":["import { CfnResource } from 'aws-cdk-lib';\nimport { BillingMode, StreamViewType } from 'aws-cdk-lib/aws-dynamodb';\n\nconst AMPLIFY_DYNAMODB_TABLE_RESOURCE_TYPE = 'Custom::AmplifyDynamoDBTable';\n\n/**\n * Shape for TTL config.\n */\nexport interface TimeToLiveSpecification {\n  /**\n   * Boolean determining if the ttl is enabled or not.\n   */\n  readonly enabled: boolean;\n\n  /**\n   * Attribute name to apply to the ttl spec.\n   */\n  readonly attributeName?: string;\n}\n\n/**\n * Wrapper for provisioned throughput config in DDB.\n */\nexport interface ProvisionedThroughput {\n  /**\n   * The read capacity units on the table or index.\n   */\n  readonly readCapacityUnits: number;\n\n  /**\n   * The write capacity units on the table or index.\n   */\n  readonly writeCapacityUnits: number;\n}\n\n/**\n * Server Side Encryption Type Values\n * - `KMS` - Server-side encryption that uses AWS KMS. The key is stored in your account and is managed by KMS (AWS KMS charges apply).\n */\nexport enum SSEType {\n  KMS = 'KMS',\n}\n\n/**\n * Represents the settings used to enable server-side encryption.\n */\nexport interface SSESpecification {\n  /**\n   * Indicates whether server-side encryption is done using an AWS managed key or an AWS owned key.\n   * If enabled (true), server-side encryption type is set to `KMS` and an AWS managed key is used ( AWS KMS charges apply).\n   * If disabled (false) or not specified, server-side encryption is set to AWS owned key.\n   */\n  readonly sseEnabled: boolean;\n\n  /**\n   * The AWS KMS key that should be used for the AWS KMS encryption.\n   * To specify a key, use its key ID, Amazon Resource Name (ARN), alias name, or alias ARN. Note that you should only provide\n   * this parameter if the key is different from the default DynamoDB key `alias/aws/dynamodb` .\n   */\n  readonly kmsMasterKeyId?: string;\n\n  /**\n   * Server-side encryption type. The only supported value is:\n   * `KMS` Server-side encryption that uses AWS Key Management Service.\n   *   The key is stored in your account and is managed by AWS KMS ( AWS KMS charges apply).\n   */\n  readonly sseType?: SSEType;\n}\n\n/**\n * Represents the DynamoDB Streams configuration for a table in DynamoDB.\n */\nexport interface StreamSpecification {\n  /**\n   * When an item in the table is modified, `StreamViewType` determines what information is written to the stream for this table.\n   * Valid values for `StreamViewType` are:\n   * - `KEYS_ONLY` - Only the key attributes of the modified item are written to the stream.\n   * - `NEW_IMAGE` - The entire item, as it appears after it was modified, is written to the stream.\n   * - `OLD_IMAGE` - The entire item, as it appeared before it was modified, is written to the stream.\n   * - `NEW_AND_OLD_IMAGES` - Both the new and the old item images of the item are written to the stream.\n   */\n  readonly streamViewType: StreamViewType;\n}\n\n/**\n * Wrapper class around Custom::AmplifyDynamoDBTable custom resource, to simplify\n * the override experience a bit. This is NOT a construct, just an easier way to access\n * the generated construct.\n * This is a wrapper intended to mimic the `aws_cdk_lib.aws_dynamodb.Table` functionality more-or-less.\n * Notable differences is the addition of TKTK properties, to account for the fact that they're constructor props\n * in the CDK construct, as well as the removal of all from*, grant*, and metric* methods implemented by Table.\n */\nexport class AmplifyDynamoDbTableWrapper {\n  /**\n   * Return true and perform type narrowing if a given input appears to be capable of\n   * @param x the object to check.\n   * @returns whether or not the resource is an underlying amplify dynamodb table resource.\n   */\n  static isAmplifyDynamoDbTableResource(x: any): x is CfnResource {\n    return x instanceof CfnResource && x.cfnResourceType === AMPLIFY_DYNAMODB_TABLE_RESOURCE_TYPE;\n  }\n\n  /**\n   * Create the wrapper given an underlying CfnResource that is an instance of Custom::AmplifyDynamoDBTable.\n   * @param resource the Cfn resource.\n   */\n  constructor(private readonly resource: CfnResource) {\n    if (resource.cfnResourceType !== AMPLIFY_DYNAMODB_TABLE_RESOURCE_TYPE) {\n      throw new Error(`Only CfnResource with type ${AMPLIFY_DYNAMODB_TABLE_RESOURCE_TYPE} can be used in AmplifyDynamoDbTable`);\n    }\n  }\n\n  /**\n   * Specify how you are charged for read and write throughput and how you manage capacity.\n   */\n  set billingMode(billingMode: BillingMode) {\n    this.resource.addPropertyOverride('billingMode', billingMode);\n  }\n\n  /**\n   * The name of TTL attribute.\n   */\n  set timeToLiveAttribute(timeToLiveSpecification: TimeToLiveSpecification) {\n    this.resource.addPropertyOverride('timeToLiveSpecification', timeToLiveSpecification);\n  }\n\n  /**\n   * Whether point-in-time recovery is enabled.\n   */\n  set pointInTimeRecoveryEnabled(pointInTimeRecoveryEnabled: boolean) {\n    this.resource.addPropertyOverride('pointInTimeRecoverySpecification', { pointInTimeRecoveryEnabled });\n  }\n\n  /**\n   * Update the provisioned throughput for the base table.\n   */\n  set provisionedThroughput(provisionedThroughput: ProvisionedThroughput) {\n    this.resource.addPropertyOverride('provisionedThroughput', provisionedThroughput);\n  }\n\n  /**\n   * Set the provisionedThroughtput for a specified GSI by name.\n   * @param indexName the index to specify a provisionedThroughput config for\n   * @param provisionedThroughput the config to set\n   */\n  setGlobalSecondaryIndexProvisionedThroughput(indexName: string, provisionedThroughput: ProvisionedThroughput): void {\n    const gsis: Array<[string, { indexName: string }]> = Object.entries(\n      (this.resource as any).rawOverrides?.Properties?.globalSecondaryIndexes ?? {},\n    );\n    const foundGsis = gsis.filter(([_, gsiConfig]) => indexName === gsiConfig.indexName).map(([gsiIndex]) => gsiIndex);\n    if (foundGsis.length !== 1) {\n      throw new Error(`Index with name ${indexName} not found in table definition`);\n    }\n    this.resource.addPropertyOverride(`globalSecondaryIndexes.${foundGsis[0]}.provisionedThroughput`, provisionedThroughput);\n  }\n\n  /**\n   * Set the ddb stream specification on the table.\n   */\n  set streamSpecification(streamSpecification: StreamSpecification) {\n    this.resource.addPropertyOverride('streamSpecification', streamSpecification);\n  }\n\n  /**\n   * Set the ddb server-side encryption specification on the table.\n   */\n  set sseSpecification(sseSpecification: SSESpecification) {\n    this.resource.addPropertyOverride('sseSpecification', sseSpecification);\n  }\n\n  /**\n   * Set table deletion protection.\n   */\n  set deletionProtectionEnabled(deletionProtectionEnabled: boolean) {\n    this.resource.addPropertyOverride('deletionProtectionEnabled', deletionProtectionEnabled);\n  }\n}\n"]}
@@ -259,7 +259,7 @@ class AmplifyGraphqlApi extends constructs_1.Construct {
259
259
  }
260
260
  exports.AmplifyGraphqlApi = AmplifyGraphqlApi;
261
261
  _a = JSII_RTTI_SYMBOL_1;
262
- AmplifyGraphqlApi[_a] = { fqn: "@aws-amplify/graphql-api-construct.AmplifyGraphqlApi", version: "1.5.7-implicit-fields.0" };
262
+ AmplifyGraphqlApi[_a] = { fqn: "@aws-amplify/graphql-api-construct.AmplifyGraphqlApi", version: "1.6.0-secrets-manager.0" };
263
263
  /**
264
264
  * Given the provided scope, walk the node tree, and throw an exception if any other AmplifyGraphqlApi constructs
265
265
  * are found in the stack.
@@ -101,5 +101,5 @@ class AmplifyGraphqlDefinition {
101
101
  }
102
102
  exports.AmplifyGraphqlDefinition = AmplifyGraphqlDefinition;
103
103
  _a = JSII_RTTI_SYMBOL_1;
104
- AmplifyGraphqlDefinition[_a] = { fqn: "@aws-amplify/graphql-api-construct.AmplifyGraphqlDefinition", version: "1.5.7-implicit-fields.0" };
104
+ AmplifyGraphqlDefinition[_a] = { fqn: "@aws-amplify/graphql-api-construct.AmplifyGraphqlDefinition", version: "1.6.0-secrets-manager.0" };
105
105
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"amplify-graphql-definition.js","sourceRoot":"","sources":["../src/amplify-graphql-definition.ts"],"names":[],"mappings":"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","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"]}
@@ -3,6 +3,8 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.validateDataSourceStrategy = exports.schemaByMergingDefinitions = exports.getDataSourceStrategiesProvider = exports.constructCustomSqlDataSourceStrategies = void 0;
4
4
  const graphql_1 = require("graphql");
5
5
  const graphql_transformer_core_1 = require("@aws-amplify/graphql-transformer-core");
6
+ const graphql_transformer_interfaces_1 = require("@aws-amplify/graphql-transformer-interfaces");
7
+ const aws_cdk_lib_1 = require("aws-cdk-lib");
6
8
  /**
7
9
  * Creates an interface flavor of customSqlDataSourceStrategies from a factory method's schema and data source. Internally, this function
8
10
  * scans the fields of `Query` and `Mutation` looking for fields annotated with the `@sql` directive and designates the specified
@@ -148,13 +150,44 @@ const validateDataSourceStrategy = (strategy) => {
148
150
  return;
149
151
  }
150
152
  const dbConnectionConfig = strategy.dbConnectionConfig;
151
- const invalidSSMPaths = Object.values(dbConnectionConfig).filter((value) => typeof value === 'string' && !isValidSSMPath(value));
152
- if (invalidSSMPaths.length > 0) {
153
- throw new Error(`Invalid data source strategy "${strategy.name}". Following SSM paths must start with '/' in dbConnectionConfig: ${invalidSSMPaths.join(', ')}.`);
153
+ if ((0, graphql_transformer_interfaces_1.isSqlModelDataSourceSsmDbConnectionConfig)(dbConnectionConfig)) {
154
+ const invalidSSMPaths = Object.values(dbConnectionConfig).filter((value) => typeof value === 'string' && !isValidSSMPath(value));
155
+ if (invalidSSMPaths.length > 0) {
156
+ throw new Error(`Invalid data source strategy "${strategy.name}". Following SSM paths must start with '/' in dbConnectionConfig: ${invalidSSMPaths.join(', ')}.`);
157
+ }
158
+ }
159
+ else if ((0, graphql_transformer_interfaces_1.isSqlModelDataSourceSecretsManagerDbConnectionConfig)(dbConnectionConfig)) {
160
+ if (!aws_cdk_lib_1.Token.isUnresolved(dbConnectionConfig.secretArn)) {
161
+ try {
162
+ const arnComponents = aws_cdk_lib_1.Arn.split(dbConnectionConfig.secretArn, aws_cdk_lib_1.ArnFormat.COLON_RESOURCE_NAME);
163
+ if (arnComponents.service !== 'secretsmanager' || arnComponents.resource !== 'secret') {
164
+ // error message does not matter because it inside try/catch
165
+ throw new Error();
166
+ }
167
+ }
168
+ catch {
169
+ throw new Error(`Invalid data source strategy "${strategy.name}". The value of secretArn is not a valid Secrets Manager ARN.`);
170
+ }
171
+ }
172
+ if (dbConnectionConfig.keyArn && !aws_cdk_lib_1.Token.isUnresolved(dbConnectionConfig.keyArn)) {
173
+ try {
174
+ const arnComponents = aws_cdk_lib_1.Arn.split(dbConnectionConfig.keyArn, aws_cdk_lib_1.ArnFormat.SLASH_RESOURCE_NAME);
175
+ if (arnComponents.service !== 'kms' || arnComponents.resource !== 'key') {
176
+ // error message does not matter because it inside try/catch
177
+ throw new Error();
178
+ }
179
+ }
180
+ catch {
181
+ throw new Error(`Invalid data source strategy "${strategy.name}". The value of keyArn is not a valid KMS ARN.`);
182
+ }
183
+ }
184
+ }
185
+ else {
186
+ throw new Error(`Invalid data source strategy "${strategy.name}". dbConnectionConfig does not include SSM paths or Secret ARN.`);
154
187
  }
155
188
  };
156
189
  exports.validateDataSourceStrategy = validateDataSourceStrategy;
157
190
  const isValidSSMPath = (path) => {
158
191
  return path.startsWith('/');
159
192
  };
160
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-source-config.js","sourceRoot":"","sources":["../../src/internal/data-source-config.ts"],"names":[],"mappings":"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","sourcesContent":["import { DefinitionNode, FieldDefinitionNode, InterfaceTypeDefinitionNode, ObjectTypeDefinitionNode, parse, print } from 'graphql';\nimport {\n  isBuiltInGraphqlNode,\n  isSqlStrategy,\n  isQueryNode,\n  isMutationNode,\n  fieldsWithSqlDirective,\n} from '@aws-amplify/graphql-transformer-core';\nimport { DataSourceStrategiesProvider } from '@aws-amplify/graphql-transformer-interfaces';\nimport {\n  CustomSqlDataSourceStrategy as ConstructCustomSqlDataSourceStrategy,\n  ModelDataSourceStrategy as ConstructModelDataSourceStrategy,\n} from '../model-datasource-strategy-types';\nimport { IAmplifyGraphqlDefinition } from '../types';\n\n/**\n * Creates an interface flavor of customSqlDataSourceStrategies from a factory method's schema and data source. Internally, this function\n * scans the fields of `Query` and `Mutation` looking for fields annotated with the `@sql` directive and designates the specified\n * dataSourceStrategy to fulfill those custom queries.\n *\n * 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\n * anyway, since subscriptions are processed from an incoming Mutation, not as the result of a direct datasource access.\n */\nexport const constructCustomSqlDataSourceStrategies = (\n  schema: string,\n  dataSourceStrategy: ConstructModelDataSourceStrategy,\n): ConstructCustomSqlDataSourceStrategy[] => {\n  if (!isSqlStrategy(dataSourceStrategy)) {\n    return [];\n  }\n\n  const parsedSchema = parse(schema);\n\n  const queryNode = parsedSchema.definitions.find(isQueryNode);\n  const mutationNode = parsedSchema.definitions.find(isMutationNode);\n  if (!queryNode && !mutationNode) {\n    return [];\n  }\n\n  const customSqlDataSourceStrategies: ConstructCustomSqlDataSourceStrategy[] = [];\n\n  if (queryNode) {\n    const fields = fieldsWithSqlDirective(queryNode);\n    for (const field of fields) {\n      customSqlDataSourceStrategies.push({\n        typeName: 'Query',\n        fieldName: field.name.value,\n        strategy: dataSourceStrategy,\n      });\n    }\n  }\n\n  if (mutationNode) {\n    const fields = fieldsWithSqlDirective(mutationNode);\n    for (const field of fields) {\n      customSqlDataSourceStrategies.push({\n        typeName: 'Mutation',\n        fieldName: field.name.value,\n        strategy: dataSourceStrategy,\n      });\n    }\n  }\n\n  return customSqlDataSourceStrategies;\n};\n\n/**\n * Extracts the data source provider from the definition. This jumps through some hoops to avoid changing the public interface. If we decide\n * to change the public interface to simplify the structure, then this process gets a lot simpler.\n */\nexport const getDataSourceStrategiesProvider = (definition: IAmplifyGraphqlDefinition): DataSourceStrategiesProvider => {\n  const provider: DataSourceStrategiesProvider = {\n    // We can directly use the interface strategies, even though the SQL strategies have the customSqlStatements field that is unused by the\n    // transformer flavor of this type\n    dataSourceStrategies: definition.dataSourceStrategies,\n    sqlDirectiveDataSourceStrategies: [],\n  };\n\n  // We'll collect all the custom SQL statements from the definition into a single map, and use that to make our\n  // SqlDirectiveDataSourceStrategies\n  const customSqlStatements: Record<string, string> = {};\n\n  const constructSqlStrategies = definition.customSqlDataSourceStrategies ?? [];\n\n  // Note that we're relying on the `customSqlStatements` object reference to stay the same throughout this loop. Don't reassign it, or the\n  // collected sqlDirectiveStrategies will break\n  constructSqlStrategies.forEach((sqlStrategy) => {\n    if (sqlStrategy.strategy.customSqlStatements) {\n      Object.assign(customSqlStatements, sqlStrategy.strategy.customSqlStatements);\n    }\n\n    provider.sqlDirectiveDataSourceStrategies!.push({\n      typeName: sqlStrategy.typeName,\n      fieldName: sqlStrategy.fieldName,\n      strategy: sqlStrategy.strategy,\n      customSqlStatements,\n    });\n  });\n\n  return provider;\n};\n\n/**\n * Creates a new schema by merging the individual schemas contained in the definitions, combining fields of the Query and Mutation types in\n * individual definitions into a single combined definition. Adding directives to `Query` and `Mutation` types participating in a\n * combination is not supported (the behavior is undefined whether those directives are migrated).\n */\nexport const schemaByMergingDefinitions = (definitions: IAmplifyGraphqlDefinition[]): string => {\n  const schema = definitions.map((def) => def.schema).join('\\n');\n  const parsedSchema = parse(schema);\n\n  // We store the Query & Mutation definitions separately. Since the interfaces are readonly, we'll have to re-compose the types after we've\n  // collected all the fields\n  const queryAndMutationDefinitions: Record<\n    string,\n    {\n      node: ObjectTypeDefinitionNode | InterfaceTypeDefinitionNode;\n      fields: FieldDefinitionNode[];\n    }\n  > = {};\n\n  // Throws if the field has already been encountered\n  const validateField = (typeName: string, fieldName: string): void => {\n    const fields = queryAndMutationDefinitions[typeName]?.fields;\n    if (!fields) {\n      return;\n    }\n    if (fields.find((field) => field.name.value === fieldName)) {\n      throw new Error(\n        `The custom ${typeName} field '${fieldName}' was found in multiple definitions, but a field name cannot be shared between definitions.`,\n      );\n    }\n  };\n\n  // Transform the schema by reducing Mutation & Query types:\n  // - Collect Mutation and Query definitions\n  // - Alter the parsed schema by filtering out Mutation & Query types\n  // - Add the combined Mutation & Query definitions to the filtered schema\n  parsedSchema.definitions.filter(isBuiltInGraphqlNode).forEach((def) => {\n    const typeName = def.name.value;\n    if (!queryAndMutationDefinitions[typeName]) {\n      queryAndMutationDefinitions[typeName] = {\n        node: def,\n        // `ObjectTypeDefinitionNode.fields` is a ReadonlyArray; so we have to create a new mutable array to collect all the fields\n        fields: [...(def.fields ?? [])],\n      };\n      return;\n    }\n\n    (def.fields ?? []).forEach((field) => {\n      validateField(typeName, field.name.value);\n    });\n\n    queryAndMutationDefinitions[typeName].fields = [...queryAndMutationDefinitions[typeName].fields, ...(def.fields ?? [])];\n  });\n\n  // Gather the collected Query & Mutation fields into <=2 new definitions\n  const combinedDefinitions = Object.values(queryAndMutationDefinitions)\n    .sort((a, b) => a.node.name.value.localeCompare(b.node.name.value))\n    .reduce((acc, cur) => {\n      const definitionNode = {\n        ...cur.node,\n        fields: cur.fields,\n      };\n      return [...acc, definitionNode];\n    }, [] as DefinitionNode[]);\n\n  // Filter out the old Query & Mutation definitions\n  const filteredDefinitions = parsedSchema.definitions.filter((def) => !isBuiltInGraphqlNode(def));\n\n  // Compose the new schema by appending the collected definitions to the filtered definitions. This means that every query will be\n  // rewritten such that the Mutation and Query types appear at the end of the schema.\n  const newSchema = {\n    ...parsedSchema,\n    definitions: [...filteredDefinitions, ...combinedDefinitions],\n  };\n\n  const combinedSchemaString = print(newSchema);\n  return combinedSchemaString;\n};\n\n/*\n * Validates the user input for the dataSourceStrategy. This is a no-op for DynamoDB strategies for now.\n * @param strategy user provided model data source strategy\n * @returns validates and throws an error if the strategy is invalid\n */\nexport const validateDataSourceStrategy = (strategy: ConstructModelDataSourceStrategy) => {\n  if (!isSqlStrategy(strategy)) {\n    return;\n  }\n\n  const dbConnectionConfig = strategy.dbConnectionConfig;\n  const invalidSSMPaths = Object.values(dbConnectionConfig).filter((value) => typeof value === 'string' && !isValidSSMPath(value));\n  if (invalidSSMPaths.length > 0) {\n    throw new Error(\n      `Invalid data source strategy \"${\n        strategy.name\n      }\". Following SSM paths must start with '/' in dbConnectionConfig: ${invalidSSMPaths.join(', ')}.`,\n    );\n  }\n};\n\nconst isValidSSMPath = (path: string): boolean => {\n  return path.startsWith('/');\n};\n"]}
193
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-source-config.js","sourceRoot":"","sources":["../../src/internal/data-source-config.ts"],"names":[],"mappings":"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","sourcesContent":["import { DefinitionNode, FieldDefinitionNode, InterfaceTypeDefinitionNode, ObjectTypeDefinitionNode, parse, print } from 'graphql';\nimport {\n  isBuiltInGraphqlNode,\n  isSqlStrategy,\n  isQueryNode,\n  isMutationNode,\n  fieldsWithSqlDirective,\n} from '@aws-amplify/graphql-transformer-core';\nimport {\n  DataSourceStrategiesProvider,\n  isSqlModelDataSourceSsmDbConnectionConfig,\n  isSqlModelDataSourceSecretsManagerDbConnectionConfig,\n} from '@aws-amplify/graphql-transformer-interfaces';\nimport { Token, Arn, ArnFormat } from 'aws-cdk-lib';\nimport {\n  CustomSqlDataSourceStrategy as ConstructCustomSqlDataSourceStrategy,\n  ModelDataSourceStrategy as ConstructModelDataSourceStrategy,\n} from '../model-datasource-strategy-types';\nimport { IAmplifyGraphqlDefinition } from '../types';\n\n/**\n * Creates an interface flavor of customSqlDataSourceStrategies from a factory method's schema and data source. Internally, this function\n * scans the fields of `Query` and `Mutation` looking for fields annotated with the `@sql` directive and designates the specified\n * dataSourceStrategy to fulfill those custom queries.\n *\n * 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\n * anyway, since subscriptions are processed from an incoming Mutation, not as the result of a direct datasource access.\n */\nexport const constructCustomSqlDataSourceStrategies = (\n  schema: string,\n  dataSourceStrategy: ConstructModelDataSourceStrategy,\n): ConstructCustomSqlDataSourceStrategy[] => {\n  if (!isSqlStrategy(dataSourceStrategy)) {\n    return [];\n  }\n\n  const parsedSchema = parse(schema);\n\n  const queryNode = parsedSchema.definitions.find(isQueryNode);\n  const mutationNode = parsedSchema.definitions.find(isMutationNode);\n  if (!queryNode && !mutationNode) {\n    return [];\n  }\n\n  const customSqlDataSourceStrategies: ConstructCustomSqlDataSourceStrategy[] = [];\n\n  if (queryNode) {\n    const fields = fieldsWithSqlDirective(queryNode);\n    for (const field of fields) {\n      customSqlDataSourceStrategies.push({\n        typeName: 'Query',\n        fieldName: field.name.value,\n        strategy: dataSourceStrategy,\n      });\n    }\n  }\n\n  if (mutationNode) {\n    const fields = fieldsWithSqlDirective(mutationNode);\n    for (const field of fields) {\n      customSqlDataSourceStrategies.push({\n        typeName: 'Mutation',\n        fieldName: field.name.value,\n        strategy: dataSourceStrategy,\n      });\n    }\n  }\n\n  return customSqlDataSourceStrategies;\n};\n\n/**\n * Extracts the data source provider from the definition. This jumps through some hoops to avoid changing the public interface. If we decide\n * to change the public interface to simplify the structure, then this process gets a lot simpler.\n */\nexport const getDataSourceStrategiesProvider = (definition: IAmplifyGraphqlDefinition): DataSourceStrategiesProvider => {\n  const provider: DataSourceStrategiesProvider = {\n    // We can directly use the interface strategies, even though the SQL strategies have the customSqlStatements field that is unused by the\n    // transformer flavor of this type\n    dataSourceStrategies: definition.dataSourceStrategies,\n    sqlDirectiveDataSourceStrategies: [],\n  };\n\n  // We'll collect all the custom SQL statements from the definition into a single map, and use that to make our\n  // SqlDirectiveDataSourceStrategies\n  const customSqlStatements: Record<string, string> = {};\n\n  const constructSqlStrategies = definition.customSqlDataSourceStrategies ?? [];\n\n  // Note that we're relying on the `customSqlStatements` object reference to stay the same throughout this loop. Don't reassign it, or the\n  // collected sqlDirectiveStrategies will break\n  constructSqlStrategies.forEach((sqlStrategy) => {\n    if (sqlStrategy.strategy.customSqlStatements) {\n      Object.assign(customSqlStatements, sqlStrategy.strategy.customSqlStatements);\n    }\n\n    provider.sqlDirectiveDataSourceStrategies!.push({\n      typeName: sqlStrategy.typeName,\n      fieldName: sqlStrategy.fieldName,\n      strategy: sqlStrategy.strategy,\n      customSqlStatements,\n    });\n  });\n\n  return provider;\n};\n\n/**\n * Creates a new schema by merging the individual schemas contained in the definitions, combining fields of the Query and Mutation types in\n * individual definitions into a single combined definition. Adding directives to `Query` and `Mutation` types participating in a\n * combination is not supported (the behavior is undefined whether those directives are migrated).\n */\nexport const schemaByMergingDefinitions = (definitions: IAmplifyGraphqlDefinition[]): string => {\n  const schema = definitions.map((def) => def.schema).join('\\n');\n  const parsedSchema = parse(schema);\n\n  // We store the Query & Mutation definitions separately. Since the interfaces are readonly, we'll have to re-compose the types after we've\n  // collected all the fields\n  const queryAndMutationDefinitions: Record<\n    string,\n    {\n      node: ObjectTypeDefinitionNode | InterfaceTypeDefinitionNode;\n      fields: FieldDefinitionNode[];\n    }\n  > = {};\n\n  // Throws if the field has already been encountered\n  const validateField = (typeName: string, fieldName: string): void => {\n    const fields = queryAndMutationDefinitions[typeName]?.fields;\n    if (!fields) {\n      return;\n    }\n    if (fields.find((field) => field.name.value === fieldName)) {\n      throw new Error(\n        `The custom ${typeName} field '${fieldName}' was found in multiple definitions, but a field name cannot be shared between definitions.`,\n      );\n    }\n  };\n\n  // Transform the schema by reducing Mutation & Query types:\n  // - Collect Mutation and Query definitions\n  // - Alter the parsed schema by filtering out Mutation & Query types\n  // - Add the combined Mutation & Query definitions to the filtered schema\n  parsedSchema.definitions.filter(isBuiltInGraphqlNode).forEach((def) => {\n    const typeName = def.name.value;\n    if (!queryAndMutationDefinitions[typeName]) {\n      queryAndMutationDefinitions[typeName] = {\n        node: def,\n        // `ObjectTypeDefinitionNode.fields` is a ReadonlyArray; so we have to create a new mutable array to collect all the fields\n        fields: [...(def.fields ?? [])],\n      };\n      return;\n    }\n\n    (def.fields ?? []).forEach((field) => {\n      validateField(typeName, field.name.value);\n    });\n\n    queryAndMutationDefinitions[typeName].fields = [...queryAndMutationDefinitions[typeName].fields, ...(def.fields ?? [])];\n  });\n\n  // Gather the collected Query & Mutation fields into <=2 new definitions\n  const combinedDefinitions = Object.values(queryAndMutationDefinitions)\n    .sort((a, b) => a.node.name.value.localeCompare(b.node.name.value))\n    .reduce((acc, cur) => {\n      const definitionNode = {\n        ...cur.node,\n        fields: cur.fields,\n      };\n      return [...acc, definitionNode];\n    }, [] as DefinitionNode[]);\n\n  // Filter out the old Query & Mutation definitions\n  const filteredDefinitions = parsedSchema.definitions.filter((def) => !isBuiltInGraphqlNode(def));\n\n  // Compose the new schema by appending the collected definitions to the filtered definitions. This means that every query will be\n  // rewritten such that the Mutation and Query types appear at the end of the schema.\n  const newSchema = {\n    ...parsedSchema,\n    definitions: [...filteredDefinitions, ...combinedDefinitions],\n  };\n\n  const combinedSchemaString = print(newSchema);\n  return combinedSchemaString;\n};\n\n/*\n * Validates the user input for the dataSourceStrategy. This is a no-op for DynamoDB strategies for now.\n * @param strategy user provided model data source strategy\n * @returns validates and throws an error if the strategy is invalid\n */\nexport const validateDataSourceStrategy = (strategy: ConstructModelDataSourceStrategy): void => {\n  if (!isSqlStrategy(strategy)) {\n    return;\n  }\n\n  const dbConnectionConfig = strategy.dbConnectionConfig;\n  if (isSqlModelDataSourceSsmDbConnectionConfig(dbConnectionConfig)) {\n    const invalidSSMPaths = Object.values(dbConnectionConfig).filter((value) => typeof value === 'string' && !isValidSSMPath(value));\n    if (invalidSSMPaths.length > 0) {\n      throw new Error(\n        `Invalid data source strategy \"${\n          strategy.name\n        }\". Following SSM paths must start with '/' in dbConnectionConfig: ${invalidSSMPaths.join(', ')}.`,\n      );\n    }\n  } else if (isSqlModelDataSourceSecretsManagerDbConnectionConfig(dbConnectionConfig)) {\n    if (!Token.isUnresolved(dbConnectionConfig.secretArn)) {\n      try {\n        const arnComponents = Arn.split(dbConnectionConfig.secretArn, ArnFormat.COLON_RESOURCE_NAME);\n        if (arnComponents.service !== 'secretsmanager' || arnComponents.resource !== 'secret') {\n          // error message does not matter because it inside try/catch\n          throw new Error();\n        }\n      } catch {\n        throw new Error(`Invalid data source strategy \"${strategy.name}\". The value of secretArn is not a valid Secrets Manager ARN.`);\n      }\n    }\n\n    if (dbConnectionConfig.keyArn && !Token.isUnresolved(dbConnectionConfig.keyArn)) {\n      try {\n        const arnComponents = Arn.split(dbConnectionConfig.keyArn, ArnFormat.SLASH_RESOURCE_NAME);\n        if (arnComponents.service !== 'kms' || arnComponents.resource !== 'key') {\n          // error message does not matter because it inside try/catch\n          throw new Error();\n        }\n      } catch {\n        throw new Error(`Invalid data source strategy \"${strategy.name}\". The value of keyArn is not a valid KMS ARN.`);\n      }\n    }\n  } else {\n    throw new Error(`Invalid data source strategy \"${strategy.name}\". dbConnectionConfig does not include SSM paths or Secret ARN.`);\n  }\n};\n\nconst isValidSSMPath = (path: string): boolean => {\n  return path.startsWith('/');\n};\n"]}
@@ -88,12 +88,36 @@ export interface SubnetAvailabilityZone {
88
88
  /** The availability zone of the subnet. */
89
89
  readonly availabilityZone: string;
90
90
  }
91
+ /**
92
+ * The credentials the lambda data source will use to connect to the database.
93
+ *
94
+ * @experimental
95
+ */
96
+ export type SqlModelDataSourceDbConnectionConfig = SqlModelDataSourceSecretsManagerDbConnectionConfig | SqlModelDataSourceSsmDbConnectionConfig;
97
+ /**
98
+ * The credentials stored in Secrets Manager that the lambda data source will use to connect to the database.
99
+ *
100
+ * The managed secret should be in the same region as the lambda.
101
+ * @experimental
102
+ */
103
+ export interface SqlModelDataSourceSecretsManagerDbConnectionConfig {
104
+ /** The ARN of the managed secret with username, password, and hostname to use when connecting to the database. **/
105
+ readonly secretArn: string;
106
+ /** The ARN of the customer managed encryption key for the secret. If not supplied, the secret is expected to be encrypted with the default AWS-managed key. **/
107
+ readonly keyArn?: string;
108
+ /** The port number of the database proxy, cluster, or instance. */
109
+ readonly port: number;
110
+ /** The database name. */
111
+ readonly databaseName: string;
112
+ /** The hostame of the database. */
113
+ readonly hostname: string;
114
+ }
91
115
  /**
92
116
  * The Secure Systems Manager parameter paths the Lambda data source will use to connect to the database.
93
117
  *
94
118
  * These parameters are retrieved from Secure Systems Manager in the same region as the Lambda.
95
119
  */
96
- export interface SqlModelDataSourceDbConnectionConfig {
120
+ export interface SqlModelDataSourceSsmDbConnectionConfig {
97
121
  /** The Secure Systems Manager parameter containing the hostname of the database. For RDS-based SQL data sources, this can be the hostname
98
122
  * of a database proxy, cluster, or instance.
99
123
  */
@@ -7,4 +7,4 @@
7
7
  // amplify-graphql-transformer-interfaces/src/model-datasource (the internal implementation)
8
8
  // #########################################################################################################################################
9
9
  Object.defineProperty(exports, "__esModule", { value: true });
10
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"model-datasource-strategy-types.js","sourceRoot":"","sources":["../src/model-datasource-strategy-types.ts"],"names":[],"mappings":";AAAA,4IAA4I;AAC5I,4IAA4I;AAC5I,8DAA8D;AAC9D,EAAE;AACF,6GAA6G;AAC7G,4FAA4F;AAC5F,4IAA4I","sourcesContent":["// #########################################################################################################################################\n// These are the public-facing types used by customers to define their L3 CDK construct. Many of these have corresponding definitions in the\n// transformer-interfaces package to define internal behavior.\n//\n// If you change types in this file (the customer-facing interface), be sure to make corresponding changes to\n// amplify-graphql-transformer-interfaces/src/model-datasource (the internal implementation)\n// #########################################################################################################################################\n\n/**\n * All known ModelDataSourceStrategies. Concrete strategies vary widely in their requirements and implementations.\n */\nexport type ModelDataSourceStrategy =\n  | DefaultDynamoDbModelDataSourceStrategy\n  | AmplifyDynamoDbModelDataSourceStrategy\n  | SQLLambdaModelDataSourceStrategy;\n\n/**\n * All supported database types that can be used to resolve models.\n */\nexport type ModelDataSourceStrategyDbType = 'DYNAMODB' | ModelDataSourceStrategySqlDbType;\n\n/**\n * All supported SQL database types that can be used to resolve models.\n */\nexport type ModelDataSourceStrategySqlDbType = 'MYSQL' | 'POSTGRES';\n\n/**\n * Use default CloudFormation type 'AWS::DynamoDB::Table' to provision table.\n */\nexport interface DefaultDynamoDbModelDataSourceStrategy {\n  readonly dbType: 'DYNAMODB';\n  readonly provisionStrategy: 'DEFAULT';\n}\n\n/**\n * Use custom resource type 'Custom::AmplifyDynamoDBTable' to provision table.\n */\nexport interface AmplifyDynamoDbModelDataSourceStrategy {\n  readonly dbType: 'DYNAMODB';\n  readonly provisionStrategy: 'AMPLIFY_TABLE';\n}\n\n/**\n * A strategy that creates a Lambda to connect to a pre-existing SQL table to resolve model data.\n */\nexport interface SQLLambdaModelDataSourceStrategy {\n  /**\n   * The name of the strategy. This will be used to name the AppSync DataSource itself, plus any associated resources like resolver Lambdas.\n   * This name must be unique across all schema definitions in a GraphQL API.\n   */\n  readonly name: string;\n\n  /**\n   * The type of the SQL database used to process model operations for this definition.\n   */\n  readonly dbType: ModelDataSourceStrategySqlDbType;\n\n  /**\n   * The parameters the Lambda data source will use to connect to the database.\n   */\n  readonly dbConnectionConfig: SqlModelDataSourceDbConnectionConfig;\n\n  /**\n   * The configuration of the VPC into which to install the Lambda.\n   */\n  readonly vpcConfiguration?: VpcConfig;\n\n  /**\n   * Custom SQL statements. The key is the value of the `references` attribute of the `@sql` directive in the `schema`; the value is the SQL\n   * to be executed.\n   */\n  readonly customSqlStatements?: Record<string, string>;\n\n  /**\n   * The configuration for the provisioned concurrency of the Lambda.\n   */\n  readonly sqlLambdaProvisionedConcurrencyConfig?: ProvisionedConcurrencyConfig;\n}\n\n/**\n * Configuration of the VPC in which to install a Lambda to resolve queries against a SQL-based data source. The SQL Lambda will be deployed\n * into the specified VPC, subnets, and security groups. The specified subnets and security groups must be in the same VPC. The VPC must\n * have at least one subnet. The construct will also create VPC service endpoints in the specified subnets, as well as inbound security\n * rules, to allow traffic on port 443 within each security group. This allows the Lambda to read database connection information from\n * Secure Systems Manager.\n */\nexport interface VpcConfig {\n  /** The VPC to install the Lambda data source in. */\n  readonly vpcId: string;\n\n  /** The security groups to install the Lambda data source in. */\n  readonly securityGroupIds: string[];\n\n  /** The subnets to install the Lambda data source in, one per availability zone. */\n  readonly subnetAvailabilityZoneConfig: SubnetAvailabilityZone[];\n}\n\n/**\n * The configuration for the provisioned concurrency of the Lambda.\n */\nexport interface ProvisionedConcurrencyConfig {\n  /** The amount of provisioned concurrency to allocate. **/\n  readonly provisionedConcurrentExecutions: number;\n}\n\n/**\n * Subnet configuration for VPC endpoints used by a Lambda resolver for a SQL-based data source. Although it is possible to create multiple\n * subnets in a single availability zone, VPC service endpoints may only be deployed to a single subnet in a given availability zone. This\n * structure ensures that the Lambda function and VPC service endpoints are mutually consistent.\n */\nexport interface SubnetAvailabilityZone {\n  /** The subnet ID to install the Lambda data source in. */\n  readonly subnetId: string;\n\n  /** The availability zone of the subnet. */\n  readonly availabilityZone: string;\n}\n\n/**\n * The Secure Systems Manager parameter paths the Lambda data source will use to connect to the database.\n *\n * These parameters are retrieved from Secure Systems Manager in the same region as the Lambda.\n */\nexport interface SqlModelDataSourceDbConnectionConfig {\n  /** The Secure Systems Manager parameter containing the hostname of the database. For RDS-based SQL data sources, this can be the hostname\n   * of a database proxy, cluster, or instance.\n   */\n  readonly hostnameSsmPath: string;\n\n  /** The Secure Systems Manager parameter containing the port number of the database proxy, cluster, or instance. */\n  readonly portSsmPath: string;\n\n  /** The Secure Systems Manager parameter containing the username to use when connecting to the database. */\n  readonly usernameSsmPath: string;\n\n  /** The Secure Systems Manager parameter containing the password to use when connecting to the database. */\n  readonly passwordSsmPath: string;\n\n  /** The Secure Systems Manager parameter containing the database name. */\n  readonly databaseNameSsmPath: string;\n}\n\n/**\n * The input type for defining a ModelDataSourceStrategy used to resolve a field annotated with a `@sql` directive. Although this is a\n * public type, you should rarely need to use this. The AmplifyGraphqlDefinition factory methods (e.g., `fromString`,\n * `fromFilesAndStrategy`) will automatically construct this structure for you.\n */\nexport interface CustomSqlDataSourceStrategy {\n  /** The built-in type (either \"Query\" or \"Mutation\") with which the custom SQL is associated */\n  readonly typeName: 'Query' | 'Mutation';\n\n  /** The field name with which the custom SQL is associated */\n  readonly fieldName: string;\n\n  /** The strategy used to create the datasource that will resolve the custom SQL statement. */\n  readonly strategy: SQLLambdaModelDataSourceStrategy;\n}\n"]}
10
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"model-datasource-strategy-types.js","sourceRoot":"","sources":["../src/model-datasource-strategy-types.ts"],"names":[],"mappings":";AAAA,4IAA4I;AAC5I,4IAA4I;AAC5I,8DAA8D;AAC9D,EAAE;AACF,6GAA6G;AAC7G,4FAA4F;AAC5F,4IAA4I","sourcesContent":["// #########################################################################################################################################\n// These are the public-facing types used by customers to define their L3 CDK construct. Many of these have corresponding definitions in the\n// transformer-interfaces package to define internal behavior.\n//\n// If you change types in this file (the customer-facing interface), be sure to make corresponding changes to\n// amplify-graphql-transformer-interfaces/src/model-datasource (the internal implementation)\n// #########################################################################################################################################\n\n/**\n * All known ModelDataSourceStrategies. Concrete strategies vary widely in their requirements and implementations.\n */\nexport type ModelDataSourceStrategy =\n  | DefaultDynamoDbModelDataSourceStrategy\n  | AmplifyDynamoDbModelDataSourceStrategy\n  | SQLLambdaModelDataSourceStrategy;\n\n/**\n * All supported database types that can be used to resolve models.\n */\nexport type ModelDataSourceStrategyDbType = 'DYNAMODB' | ModelDataSourceStrategySqlDbType;\n\n/**\n * All supported SQL database types that can be used to resolve models.\n */\nexport type ModelDataSourceStrategySqlDbType = 'MYSQL' | 'POSTGRES';\n\n/**\n * Use default CloudFormation type 'AWS::DynamoDB::Table' to provision table.\n */\nexport interface DefaultDynamoDbModelDataSourceStrategy {\n  readonly dbType: 'DYNAMODB';\n  readonly provisionStrategy: 'DEFAULT';\n}\n\n/**\n * Use custom resource type 'Custom::AmplifyDynamoDBTable' to provision table.\n */\nexport interface AmplifyDynamoDbModelDataSourceStrategy {\n  readonly dbType: 'DYNAMODB';\n  readonly provisionStrategy: 'AMPLIFY_TABLE';\n}\n\n/**\n * A strategy that creates a Lambda to connect to a pre-existing SQL table to resolve model data.\n */\nexport interface SQLLambdaModelDataSourceStrategy {\n  /**\n   * The name of the strategy. This will be used to name the AppSync DataSource itself, plus any associated resources like resolver Lambdas.\n   * This name must be unique across all schema definitions in a GraphQL API.\n   */\n  readonly name: string;\n\n  /**\n   * The type of the SQL database used to process model operations for this definition.\n   */\n  readonly dbType: ModelDataSourceStrategySqlDbType;\n\n  /**\n   * The parameters the Lambda data source will use to connect to the database.\n   */\n  readonly dbConnectionConfig: SqlModelDataSourceDbConnectionConfig;\n\n  /**\n   * The configuration of the VPC into which to install the Lambda.\n   */\n  readonly vpcConfiguration?: VpcConfig;\n\n  /**\n   * Custom SQL statements. The key is the value of the `references` attribute of the `@sql` directive in the `schema`; the value is the SQL\n   * to be executed.\n   */\n  readonly customSqlStatements?: Record<string, string>;\n\n  /**\n   * The configuration for the provisioned concurrency of the Lambda.\n   */\n  readonly sqlLambdaProvisionedConcurrencyConfig?: ProvisionedConcurrencyConfig;\n}\n\n/**\n * Configuration of the VPC in which to install a Lambda to resolve queries against a SQL-based data source. The SQL Lambda will be deployed\n * into the specified VPC, subnets, and security groups. The specified subnets and security groups must be in the same VPC. The VPC must\n * have at least one subnet. The construct will also create VPC service endpoints in the specified subnets, as well as inbound security\n * rules, to allow traffic on port 443 within each security group. This allows the Lambda to read database connection information from\n * Secure Systems Manager.\n */\nexport interface VpcConfig {\n  /** The VPC to install the Lambda data source in. */\n  readonly vpcId: string;\n\n  /** The security groups to install the Lambda data source in. */\n  readonly securityGroupIds: string[];\n\n  /** The subnets to install the Lambda data source in, one per availability zone. */\n  readonly subnetAvailabilityZoneConfig: SubnetAvailabilityZone[];\n}\n\n/**\n * The configuration for the provisioned concurrency of the Lambda.\n */\nexport interface ProvisionedConcurrencyConfig {\n  /** The amount of provisioned concurrency to allocate. **/\n  readonly provisionedConcurrentExecutions: number;\n}\n\n/**\n * Subnet configuration for VPC endpoints used by a Lambda resolver for a SQL-based data source. Although it is possible to create multiple\n * subnets in a single availability zone, VPC service endpoints may only be deployed to a single subnet in a given availability zone. This\n * structure ensures that the Lambda function and VPC service endpoints are mutually consistent.\n */\nexport interface SubnetAvailabilityZone {\n  /** The subnet ID to install the Lambda data source in. */\n  readonly subnetId: string;\n\n  /** The availability zone of the subnet. */\n  readonly availabilityZone: string;\n}\n\n/**\n * The credentials the lambda data source will use to connect to the database.\n *\n * @experimental\n */\nexport type SqlModelDataSourceDbConnectionConfig =\n  | SqlModelDataSourceSecretsManagerDbConnectionConfig\n  | SqlModelDataSourceSsmDbConnectionConfig;\n\n/**\n * The credentials stored in Secrets Manager that the lambda data source will use to connect to the database.\n *\n * The managed secret should be in the same region as the lambda.\n * @experimental\n */\nexport interface SqlModelDataSourceSecretsManagerDbConnectionConfig {\n  /** The ARN of the managed secret with username, password, and hostname to use when connecting to the database. **/\n  readonly secretArn: string;\n\n  /** The ARN of the customer managed encryption key for the secret. If not supplied, the secret is expected to be encrypted with the default AWS-managed key. **/\n  readonly keyArn?: string;\n\n  /** The port number of the database proxy, cluster, or instance. */\n  readonly port: number;\n\n  /** The database name. */\n  readonly databaseName: string;\n\n  /** The hostame of the database. */\n  readonly hostname: string;\n}\n\n/**\n * The Secure Systems Manager parameter paths the Lambda data source will use to connect to the database.\n *\n * These parameters are retrieved from Secure Systems Manager in the same region as the Lambda.\n */\nexport interface SqlModelDataSourceSsmDbConnectionConfig {\n  /** The Secure Systems Manager parameter containing the hostname of the database. For RDS-based SQL data sources, this can be the hostname\n   * of a database proxy, cluster, or instance.\n   */\n  readonly hostnameSsmPath: string;\n\n  /** The Secure Systems Manager parameter containing the port number of the database proxy, cluster, or instance. */\n  readonly portSsmPath: string;\n\n  /** The Secure Systems Manager parameter containing the username to use when connecting to the database. */\n  readonly usernameSsmPath: string;\n\n  /** The Secure Systems Manager parameter containing the password to use when connecting to the database. */\n  readonly passwordSsmPath: string;\n\n  /** The Secure Systems Manager parameter containing the database name. */\n  readonly databaseNameSsmPath: string;\n}\n\n/**\n * The input type for defining a ModelDataSourceStrategy used to resolve a field annotated with a `@sql` directive. Although this is a\n * public type, you should rarely need to use this. The AmplifyGraphqlDefinition factory methods (e.g., `fromString`,\n * `fromFilesAndStrategy`) will automatically construct this structure for you.\n */\nexport interface CustomSqlDataSourceStrategy {\n  /** The built-in type (either \"Query\" or \"Mutation\") with which the custom SQL is associated */\n  readonly typeName: 'Query' | 'Mutation';\n\n  /** The field name with which the custom SQL is associated */\n  readonly fieldName: string;\n\n  /** The strategy used to create the datasource that will resolve the custom SQL statement. */\n  readonly strategy: SQLLambdaModelDataSourceStrategy;\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { SQLLambdaModelDataSourceStrategy, SqlModelDataSourceDbConnectionConfig } from './model-datasource-strategy-types';
1
+ import { SQLLambdaModelDataSourceStrategy, SqlModelDataSourceDbConnectionConfig, SqlModelDataSourceSsmDbConnectionConfig, SqlModelDataSourceSecretsManagerDbConnectionConfig } from './model-datasource-strategy-types';
2
2
  /**
3
3
  * Type predicate that returns true if the object is a SQLLambdaModelDataSourceStrategy.
4
4
  * @param obj the object to inspect
@@ -11,6 +11,18 @@ export declare const isSQLLambdaModelDataSourceStrategy: (obj: any) => obj is SQ
11
11
  * @returns true if the object is shaped like a SqlModelDataSourceDbConnectionConfig
12
12
  */
13
13
  export declare const isSqlModelDataSourceDbConnectionConfig: (obj: any) => obj is SqlModelDataSourceDbConnectionConfig;
14
+ /**
15
+ * Type predicate that returns true if the object is a SqlModelDataSourceSsmDbConnectionConfig.
16
+ * @param obj the object to inspect
17
+ * @returns true if the object is shaped like a SqlModelDataSourceSsmDbConnectionConfig
18
+ */
19
+ export declare const isSqlModelDataSourceSsmDbConnectionConfig: (obj: any) => obj is SqlModelDataSourceSsmDbConnectionConfig;
20
+ /**
21
+ * Type predicate that returns true if the object is a SqlModelDataSourceSecretsManagerDbConnectionConfig.
22
+ * @param obj the object to inspect
23
+ * @returns true if the object is shaped like a SqlModelDataSourceSecretsManagerDbConnectionConfig
24
+ */
25
+ export declare const isSqlModelDataSourceSecretsManagerDbConnectionConfig: (obj: any) => obj is SqlModelDataSourceSecretsManagerDbConnectionConfig;
14
26
  /**
15
27
  * Class exposing utilities to produce SQLLambdaModelDataSourceStrategy objects given various inputs.
16
28
  */