@aws-amplify/graphql-api-construct 1.6.0 → 1.7.0-cors-rule.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (129) hide show
  1. package/.jsii +145 -34
  2. package/API.md +13 -1
  3. package/CHANGELOG.md +7 -0
  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/codegen-assets.js +14 -1
  9. package/lib/internal/data-source-config.js +37 -4
  10. package/lib/model-datasource-strategy-types.d.ts +25 -1
  11. package/lib/model-datasource-strategy-types.js +1 -1
  12. package/lib/sql-model-datasource-strategy.d.ts +13 -1
  13. package/lib/sql-model-datasource-strategy.js +26 -4
  14. package/node_modules/@aws-amplify/graphql-auth-transformer/CHANGELOG.md +4 -0
  15. package/node_modules/@aws-amplify/graphql-auth-transformer/package.json +11 -11
  16. package/node_modules/@aws-amplify/graphql-default-value-transformer/CHANGELOG.md +4 -0
  17. package/node_modules/@aws-amplify/graphql-default-value-transformer/package.json +6 -6
  18. package/node_modules/@aws-amplify/graphql-function-transformer/CHANGELOG.md +4 -0
  19. package/node_modules/@aws-amplify/graphql-function-transformer/LICENSE +201 -0
  20. package/node_modules/@aws-amplify/graphql-function-transformer/package.json +6 -5
  21. package/node_modules/@aws-amplify/graphql-http-transformer/CHANGELOG.md +4 -0
  22. package/node_modules/@aws-amplify/graphql-http-transformer/LICENSE +201 -0
  23. package/node_modules/@aws-amplify/graphql-http-transformer/package.json +6 -5
  24. package/node_modules/@aws-amplify/graphql-index-transformer/CHANGELOG.md +4 -0
  25. package/node_modules/@aws-amplify/graphql-index-transformer/package.json +6 -6
  26. package/node_modules/@aws-amplify/graphql-maps-to-transformer/CHANGELOG.md +4 -0
  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 +9 -9
  29. package/node_modules/@aws-amplify/graphql-model-transformer/CHANGELOG.md +6 -0
  30. package/node_modules/@aws-amplify/graphql-model-transformer/lib/rds-lambda.zip +0 -0
  31. package/node_modules/@aws-amplify/graphql-model-transformer/lib/rds-notification-lambda.zip +0 -0
  32. package/node_modules/@aws-amplify/graphql-model-transformer/lib/rds-patching-lambda.zip +0 -0
  33. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resolvers/rds/resolver.d.ts +5 -1
  34. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resolvers/rds/resolver.d.ts.map +1 -1
  35. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resolvers/rds/resolver.js +71 -26
  36. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resolvers/rds/resolver.js.map +1 -1
  37. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resources/rds-model-resource-generator.d.ts.map +1 -1
  38. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resources/rds-model-resource-generator.js +21 -7
  39. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resources/rds-model-resource-generator.js.map +1 -1
  40. package/node_modules/@aws-amplify/graphql-model-transformer/package.json +5 -5
  41. package/node_modules/@aws-amplify/graphql-predictions-transformer/CHANGELOG.md +4 -0
  42. package/node_modules/@aws-amplify/graphql-predictions-transformer/LICENSE +201 -0
  43. package/node_modules/@aws-amplify/graphql-predictions-transformer/lib/predictionsLambdaFunction.zip +0 -0
  44. package/node_modules/@aws-amplify/graphql-predictions-transformer/package.json +6 -5
  45. package/node_modules/@aws-amplify/graphql-relational-transformer/CHANGELOG.md +4 -0
  46. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/belongs-to/belongs-to-directive-ddb-fields-transformer.d.ts +12 -0
  47. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/belongs-to/belongs-to-directive-ddb-fields-transformer.d.ts.map +1 -0
  48. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/belongs-to/belongs-to-directive-ddb-fields-transformer.js +34 -0
  49. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/belongs-to/belongs-to-directive-ddb-fields-transformer.js.map +1 -0
  50. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/belongs-to/belongs-to-directive-sql-transformer.d.ts +12 -0
  51. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/belongs-to/belongs-to-directive-sql-transformer.d.ts.map +1 -0
  52. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/belongs-to/belongs-to-directive-sql-transformer.js +27 -0
  53. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/belongs-to/belongs-to-directive-sql-transformer.js.map +1 -0
  54. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/belongs-to/belongs-to-directive-transformer-factory.d.ts +5 -0
  55. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/belongs-to/belongs-to-directive-transformer-factory.d.ts.map +1 -0
  56. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/belongs-to/belongs-to-directive-transformer-factory.js +16 -0
  57. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/belongs-to/belongs-to-directive-transformer-factory.js.map +1 -0
  58. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/data-source-based-directive-transformer.d.ts +11 -0
  59. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/data-source-based-directive-transformer.d.ts.map +1 -0
  60. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/data-source-based-directive-transformer.js +3 -0
  61. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/data-source-based-directive-transformer.js.map +1 -0
  62. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/graphql-belongs-to-transformer.d.ts.map +1 -1
  63. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/graphql-belongs-to-transformer.js +9 -40
  64. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/graphql-belongs-to-transformer.js.map +1 -1
  65. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/graphql-has-many-transformer.d.ts.map +1 -1
  66. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/graphql-has-many-transformer.js +12 -35
  67. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/graphql-has-many-transformer.js.map +1 -1
  68. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/graphql-has-one-transformer.d.ts.map +1 -1
  69. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/graphql-has-one-transformer.js +8 -27
  70. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/graphql-has-one-transformer.js.map +1 -1
  71. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-many/has-many-directive-ddb-fields-transformer.d.ts +12 -0
  72. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-many/has-many-directive-ddb-fields-transformer.d.ts.map +1 -0
  73. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-many/has-many-directive-ddb-fields-transformer.js +32 -0
  74. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-many/has-many-directive-ddb-fields-transformer.js.map +1 -0
  75. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-many/has-many-directive-sql-transformer.d.ts +12 -0
  76. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-many/has-many-directive-sql-transformer.d.ts.map +1 -0
  77. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-many/has-many-directive-sql-transformer.js +27 -0
  78. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-many/has-many-directive-sql-transformer.js.map +1 -0
  79. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-many/has-many-directive-transformer-factory.d.ts +5 -0
  80. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-many/has-many-directive-transformer-factory.d.ts.map +1 -0
  81. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-many/has-many-directive-transformer-factory.js +16 -0
  82. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-many/has-many-directive-transformer-factory.js.map +1 -0
  83. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-one/has-one-directive-ddb-fields-transformer.d.ts +12 -0
  84. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-one/has-one-directive-ddb-fields-transformer.d.ts.map +1 -0
  85. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-one/has-one-directive-ddb-fields-transformer.js +31 -0
  86. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-one/has-one-directive-ddb-fields-transformer.js.map +1 -0
  87. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-one/has-one-directive-sql-transformer.d.ts +12 -0
  88. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-one/has-one-directive-sql-transformer.d.ts.map +1 -0
  89. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-one/has-one-directive-sql-transformer.js +27 -0
  90. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-one/has-one-directive-sql-transformer.js.map +1 -0
  91. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-one/has-one-directive-transformer-factory.d.ts +5 -0
  92. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-one/has-one-directive-transformer-factory.d.ts.map +1 -0
  93. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-one/has-one-directive-transformer-factory.js +16 -0
  94. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-one/has-one-directive-transformer-factory.js.map +1 -0
  95. package/node_modules/@aws-amplify/graphql-relational-transformer/package.json +7 -7
  96. package/node_modules/@aws-amplify/graphql-searchable-transformer/CHANGELOG.md +4 -0
  97. package/node_modules/@aws-amplify/graphql-searchable-transformer/lib/streaming-lambda.zip +0 -0
  98. package/node_modules/@aws-amplify/graphql-searchable-transformer/package.json +6 -6
  99. package/node_modules/@aws-amplify/graphql-sql-transformer/CHANGELOG.md +4 -0
  100. package/node_modules/@aws-amplify/graphql-sql-transformer/package.json +6 -6
  101. package/node_modules/@aws-amplify/graphql-transformer/CHANGELOG.md +6 -0
  102. package/node_modules/@aws-amplify/graphql-transformer/package.json +16 -16
  103. package/node_modules/@aws-amplify/graphql-transformer-core/API.md +3 -0
  104. package/node_modules/@aws-amplify/graphql-transformer-core/CHANGELOG.md +4 -0
  105. package/node_modules/@aws-amplify/graphql-transformer-core/LICENSE +201 -0
  106. package/node_modules/@aws-amplify/graphql-transformer-core/lib/index.d.ts +1 -1
  107. package/node_modules/@aws-amplify/graphql-transformer-core/lib/index.d.ts.map +1 -1
  108. package/node_modules/@aws-amplify/graphql-transformer-core/lib/index.js +3 -2
  109. package/node_modules/@aws-amplify/graphql-transformer-core/lib/index.js.map +1 -1
  110. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/model-datasource-strategy-utils.d.ts +1 -0
  111. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/model-datasource-strategy-utils.d.ts.map +1 -1
  112. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/model-datasource-strategy-utils.js +8 -1
  113. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/model-datasource-strategy-utils.js.map +1 -1
  114. package/node_modules/@aws-amplify/graphql-transformer-core/package.json +4 -3
  115. package/node_modules/@aws-amplify/graphql-transformer-interfaces/API.md +27 -1
  116. package/node_modules/@aws-amplify/graphql-transformer-interfaces/CHANGELOG.md +6 -0
  117. package/node_modules/@aws-amplify/graphql-transformer-interfaces/LICENSE +201 -0
  118. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/model-datasource/types.d.ts +12 -1
  119. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/model-datasource/types.d.ts.map +1 -1
  120. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/model-datasource/types.js +22 -0
  121. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/model-datasource/types.js.map +1 -1
  122. package/node_modules/@aws-amplify/graphql-transformer-interfaces/package.json +3 -2
  123. package/node_modules/@aws-amplify/graphql-transformer-interfaces/src/model-datasource/types.ts +76 -1
  124. package/node_modules/@aws-amplify/graphql-transformer-interfaces/tsconfig.tsbuildinfo +1 -1
  125. package/package.json +17 -17
  126. package/src/internal/codegen-assets.ts +15 -2
  127. package/src/internal/data-source-config.ts +42 -9
  128. package/src/model-datasource-strategy-types.ts +33 -1
  129. package/src/sql-model-datasource-strategy.ts +32 -1
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aws-amplify/graphql-api-construct",
3
- "version": "1.6.0",
3
+ "version": "1.7.0-cors-rule.0",
4
4
  "description": "AppSync GraphQL Api Construct using Amplify GraphQL Transformer.",
5
5
  "repository": {
6
6
  "type": "git",
@@ -75,20 +75,20 @@
75
75
  "dependencies": {
76
76
  "@aws-amplify/backend-output-schemas": "^0.4.0",
77
77
  "@aws-amplify/backend-output-storage": "^0.2.2",
78
- "@aws-amplify/graphql-auth-transformer": "3.4.1",
79
- "@aws-amplify/graphql-default-value-transformer": "2.3.1",
80
- "@aws-amplify/graphql-function-transformer": "2.1.18",
81
- "@aws-amplify/graphql-http-transformer": "2.1.18",
82
- "@aws-amplify/graphql-index-transformer": "2.3.7",
83
- "@aws-amplify/graphql-maps-to-transformer": "3.4.8",
84
- "@aws-amplify/graphql-model-transformer": "2.6.0",
85
- "@aws-amplify/graphql-predictions-transformer": "2.1.18",
86
- "@aws-amplify/graphql-relational-transformer": "2.4.1",
87
- "@aws-amplify/graphql-searchable-transformer": "2.6.1",
88
- "@aws-amplify/graphql-sql-transformer": "0.2.7",
89
- "@aws-amplify/graphql-transformer": "1.3.12",
90
- "@aws-amplify/graphql-transformer-core": "2.5.0",
91
- "@aws-amplify/graphql-transformer-interfaces": "3.4.0",
78
+ "@aws-amplify/graphql-auth-transformer": "3.4.2-cors-rule.0",
79
+ "@aws-amplify/graphql-default-value-transformer": "2.3.2-cors-rule.0",
80
+ "@aws-amplify/graphql-function-transformer": "2.1.19-cors-rule.0",
81
+ "@aws-amplify/graphql-http-transformer": "2.1.19-cors-rule.0",
82
+ "@aws-amplify/graphql-index-transformer": "2.3.8-cors-rule.0",
83
+ "@aws-amplify/graphql-maps-to-transformer": "3.4.9-cors-rule.0",
84
+ "@aws-amplify/graphql-model-transformer": "2.7.0-cors-rule.0",
85
+ "@aws-amplify/graphql-predictions-transformer": "2.1.19-cors-rule.0",
86
+ "@aws-amplify/graphql-relational-transformer": "2.4.2-cors-rule.0",
87
+ "@aws-amplify/graphql-searchable-transformer": "2.6.2-cors-rule.0",
88
+ "@aws-amplify/graphql-sql-transformer": "0.2.8-cors-rule.0",
89
+ "@aws-amplify/graphql-transformer": "1.4.0-cors-rule.0",
90
+ "@aws-amplify/graphql-transformer-core": "2.5.1-cors-rule.0",
91
+ "@aws-amplify/graphql-transformer-interfaces": "3.5.0-cors-rule.0",
92
92
  "@aws-amplify/platform-core": "^0.2.0",
93
93
  "@aws-amplify/plugin-types": "^0.4.1",
94
94
  "charenc": "^0.0.2",
@@ -112,7 +112,7 @@
112
112
  "zod": "^3.22.3"
113
113
  },
114
114
  "devDependencies": {
115
- "@aws-amplify/graphql-transformer-test-utils": "0.4.6",
115
+ "@aws-amplify/graphql-transformer-test-utils": "0.4.7-cors-rule.0",
116
116
  "@types/fs-extra": "^8.0.1",
117
117
  "@types/node": "^12.12.6",
118
118
  "aws-cdk-lib": "2.80.0",
@@ -177,5 +177,5 @@
177
177
  "/__tests__/"
178
178
  ]
179
179
  },
180
- "gitHead": "9a0fb53d5df94e76811cbbdc4f3fc98fc6278c41"
180
+ "gitHead": "8a673ad53fc3116a79c6ce1d52a1113eb0160e9b"
181
181
  }
@@ -1,5 +1,5 @@
1
- import { RemovalPolicy } from 'aws-cdk-lib';
2
- import { Bucket, IBucket } from 'aws-cdk-lib/aws-s3';
1
+ import { RemovalPolicy, Fn } from 'aws-cdk-lib';
2
+ import { Bucket, HttpMethods, IBucket } from 'aws-cdk-lib/aws-s3';
3
3
  import { BucketDeployment, Source } from 'aws-cdk-lib/aws-s3-deployment';
4
4
  import { Construct } from 'constructs';
5
5
 
@@ -8,6 +8,11 @@ export type CodegenAssetsProps = {
8
8
  };
9
9
 
10
10
  const MODEL_SCHEMA_KEY = 'model-schema.graphql';
11
+ const CONSOLE_SERVICE_ENDPOINT = Fn.join('', [
12
+ 'https://',
13
+ Fn.ref('AWS::Region'),
14
+ '.console.aws.amazon.com/amplify',
15
+ ]);
11
16
 
12
17
  /**
13
18
  * Construct an S3 URI string for a given bucket and key.
@@ -30,6 +35,14 @@ export class CodegenAssets extends Construct {
30
35
  const bucket = new Bucket(this, `${id}Bucket`, {
31
36
  removalPolicy: RemovalPolicy.DESTROY,
32
37
  autoDeleteObjects: true,
38
+ // Enabling CORS to allow console to access the codegen assets.
39
+ cors: [
40
+ {
41
+ allowedMethods: [HttpMethods.GET, HttpMethods.HEAD],
42
+ allowedHeaders: ['*'],
43
+ allowedOrigins: [CONSOLE_SERVICE_ENDPOINT],
44
+ },
45
+ ],
33
46
  });
34
47
 
35
48
  const deployment = new BucketDeployment(this, `${id}Deployment`, {
@@ -6,7 +6,12 @@ import {
6
6
  isMutationNode,
7
7
  fieldsWithSqlDirective,
8
8
  } from '@aws-amplify/graphql-transformer-core';
9
- import { DataSourceStrategiesProvider } from '@aws-amplify/graphql-transformer-interfaces';
9
+ import {
10
+ DataSourceStrategiesProvider,
11
+ isSqlModelDataSourceSsmDbConnectionConfig,
12
+ isSqlModelDataSourceSecretsManagerDbConnectionConfig,
13
+ } from '@aws-amplify/graphql-transformer-interfaces';
14
+ import { Token, Arn, ArnFormat } from 'aws-cdk-lib';
10
15
  import {
11
16
  CustomSqlDataSourceStrategy as ConstructCustomSqlDataSourceStrategy,
12
17
  ModelDataSourceStrategy as ConstructModelDataSourceStrategy,
@@ -184,19 +189,47 @@ export const schemaByMergingDefinitions = (definitions: IAmplifyGraphqlDefinitio
184
189
  * @param strategy user provided model data source strategy
185
190
  * @returns validates and throws an error if the strategy is invalid
186
191
  */
187
- export const validateDataSourceStrategy = (strategy: ConstructModelDataSourceStrategy) => {
192
+ export const validateDataSourceStrategy = (strategy: ConstructModelDataSourceStrategy): void => {
188
193
  if (!isSqlStrategy(strategy)) {
189
194
  return;
190
195
  }
191
196
 
192
197
  const dbConnectionConfig = strategy.dbConnectionConfig;
193
- const invalidSSMPaths = Object.values(dbConnectionConfig).filter((value) => typeof value === 'string' && !isValidSSMPath(value));
194
- if (invalidSSMPaths.length > 0) {
195
- throw new Error(
196
- `Invalid data source strategy "${
197
- strategy.name
198
- }". Following SSM paths must start with '/' in dbConnectionConfig: ${invalidSSMPaths.join(', ')}.`,
199
- );
198
+ if (isSqlModelDataSourceSsmDbConnectionConfig(dbConnectionConfig)) {
199
+ const invalidSSMPaths = Object.values(dbConnectionConfig).filter((value) => typeof value === 'string' && !isValidSSMPath(value));
200
+ if (invalidSSMPaths.length > 0) {
201
+ throw new Error(
202
+ `Invalid data source strategy "${
203
+ strategy.name
204
+ }". Following SSM paths must start with '/' in dbConnectionConfig: ${invalidSSMPaths.join(', ')}.`,
205
+ );
206
+ }
207
+ } else if (isSqlModelDataSourceSecretsManagerDbConnectionConfig(dbConnectionConfig)) {
208
+ if (!Token.isUnresolved(dbConnectionConfig.secretArn)) {
209
+ try {
210
+ const arnComponents = Arn.split(dbConnectionConfig.secretArn, ArnFormat.COLON_RESOURCE_NAME);
211
+ if (arnComponents.service !== 'secretsmanager' || arnComponents.resource !== 'secret') {
212
+ // error message does not matter because it inside try/catch
213
+ throw new Error();
214
+ }
215
+ } catch {
216
+ throw new Error(`Invalid data source strategy "${strategy.name}". The value of secretArn is not a valid Secrets Manager ARN.`);
217
+ }
218
+ }
219
+
220
+ if (dbConnectionConfig.keyArn && !Token.isUnresolved(dbConnectionConfig.keyArn)) {
221
+ try {
222
+ const arnComponents = Arn.split(dbConnectionConfig.keyArn, ArnFormat.SLASH_RESOURCE_NAME);
223
+ if (arnComponents.service !== 'kms' || arnComponents.resource !== 'key') {
224
+ // error message does not matter because it inside try/catch
225
+ throw new Error();
226
+ }
227
+ } catch {
228
+ throw new Error(`Invalid data source strategy "${strategy.name}". The value of keyArn is not a valid KMS ARN.`);
229
+ }
230
+ }
231
+ } else {
232
+ throw new Error(`Invalid data source strategy "${strategy.name}". dbConnectionConfig does not include SSM paths or Secret ARN.`);
200
233
  }
201
234
  };
202
235
 
@@ -116,12 +116,44 @@ export interface SubnetAvailabilityZone {
116
116
  readonly availabilityZone: string;
117
117
  }
118
118
 
119
+ /**
120
+ * The credentials the lambda data source will use to connect to the database.
121
+ *
122
+ * @experimental
123
+ */
124
+ export type SqlModelDataSourceDbConnectionConfig =
125
+ | SqlModelDataSourceSecretsManagerDbConnectionConfig
126
+ | SqlModelDataSourceSsmDbConnectionConfig;
127
+
128
+ /**
129
+ * The credentials stored in Secrets Manager that the lambda data source will use to connect to the database.
130
+ *
131
+ * The managed secret should be in the same region as the lambda.
132
+ * @experimental
133
+ */
134
+ export interface SqlModelDataSourceSecretsManagerDbConnectionConfig {
135
+ /** The ARN of the managed secret with username, password, and hostname to use when connecting to the database. **/
136
+ readonly secretArn: string;
137
+
138
+ /** 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. **/
139
+ readonly keyArn?: string;
140
+
141
+ /** The port number of the database proxy, cluster, or instance. */
142
+ readonly port: number;
143
+
144
+ /** The database name. */
145
+ readonly databaseName: string;
146
+
147
+ /** The hostame of the database. */
148
+ readonly hostname: string;
149
+ }
150
+
119
151
  /**
120
152
  * The Secure Systems Manager parameter paths the Lambda data source will use to connect to the database.
121
153
  *
122
154
  * These parameters are retrieved from Secure Systems Manager in the same region as the Lambda.
123
155
  */
124
- export interface SqlModelDataSourceDbConnectionConfig {
156
+ export interface SqlModelDataSourceSsmDbConnectionConfig {
125
157
  /** The Secure Systems Manager parameter containing the hostname of the database. For RDS-based SQL data sources, this can be the hostname
126
158
  * of a database proxy, cluster, or instance.
127
159
  */
@@ -1,7 +1,12 @@
1
1
  import * as fs from 'fs';
2
2
  import * as path from 'path';
3
3
  import { isSqlDbType } from '@aws-amplify/graphql-transformer-core';
4
- import { SQLLambdaModelDataSourceStrategy, SqlModelDataSourceDbConnectionConfig } from './model-datasource-strategy-types';
4
+ import {
5
+ SQLLambdaModelDataSourceStrategy,
6
+ SqlModelDataSourceDbConnectionConfig,
7
+ SqlModelDataSourceSsmDbConnectionConfig,
8
+ SqlModelDataSourceSecretsManagerDbConnectionConfig,
9
+ } from './model-datasource-strategy-types';
5
10
 
6
11
  /**
7
12
  * Type predicate that returns true if the object is a SQLLambdaModelDataSourceStrategy.
@@ -24,6 +29,15 @@ export const isSQLLambdaModelDataSourceStrategy = (obj: any): obj is SQLLambdaMo
24
29
  * @returns true if the object is shaped like a SqlModelDataSourceDbConnectionConfig
25
30
  */
26
31
  export const isSqlModelDataSourceDbConnectionConfig = (obj: any): obj is SqlModelDataSourceDbConnectionConfig => {
32
+ return isSqlModelDataSourceSsmDbConnectionConfig(obj) || isSqlModelDataSourceSecretsManagerDbConnectionConfig(obj);
33
+ };
34
+
35
+ /**
36
+ * Type predicate that returns true if the object is a SqlModelDataSourceSsmDbConnectionConfig.
37
+ * @param obj the object to inspect
38
+ * @returns true if the object is shaped like a SqlModelDataSourceSsmDbConnectionConfig
39
+ */
40
+ export const isSqlModelDataSourceSsmDbConnectionConfig = (obj: any): obj is SqlModelDataSourceSsmDbConnectionConfig => {
27
41
  return (
28
42
  (typeof obj === 'object' || typeof obj === 'function') &&
29
43
  typeof obj.hostnameSsmPath === 'string' &&
@@ -34,6 +48,23 @@ export const isSqlModelDataSourceDbConnectionConfig = (obj: any): obj is SqlMode
34
48
  );
35
49
  };
36
50
 
51
+ /**
52
+ * Type predicate that returns true if the object is a SqlModelDataSourceSecretsManagerDbConnectionConfig.
53
+ * @param obj the object to inspect
54
+ * @returns true if the object is shaped like a SqlModelDataSourceSecretsManagerDbConnectionConfig
55
+ */
56
+ export const isSqlModelDataSourceSecretsManagerDbConnectionConfig = (
57
+ obj: any,
58
+ ): obj is SqlModelDataSourceSecretsManagerDbConnectionConfig => {
59
+ return (
60
+ (typeof obj === 'object' || typeof obj === 'function') &&
61
+ typeof obj.secretArn === 'string' &&
62
+ typeof obj.port === 'number' &&
63
+ typeof obj.databaseName === 'string' &&
64
+ typeof obj.hostname == 'string'
65
+ );
66
+ };
67
+
37
68
  /**
38
69
  * Class exposing utilities to produce SQLLambdaModelDataSourceStrategy objects given various inputs.
39
70
  */