@aws-amplify/graphql-api-construct 1.9.0-gen2-release-0418-2.0 → 1.9.0-gen2-release-0423.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (157) hide show
  1. package/.jsii +72 -58
  2. package/API.md +1 -1
  3. package/CHANGELOG.md +3 -1
  4. package/README.md +156 -24
  5. package/lib/amplify-dynamodb-table-wrapper.js +1 -1
  6. package/lib/amplify-graphql-api.js +7 -10
  7. package/lib/amplify-graphql-definition.js +1 -1
  8. package/lib/internal/asset-provider.d.ts +26 -0
  9. package/lib/internal/asset-provider.js +58 -0
  10. package/lib/internal/data-source-config.js +12 -2
  11. package/lib/internal/index.d.ts +1 -1
  12. package/lib/internal/index.js +2 -2
  13. package/lib/model-datasource-strategy-types.d.ts +7 -2
  14. package/lib/model-datasource-strategy-types.js +1 -1
  15. package/lib/sql-model-datasource-strategy.js +4 -3
  16. package/node_modules/@aws-amplify/graphql-auth-transformer/CHANGELOG.md +5 -1
  17. package/node_modules/@aws-amplify/graphql-auth-transformer/package.json +13 -13
  18. package/node_modules/@aws-amplify/graphql-default-value-transformer/CHANGELOG.md +1 -1
  19. package/node_modules/@aws-amplify/graphql-default-value-transformer/package.json +8 -8
  20. package/node_modules/@aws-amplify/graphql-directives/CHANGELOG.md +1 -1
  21. package/node_modules/@aws-amplify/graphql-directives/package.json +2 -2
  22. package/node_modules/@aws-amplify/graphql-function-transformer/CHANGELOG.md +1 -1
  23. package/node_modules/@aws-amplify/graphql-function-transformer/package.json +7 -7
  24. package/node_modules/@aws-amplify/graphql-http-transformer/CHANGELOG.md +1 -1
  25. package/node_modules/@aws-amplify/graphql-http-transformer/package.json +7 -7
  26. package/node_modules/@aws-amplify/graphql-index-transformer/CHANGELOG.md +2 -1
  27. package/node_modules/@aws-amplify/graphql-index-transformer/lib/schema.js +8 -3
  28. package/node_modules/@aws-amplify/graphql-index-transformer/lib/schema.js.map +1 -1
  29. package/node_modules/@aws-amplify/graphql-index-transformer/package.json +8 -8
  30. package/node_modules/@aws-amplify/graphql-maps-to-transformer/CHANGELOG.md +1 -1
  31. package/node_modules/@aws-amplify/graphql-maps-to-transformer/lib/assets/mapping-lambda.zip +0 -0
  32. package/node_modules/@aws-amplify/graphql-maps-to-transformer/package.json +11 -11
  33. package/node_modules/@aws-amplify/graphql-model-transformer/CHANGELOG.md +2 -1
  34. package/node_modules/@aws-amplify/graphql-model-transformer/lib/rds-lambda.zip +0 -0
  35. package/node_modules/@aws-amplify/graphql-model-transformer/lib/rds-notification-lambda.zip +0 -0
  36. package/node_modules/@aws-amplify/graphql-model-transformer/lib/rds-patching-lambda.zip +0 -0
  37. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resolvers/rds/resolver.d.ts.map +1 -1
  38. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resolvers/rds/resolver.js +4 -1
  39. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resolvers/rds/resolver.js.map +1 -1
  40. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resources/rds-model-resource-generator.js +1 -1
  41. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resources/rds-model-resource-generator.js.map +1 -1
  42. package/node_modules/@aws-amplify/graphql-model-transformer/package.json +7 -7
  43. package/node_modules/@aws-amplify/graphql-predictions-transformer/CHANGELOG.md +1 -1
  44. package/node_modules/@aws-amplify/graphql-predictions-transformer/lib/predictionsLambdaFunction.zip +0 -0
  45. package/node_modules/@aws-amplify/graphql-predictions-transformer/package.json +7 -7
  46. package/node_modules/@aws-amplify/graphql-relational-transformer/CHANGELOG.md +2 -1
  47. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/belongs-to/belongs-to-directive-ddb-references-transformer.d.ts.map +1 -1
  48. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/belongs-to/belongs-to-directive-ddb-references-transformer.js +1 -0
  49. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/belongs-to/belongs-to-directive-ddb-references-transformer.js.map +1 -1
  50. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/belongs-to/belongs-to-directive-sql-transformer.d.ts.map +1 -1
  51. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/belongs-to/belongs-to-directive-sql-transformer.js +1 -0
  52. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/belongs-to/belongs-to-directive-sql-transformer.js.map +1 -1
  53. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/belongs-to/belongs-to-directive-transformer-factory.d.ts.map +1 -1
  54. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/belongs-to/belongs-to-directive-transformer-factory.js +2 -1
  55. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/belongs-to/belongs-to-directive-transformer-factory.js.map +1 -1
  56. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/graphql-has-many-transformer.d.ts.map +1 -1
  57. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/graphql-has-many-transformer.js +11 -4
  58. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/graphql-has-many-transformer.js.map +1 -1
  59. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/graphql-has-one-transformer.d.ts.map +1 -1
  60. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/graphql-has-one-transformer.js +8 -1
  61. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/graphql-has-one-transformer.js.map +1 -1
  62. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-many/has-many-directive-ddb-references-transformer.d.ts.map +1 -1
  63. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-many/has-many-directive-ddb-references-transformer.js +2 -1
  64. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-many/has-many-directive-ddb-references-transformer.js.map +1 -1
  65. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-many/has-many-directive-sql-transformer.d.ts.map +1 -1
  66. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-many/has-many-directive-sql-transformer.js +2 -1
  67. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-many/has-many-directive-sql-transformer.js.map +1 -1
  68. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-many/has-many-directive-transformer-factory.d.ts.map +1 -1
  69. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-many/has-many-directive-transformer-factory.js +3 -2
  70. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-many/has-many-directive-transformer-factory.js.map +1 -1
  71. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-one/has-one-directive-ddb-references-transformer.d.ts.map +1 -1
  72. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-one/has-one-directive-ddb-references-transformer.js +2 -1
  73. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-one/has-one-directive-ddb-references-transformer.js.map +1 -1
  74. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-one/has-one-directive-sql-transformer.d.ts.map +1 -1
  75. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-one/has-one-directive-sql-transformer.js +2 -1
  76. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-one/has-one-directive-sql-transformer.js.map +1 -1
  77. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-one/has-one-directive-transformer-factory.d.ts.map +1 -1
  78. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-one/has-one-directive-transformer-factory.js +2 -1
  79. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/has-one/has-one-directive-transformer-factory.js.map +1 -1
  80. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/resolver/ddb-references-generator.d.ts.map +1 -1
  81. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/resolver/ddb-references-generator.js +2 -2
  82. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/resolver/ddb-references-generator.js.map +1 -1
  83. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/resolvers.d.ts.map +1 -1
  84. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/resolvers.js +5 -3
  85. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/resolvers.js.map +1 -1
  86. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/types.d.ts +1 -0
  87. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/types.d.ts.map +1 -1
  88. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/utils.d.ts +2 -2
  89. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/utils.d.ts.map +1 -1
  90. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/utils.js +101 -8
  91. package/node_modules/@aws-amplify/graphql-relational-transformer/lib/utils.js.map +1 -1
  92. package/node_modules/@aws-amplify/graphql-relational-transformer/package.json +9 -9
  93. package/node_modules/@aws-amplify/graphql-searchable-transformer/CHANGELOG.md +1 -1
  94. package/node_modules/@aws-amplify/graphql-searchable-transformer/lib/streaming-lambda.zip +0 -0
  95. package/node_modules/@aws-amplify/graphql-searchable-transformer/package.json +8 -8
  96. package/node_modules/@aws-amplify/graphql-sql-transformer/CHANGELOG.md +1 -1
  97. package/node_modules/@aws-amplify/graphql-sql-transformer/package.json +8 -8
  98. package/node_modules/@aws-amplify/graphql-transformer/CHANGELOG.md +1 -1
  99. package/node_modules/@aws-amplify/graphql-transformer/package.json +15 -15
  100. package/node_modules/@aws-amplify/graphql-transformer-core/API.md +1 -1
  101. package/node_modules/@aws-amplify/graphql-transformer-core/CHANGELOG.md +4 -2
  102. package/node_modules/@aws-amplify/graphql-transformer-core/lib/appsync-function.js +2 -2
  103. package/node_modules/@aws-amplify/graphql-transformer-core/lib/appsync-function.js.map +1 -1
  104. package/node_modules/@aws-amplify/graphql-transformer-core/lib/cdk-compat/schema-asset.d.ts.map +1 -1
  105. package/node_modules/@aws-amplify/graphql-transformer-core/lib/cdk-compat/schema-asset.js +1 -2
  106. package/node_modules/@aws-amplify/graphql-transformer-core/lib/cdk-compat/schema-asset.js.map +1 -1
  107. package/node_modules/@aws-amplify/graphql-transformer-core/lib/cdk-compat/template-asset.d.ts +3 -3
  108. package/node_modules/@aws-amplify/graphql-transformer-core/lib/cdk-compat/template-asset.d.ts.map +1 -1
  109. package/node_modules/@aws-amplify/graphql-transformer-core/lib/cdk-compat/template-asset.js +4 -5
  110. package/node_modules/@aws-amplify/graphql-transformer-core/lib/cdk-compat/template-asset.js.map +1 -1
  111. package/node_modules/@aws-amplify/graphql-transformer-core/lib/graphql-api.d.ts +3 -1
  112. package/node_modules/@aws-amplify/graphql-transformer-core/lib/graphql-api.d.ts.map +1 -1
  113. package/node_modules/@aws-amplify/graphql-transformer-core/lib/graphql-api.js +1 -0
  114. package/node_modules/@aws-amplify/graphql-transformer-core/lib/graphql-api.js.map +1 -1
  115. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transform-host.js +5 -5
  116. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transform-host.js.map +1 -1
  117. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformation/transform.d.ts +1 -1
  118. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformation/transform.d.ts.map +1 -1
  119. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformation/transform.js +3 -2
  120. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformation/transform.js.map +1 -1
  121. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformer-context/index.d.ts +1 -0
  122. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformer-context/index.d.ts.map +1 -1
  123. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformer-context/index.js +1 -2
  124. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformer-context/index.js.map +1 -1
  125. package/node_modules/@aws-amplify/graphql-transformer-core/package.json +5 -5
  126. package/node_modules/@aws-amplify/graphql-transformer-interfaces/API.md +9 -6
  127. package/node_modules/@aws-amplify/graphql-transformer-interfaces/CHANGELOG.md +3 -1
  128. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/asset-provider.d.ts +2 -2
  129. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/asset-provider.d.ts.map +1 -1
  130. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/graphql-api-provider.d.ts +4 -2
  131. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/graphql-api-provider.d.ts.map +1 -1
  132. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/graphql-api-provider.js.map +1 -1
  133. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/model-datasource/types.d.ts +1 -1
  134. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/model-datasource/types.d.ts.map +1 -1
  135. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/model-datasource/types.js +2 -1
  136. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/model-datasource/types.js.map +1 -1
  137. package/node_modules/@aws-amplify/graphql-transformer-interfaces/package.json +2 -2
  138. package/node_modules/@aws-amplify/graphql-transformer-interfaces/src/asset-provider.ts +2 -2
  139. package/node_modules/@aws-amplify/graphql-transformer-interfaces/src/graphql-api-provider.ts +4 -2
  140. package/node_modules/@aws-amplify/graphql-transformer-interfaces/src/model-datasource/types.ts +5 -2
  141. package/node_modules/@aws-amplify/graphql-transformer-interfaces/tsconfig.tsbuildinfo +1 -1
  142. package/node_modules/graphql-transformer-common/CHANGELOG.md +1 -1
  143. package/node_modules/graphql-transformer-common/package.json +2 -2
  144. package/package.json +19 -19
  145. package/src/amplify-graphql-api.ts +6 -11
  146. package/src/internal/asset-provider.ts +64 -0
  147. package/src/internal/data-source-config.ts +12 -1
  148. package/src/internal/index.ts +1 -1
  149. package/src/model-datasource-strategy-types.ts +7 -2
  150. package/src/sql-model-datasource-strategy.ts +4 -1
  151. package/lib/internal/asset-manager.d.ts +0 -12
  152. package/lib/internal/asset-manager.js +0 -44
  153. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformer-context/asset-manager.d.ts +0 -10
  154. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformer-context/asset-manager.d.ts.map +0 -1
  155. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformer-context/asset-manager.js +0 -20
  156. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformer-context/asset-manager.js.map +0 -1
  157. package/src/internal/asset-manager.ts +0 -43
@@ -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.9.0-gen2-release-0418-2.0" };
104
+ AmplifyGraphqlDefinition[_a] = { fqn: "@aws-amplify/graphql-api-construct.AmplifyGraphqlDefinition", version: "1.9.0-gen2-release-0423.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"]}
@@ -0,0 +1,26 @@
1
+ import { Construct } from 'constructs';
2
+ import { AssetProps, S3Asset, AssetProvider as AssetProviderInterface } from '@aws-amplify/graphql-transformer-interfaces';
3
+ /**
4
+ * The asset provider bridges the gap between creation of file assets in the transformer (which provide a name+contents tuple)
5
+ * with the path method which is used in CDK.
6
+ * The CDK S3 asset require the contents to be written to the file system first.
7
+ * The asset provider writes to a temporary directory before creating the CDK S3 asset.
8
+ *
9
+ */
10
+ export declare class AssetProvider implements AssetProviderInterface {
11
+ private readonly tempAssetDir;
12
+ readonly resolverAssets: Record<string, string>;
13
+ constructor(scope: Construct);
14
+ /**
15
+ * Creates a new CDK S3 asset. The file contents in assetProps is first stored in a temporary file that is referenced by the CDK S3 asset.
16
+ * @param assetScope the parent of the asset
17
+ * @param assetId unique ID for CDK S3 asset
18
+ * @param assetProps name and contents of file to be added to CDK S3 asset
19
+ * @returns the CDK S3 asset
20
+ */
21
+ provide(assetScope: Construct, assetId: string, assetProps: AssetProps): S3Asset;
22
+ private addAsset;
23
+ private isContentsAReference;
24
+ private dereferenceContents;
25
+ private trackResolverAsset;
26
+ }
@@ -0,0 +1,58 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AssetProvider = void 0;
4
+ const fs = require("fs");
5
+ const path = require("path");
6
+ const cdk = require("aws-cdk-lib");
7
+ const aws_s3_assets_1 = require("aws-cdk-lib/aws-s3-assets");
8
+ const TEMP_PREFIX = 'transformer-assets';
9
+ const FUNCTION_PREFIX = 'functions';
10
+ const RESOLVER_PREFIX = 'resolvers';
11
+ /**
12
+ * The asset provider bridges the gap between creation of file assets in the transformer (which provide a name+contents tuple)
13
+ * with the path method which is used in CDK.
14
+ * The CDK S3 asset require the contents to be written to the file system first.
15
+ * The asset provider writes to a temporary directory before creating the CDK S3 asset.
16
+ *
17
+ */
18
+ class AssetProvider {
19
+ constructor(scope) {
20
+ this.resolverAssets = {};
21
+ this.tempAssetDir = cdk.FileSystem.mkdtemp(`${TEMP_PREFIX}-${scope.node.addr}`);
22
+ }
23
+ /**
24
+ * Creates a new CDK S3 asset. The file contents in assetProps is first stored in a temporary file that is referenced by the CDK S3 asset.
25
+ * @param assetScope the parent of the asset
26
+ * @param assetId unique ID for CDK S3 asset
27
+ * @param assetProps name and contents of file to be added to CDK S3 asset
28
+ * @returns the CDK S3 asset
29
+ */
30
+ provide(assetScope, assetId, assetProps) {
31
+ return new aws_s3_assets_1.Asset(assetScope, assetId, { path: this.addAsset(assetProps.fileName, assetProps.fileContent) });
32
+ }
33
+ addAsset(fileName, contents) {
34
+ this.trackResolverAsset(fileName, contents);
35
+ const writableContents = this.isContentsAReference(fileName) ? this.dereferenceContents(contents) : contents;
36
+ const filePath = path.join(this.tempAssetDir, fileName);
37
+ const fileDirName = path.dirname(filePath);
38
+ if (!fs.existsSync(fileDirName)) {
39
+ fs.mkdirSync(fileDirName, { recursive: true });
40
+ }
41
+ fs.writeFileSync(filePath, writableContents);
42
+ return filePath;
43
+ }
44
+ isContentsAReference(fileName) {
45
+ return fileName.startsWith(FUNCTION_PREFIX);
46
+ }
47
+ dereferenceContents(contents) {
48
+ return fs.readFileSync(contents);
49
+ }
50
+ trackResolverAsset(fileName, contents) {
51
+ if (fileName.startsWith(RESOLVER_PREFIX)) {
52
+ const resolverFileName = fileName.split('/')[1];
53
+ this.resolverAssets[resolverFileName] = contents;
54
+ }
55
+ }
56
+ }
57
+ exports.AssetProvider = AssetProvider;
58
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzZXQtcHJvdmlkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW50ZXJuYWwvYXNzZXQtcHJvdmlkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEseUJBQXlCO0FBQ3pCLDZCQUE2QjtBQUU3QixtQ0FBbUM7QUFDbkMsNkRBQWtEO0FBR2xELE1BQU0sV0FBVyxHQUFHLG9CQUFvQixDQUFDO0FBQ3pDLE1BQU0sZUFBZSxHQUFHLFdBQVcsQ0FBQztBQUNwQyxNQUFNLGVBQWUsR0FBRyxXQUFXLENBQUM7QUFFcEM7Ozs7OztHQU1HO0FBQ0gsTUFBYSxhQUFhO0lBSXhCLFlBQVksS0FBZ0I7UUFGWixtQkFBYyxHQUEyQixFQUFFLENBQUM7UUFHMUQsSUFBSSxDQUFDLFlBQVksR0FBRyxHQUFHLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxHQUFHLFdBQVcsSUFBSSxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDLENBQUM7SUFDbEYsQ0FBQztJQUVEOzs7Ozs7T0FNRztJQUNJLE9BQU8sQ0FBQyxVQUFxQixFQUFFLE9BQWUsRUFBRSxVQUFzQjtRQUMzRSxPQUFPLElBQUkscUJBQUssQ0FBQyxVQUFVLEVBQUUsT0FBTyxFQUFFLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxRQUFRLENBQUMsVUFBVSxDQUFDLFFBQVEsRUFBRSxVQUFVLENBQUMsV0FBVyxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQzlHLENBQUM7SUFFTyxRQUFRLENBQUMsUUFBZ0IsRUFBRSxRQUFnQjtRQUNqRCxJQUFJLENBQUMsa0JBQWtCLENBQUMsUUFBUSxFQUFFLFFBQVEsQ0FBQyxDQUFDO1FBQzVDLE1BQU0sZ0JBQWdCLEdBQUcsSUFBSSxDQUFDLG9CQUFvQixDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsbUJBQW1CLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQztRQUM3RyxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxZQUFZLEVBQUUsUUFBUSxDQUFDLENBQUM7UUFDeEQsTUFBTSxXQUFXLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUMzQyxJQUFJLENBQUMsRUFBRSxDQUFDLFVBQVUsQ0FBQyxXQUFXLENBQUMsRUFBRTtZQUMvQixFQUFFLENBQUMsU0FBUyxDQUFDLFdBQVcsRUFBRSxFQUFFLFNBQVMsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO1NBQ2hEO1FBQ0QsRUFBRSxDQUFDLGFBQWEsQ0FBQyxRQUFRLEVBQUUsZ0JBQWdCLENBQUMsQ0FBQztRQUM3QyxPQUFPLFFBQVEsQ0FBQztJQUNsQixDQUFDO0lBRU8sb0JBQW9CLENBQUMsUUFBZ0I7UUFDM0MsT0FBTyxRQUFRLENBQUMsVUFBVSxDQUFDLGVBQWUsQ0FBQyxDQUFDO0lBQzlDLENBQUM7SUFFTyxtQkFBbUIsQ0FBQyxRQUFnQjtRQUMxQyxPQUFPLEVBQUUsQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDbkMsQ0FBQztJQUVPLGtCQUFrQixDQUFDLFFBQWdCLEVBQUUsUUFBZ0I7UUFDM0QsSUFBSSxRQUFRLENBQUMsVUFBVSxDQUFDLGVBQWUsQ0FBQyxFQUFFO1lBQ3hDLE1BQU0sZ0JBQWdCLEdBQUcsUUFBUSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNoRCxJQUFJLENBQUMsY0FBYyxDQUFDLGdCQUFnQixDQUFDLEdBQUcsUUFBUSxDQUFDO1NBQ2xEO0lBQ0gsQ0FBQztDQUNGO0FBN0NELHNDQTZDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGZzIGZyb20gJ2ZzJztcbmltcG9ydCAqIGFzIHBhdGggZnJvbSAncGF0aCc7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcbmltcG9ydCAqIGFzIGNkayBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgeyBBc3NldCB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1zMy1hc3NldHMnO1xuaW1wb3J0IHsgQXNzZXRQcm9wcywgUzNBc3NldCwgQXNzZXRQcm92aWRlciBhcyBBc3NldFByb3ZpZGVySW50ZXJmYWNlIH0gZnJvbSAnQGF3cy1hbXBsaWZ5L2dyYXBocWwtdHJhbnNmb3JtZXItaW50ZXJmYWNlcyc7XG5cbmNvbnN0IFRFTVBfUFJFRklYID0gJ3RyYW5zZm9ybWVyLWFzc2V0cyc7XG5jb25zdCBGVU5DVElPTl9QUkVGSVggPSAnZnVuY3Rpb25zJztcbmNvbnN0IFJFU09MVkVSX1BSRUZJWCA9ICdyZXNvbHZlcnMnO1xuXG4vKipcbiAqIFRoZSBhc3NldCBwcm92aWRlciBicmlkZ2VzIHRoZSBnYXAgYmV0d2VlbiBjcmVhdGlvbiBvZiBmaWxlIGFzc2V0cyBpbiB0aGUgdHJhbnNmb3JtZXIgKHdoaWNoIHByb3ZpZGUgYSBuYW1lK2NvbnRlbnRzIHR1cGxlKVxuICogd2l0aCB0aGUgcGF0aCBtZXRob2Qgd2hpY2ggaXMgdXNlZCBpbiBDREsuXG4gKiBUaGUgQ0RLIFMzIGFzc2V0IHJlcXVpcmUgdGhlIGNvbnRlbnRzIHRvIGJlIHdyaXR0ZW4gdG8gdGhlIGZpbGUgc3lzdGVtIGZpcnN0LlxuICogVGhlIGFzc2V0IHByb3ZpZGVyIHdyaXRlcyB0byBhIHRlbXBvcmFyeSBkaXJlY3RvcnkgYmVmb3JlIGNyZWF0aW5nIHRoZSBDREsgUzMgYXNzZXQuXG4gKlxuICovXG5leHBvcnQgY2xhc3MgQXNzZXRQcm92aWRlciBpbXBsZW1lbnRzIEFzc2V0UHJvdmlkZXJJbnRlcmZhY2Uge1xuICBwcml2YXRlIHJlYWRvbmx5IHRlbXBBc3NldERpcjogc3RyaW5nO1xuICBwdWJsaWMgcmVhZG9ubHkgcmVzb2x2ZXJBc3NldHM6IFJlY29yZDxzdHJpbmcsIHN0cmluZz4gPSB7fTtcblxuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0KSB7XG4gICAgdGhpcy50ZW1wQXNzZXREaXIgPSBjZGsuRmlsZVN5c3RlbS5ta2R0ZW1wKGAke1RFTVBfUFJFRklYfS0ke3Njb3BlLm5vZGUuYWRkcn1gKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDcmVhdGVzIGEgbmV3IENESyBTMyBhc3NldC4gVGhlIGZpbGUgY29udGVudHMgaW4gYXNzZXRQcm9wcyBpcyBmaXJzdCBzdG9yZWQgaW4gYSB0ZW1wb3JhcnkgZmlsZSB0aGF0IGlzIHJlZmVyZW5jZWQgYnkgdGhlIENESyBTMyBhc3NldC5cbiAgICogQHBhcmFtIGFzc2V0U2NvcGUgdGhlIHBhcmVudCBvZiB0aGUgYXNzZXRcbiAgICogQHBhcmFtIGFzc2V0SWQgdW5pcXVlIElEIGZvciBDREsgUzMgYXNzZXRcbiAgICogQHBhcmFtIGFzc2V0UHJvcHMgbmFtZSBhbmQgY29udGVudHMgb2YgZmlsZSB0byBiZSBhZGRlZCB0byBDREsgUzMgYXNzZXRcbiAgICogQHJldHVybnMgdGhlIENESyBTMyBhc3NldFxuICAgKi9cbiAgcHVibGljIHByb3ZpZGUoYXNzZXRTY29wZTogQ29uc3RydWN0LCBhc3NldElkOiBzdHJpbmcsIGFzc2V0UHJvcHM6IEFzc2V0UHJvcHMpOiBTM0Fzc2V0IHtcbiAgICByZXR1cm4gbmV3IEFzc2V0KGFzc2V0U2NvcGUsIGFzc2V0SWQsIHsgcGF0aDogdGhpcy5hZGRBc3NldChhc3NldFByb3BzLmZpbGVOYW1lLCBhc3NldFByb3BzLmZpbGVDb250ZW50KSB9KTtcbiAgfVxuXG4gIHByaXZhdGUgYWRkQXNzZXQoZmlsZU5hbWU6IHN0cmluZywgY29udGVudHM6IHN0cmluZyk6IHN0cmluZyB7XG4gICAgdGhpcy50cmFja1Jlc29sdmVyQXNzZXQoZmlsZU5hbWUsIGNvbnRlbnRzKTtcbiAgICBjb25zdCB3cml0YWJsZUNvbnRlbnRzID0gdGhpcy5pc0NvbnRlbnRzQVJlZmVyZW5jZShmaWxlTmFtZSkgPyB0aGlzLmRlcmVmZXJlbmNlQ29udGVudHMoY29udGVudHMpIDogY29udGVudHM7XG4gICAgY29uc3QgZmlsZVBhdGggPSBwYXRoLmpvaW4odGhpcy50ZW1wQXNzZXREaXIsIGZpbGVOYW1lKTtcbiAgICBjb25zdCBmaWxlRGlyTmFtZSA9IHBhdGguZGlybmFtZShmaWxlUGF0aCk7XG4gICAgaWYgKCFmcy5leGlzdHNTeW5jKGZpbGVEaXJOYW1lKSkge1xuICAgICAgZnMubWtkaXJTeW5jKGZpbGVEaXJOYW1lLCB7IHJlY3Vyc2l2ZTogdHJ1ZSB9KTtcbiAgICB9XG4gICAgZnMud3JpdGVGaWxlU3luYyhmaWxlUGF0aCwgd3JpdGFibGVDb250ZW50cyk7XG4gICAgcmV0dXJuIGZpbGVQYXRoO1xuICB9XG5cbiAgcHJpdmF0ZSBpc0NvbnRlbnRzQVJlZmVyZW5jZShmaWxlTmFtZTogc3RyaW5nKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIGZpbGVOYW1lLnN0YXJ0c1dpdGgoRlVOQ1RJT05fUFJFRklYKTtcbiAgfVxuXG4gIHByaXZhdGUgZGVyZWZlcmVuY2VDb250ZW50cyhjb250ZW50czogc3RyaW5nKTogQnVmZmVyIHtcbiAgICByZXR1cm4gZnMucmVhZEZpbGVTeW5jKGNvbnRlbnRzKTtcbiAgfVxuXG4gIHByaXZhdGUgdHJhY2tSZXNvbHZlckFzc2V0KGZpbGVOYW1lOiBzdHJpbmcsIGNvbnRlbnRzOiBzdHJpbmcpOiB2b2lkIHtcbiAgICBpZiAoZmlsZU5hbWUuc3RhcnRzV2l0aChSRVNPTFZFUl9QUkVGSVgpKSB7XG4gICAgICBjb25zdCByZXNvbHZlckZpbGVOYW1lID0gZmlsZU5hbWUuc3BsaXQoJy8nKVsxXTtcbiAgICAgIHRoaXMucmVzb2x2ZXJBc3NldHNbcmVzb2x2ZXJGaWxlTmFtZV0gPSBjb250ZW50cztcbiAgICB9XG4gIH1cbn1cbiJdfQ==
@@ -152,7 +152,17 @@ const validateDataSourceStrategy = (strategy) => {
152
152
  const dbConnectionConfig = strategy.dbConnectionConfig;
153
153
  if ((0, graphql_transformer_interfaces_1.isSqlModelDataSourceSsmDbConnectionConfig)(dbConnectionConfig) ||
154
154
  (0, graphql_transformer_interfaces_1.isSqlModelDataSourceSsmDbConnectionStringConfig)(dbConnectionConfig)) {
155
- const invalidSSMPaths = Object.values(dbConnectionConfig).filter((value) => typeof value === 'string' && !isValidSSMPath(value));
155
+ const ssmPaths = Object.values(dbConnectionConfig).filter((value) => typeof value === 'string');
156
+ if ((0, graphql_transformer_interfaces_1.isSqlModelDataSourceSsmDbConnectionStringConfig)(dbConnectionConfig)) {
157
+ const hasMultipleSSMPaths = Array.isArray(dbConnectionConfig?.connectionUriSsmPath);
158
+ if (hasMultipleSSMPaths) {
159
+ if (dbConnectionConfig?.connectionUriSsmPath?.length < 1) {
160
+ throw new Error(`Invalid data source strategy "${strategy.name}". connectionUriSsmPath must be a string or non-empty array.`);
161
+ }
162
+ ssmPaths.push(...dbConnectionConfig.connectionUriSsmPath);
163
+ }
164
+ }
165
+ const invalidSSMPaths = ssmPaths.filter((value) => !isValidSSMPath(value));
156
166
  if (invalidSSMPaths.length > 0) {
157
167
  throw new Error(`Invalid data source strategy "${strategy.name}". Following SSM paths must start with '/' in dbConnectionConfig: ${invalidSSMPaths.join(', ')}.`);
158
168
  }
@@ -191,4 +201,4 @@ exports.validateDataSourceStrategy = validateDataSourceStrategy;
191
201
  const isValidSSMPath = (path) => {
192
202
  return path.startsWith('/');
193
203
  };
194
- //# 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  isSqlModelDataSourceSsmDbConnectionStringConfig,\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 (\n    isSqlModelDataSourceSsmDbConnectionConfig(dbConnectionConfig) ||\n    isSqlModelDataSourceSsmDbConnectionStringConfig(dbConnectionConfig)\n  ) {\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"]}
204
+ //# 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  isSqlModelDataSourceSsmDbConnectionStringConfig,\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 (\n    isSqlModelDataSourceSsmDbConnectionConfig(dbConnectionConfig) ||\n    isSqlModelDataSourceSsmDbConnectionStringConfig(dbConnectionConfig)\n  ) {\n    const ssmPaths = Object.values(dbConnectionConfig).filter((value) => typeof value === 'string');\n    if (isSqlModelDataSourceSsmDbConnectionStringConfig(dbConnectionConfig)) {\n      const hasMultipleSSMPaths = Array.isArray(dbConnectionConfig?.connectionUriSsmPath);\n      if (hasMultipleSSMPaths) {\n        if (dbConnectionConfig?.connectionUriSsmPath?.length < 1) {\n          throw new Error(`Invalid data source strategy \"${strategy.name}\". connectionUriSsmPath must be a string or non-empty array.`);\n        }\n        ssmPaths.push(...dbConnectionConfig.connectionUriSsmPath);\n      }\n    }\n\n    const invalidSSMPaths = ssmPaths.filter((value) => !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"]}
@@ -2,6 +2,6 @@ export * from './authorization-modes';
2
2
  export * from './construct-exports';
3
3
  export * from './default-parameters';
4
4
  export * from './conflict-resolution';
5
- export * from './asset-manager';
5
+ export * from './asset-provider';
6
6
  export * from './codegen-assets';
7
7
  export * from './model-type-name';
@@ -18,7 +18,7 @@ __exportStar(require("./authorization-modes"), exports);
18
18
  __exportStar(require("./construct-exports"), exports);
19
19
  __exportStar(require("./default-parameters"), exports);
20
20
  __exportStar(require("./conflict-resolution"), exports);
21
- __exportStar(require("./asset-manager"), exports);
21
+ __exportStar(require("./asset-provider"), exports);
22
22
  __exportStar(require("./codegen-assets"), exports);
23
23
  __exportStar(require("./model-type-name"), exports);
24
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW50ZXJuYWwvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLHdEQUFzQztBQUN0QyxzREFBb0M7QUFDcEMsdURBQXFDO0FBQ3JDLHdEQUFzQztBQUN0QyxrREFBZ0M7QUFDaEMsbURBQWlDO0FBQ2pDLG9EQUFrQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYXV0aG9yaXphdGlvbi1tb2Rlcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbnN0cnVjdC1leHBvcnRzJztcbmV4cG9ydCAqIGZyb20gJy4vZGVmYXVsdC1wYXJhbWV0ZXJzJztcbmV4cG9ydCAqIGZyb20gJy4vY29uZmxpY3QtcmVzb2x1dGlvbic7XG5leHBvcnQgKiBmcm9tICcuL2Fzc2V0LW1hbmFnZXInO1xuZXhwb3J0ICogZnJvbSAnLi9jb2RlZ2VuLWFzc2V0cyc7XG5leHBvcnQgKiBmcm9tICcuL21vZGVsLXR5cGUtbmFtZSc7XG4iXX0=
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW50ZXJuYWwvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLHdEQUFzQztBQUN0QyxzREFBb0M7QUFDcEMsdURBQXFDO0FBQ3JDLHdEQUFzQztBQUN0QyxtREFBaUM7QUFDakMsbURBQWlDO0FBQ2pDLG9EQUFrQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYXV0aG9yaXphdGlvbi1tb2Rlcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbnN0cnVjdC1leHBvcnRzJztcbmV4cG9ydCAqIGZyb20gJy4vZGVmYXVsdC1wYXJhbWV0ZXJzJztcbmV4cG9ydCAqIGZyb20gJy4vY29uZmxpY3QtcmVzb2x1dGlvbic7XG5leHBvcnQgKiBmcm9tICcuL2Fzc2V0LXByb3ZpZGVyJztcbmV4cG9ydCAqIGZyb20gJy4vY29kZWdlbi1hc3NldHMnO1xuZXhwb3J0ICogZnJvbSAnLi9tb2RlbC10eXBlLW5hbWUnO1xuIl19
@@ -99,8 +99,13 @@ export type SqlModelDataSourceDbConnectionConfig = SqlModelDataSourceSecretsMana
99
99
  * @experimental
100
100
  */
101
101
  export interface SqlModelDataSourceSsmDbConnectionStringConfig {
102
- /** The SSM Path to the secure connection string used for connecting to the database. **/
103
- readonly connectionUriSsmPath: string;
102
+ /**
103
+ * The SSM Path to the secure connection string used for connecting to the database. If more than one path is provided,
104
+ * the SQL Lambda will attempt to retrieve connection information from each path in order until it finds a valid
105
+ * path entry, then stop. If the connection information contained in that path is invalid, the SQL Lambda will not
106
+ * attempt to retrieve connection information from subsequent paths in the array.
107
+ **/
108
+ readonly connectionUriSsmPath: string | string[];
104
109
  }
105
110
  /**
106
111
  * The credentials stored in Secrets Manager that the lambda data source will use to connect to the database.
@@ -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 credentials the lambda data source will use to connect to the database.\n *\n * @experimental\n */\nexport type SqlModelDataSourceDbConnectionConfig =\n  | SqlModelDataSourceSecretsManagerDbConnectionConfig\n  | SqlModelDataSourceSsmDbConnectionConfig\n  | SqlModelDataSourceSsmDbConnectionStringConfig;\n\n/**\n * The configuration option to use a Secure Systems Manager parameter to store the connection string to the database.\n * @experimental\n */\nexport interface SqlModelDataSourceSsmDbConnectionStringConfig {\n  /** The SSM Path to the secure connection string used for connecting to the database. **/\n  readonly connectionUriSsmPath: string;\n}\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"]}
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  | SqlModelDataSourceSsmDbConnectionStringConfig;\n\n/**\n * The configuration option to use a Secure Systems Manager parameter to store the connection string to the database.\n * @experimental\n */\nexport interface SqlModelDataSourceSsmDbConnectionStringConfig {\n  /**\n   * The SSM Path to the secure connection string used for connecting to the database. If more than one path is provided,\n   * the SQL Lambda will attempt to retrieve connection information from each path in order until it finds a valid\n   * path entry, then stop. If the connection information contained in that path is invalid, the SQL Lambda will not\n   * attempt to retrieve connection information from subsequent paths in the array.\n   **/\n  readonly connectionUriSsmPath: string | string[];\n}\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"]}
@@ -63,7 +63,8 @@ exports.isSqlModelDataSourceSecretsManagerDbConnectionConfig = isSqlModelDataSou
63
63
  * @returns true if the object is shaped like a SqlModelDataSourceSsmDbConnectionStringConfig
64
64
  */
65
65
  const isSqlModelDataSourceSsmDbConnectionStringConfig = (obj) => {
66
- return (typeof obj === 'object' || typeof obj === 'function') && typeof obj.connectionUriSsmPath === 'string';
66
+ return ((typeof obj === 'object' || typeof obj === 'function') &&
67
+ (typeof obj.connectionUriSsmPath === 'string' || Array.isArray(obj.connectionUriSsmPath)));
67
68
  };
68
69
  exports.isSqlModelDataSourceSsmDbConnectionStringConfig = isSqlModelDataSourceSsmDbConnectionStringConfig;
69
70
  /**
@@ -90,5 +91,5 @@ class SQLLambdaModelDataSourceStrategyFactory {
90
91
  }
91
92
  exports.SQLLambdaModelDataSourceStrategyFactory = SQLLambdaModelDataSourceStrategyFactory;
92
93
  _a = JSII_RTTI_SYMBOL_1;
93
- SQLLambdaModelDataSourceStrategyFactory[_a] = { fqn: "@aws-amplify/graphql-api-construct.SQLLambdaModelDataSourceStrategyFactory", version: "1.9.0-gen2-release-0418-2.0" };
94
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sql-model-datasource-strategy.js","sourceRoot":"","sources":["../src/sql-model-datasource-strategy.ts"],"names":[],"mappings":";;;;;AAAA,yBAAyB;AACzB,6BAA6B;AAC7B,oFAAoE;AASpE;;;;GAIG;AACI,MAAM,kCAAkC,GAAG,CAAC,GAAQ,EAA2C,EAAE;IACtG,OAAO,CACL,CAAC,OAAO,GAAG,KAAK,QAAQ,IAAI,OAAO,GAAG,KAAK,UAAU,CAAC;QACtD,OAAO,GAAG,CAAC,IAAI,KAAK,QAAQ;QAC5B,OAAO,GAAG,CAAC,MAAM,KAAK,QAAQ;QAC9B,IAAA,sCAAW,EAAC,GAAG,CAAC,MAAM,CAAC;QACvB,IAAA,8CAAsC,EAAC,GAAG,CAAC,kBAAkB,CAAC,CAC/D,CAAC;AACJ,CAAC,CAAC;AARW,QAAA,kCAAkC,sCAQ7C;AAEF;;;;GAIG;AACI,MAAM,sCAAsC,GAAG,CAAC,GAAQ,EAA+C,EAAE;IAC9G,OAAO,CACL,IAAA,iDAAyC,EAAC,GAAG,CAAC;QAC9C,IAAA,4DAAoD,EAAC,GAAG,CAAC;QACzD,IAAA,uDAA+C,EAAC,GAAG,CAAC,CACrD,CAAC;AACJ,CAAC,CAAC;AANW,QAAA,sCAAsC,0CAMjD;AAEF;;;;GAIG;AACI,MAAM,yCAAyC,GAAG,CAAC,GAAQ,EAAkD,EAAE;IACpH,OAAO,CACL,CAAC,OAAO,GAAG,KAAK,QAAQ,IAAI,OAAO,GAAG,KAAK,UAAU,CAAC;QACtD,OAAO,GAAG,CAAC,eAAe,KAAK,QAAQ;QACvC,OAAO,GAAG,CAAC,WAAW,KAAK,QAAQ;QACnC,OAAO,GAAG,CAAC,eAAe,KAAK,QAAQ;QACvC,OAAO,GAAG,CAAC,eAAe,KAAK,QAAQ;QACvC,OAAO,GAAG,CAAC,mBAAmB,KAAK,QAAQ,CAC5C,CAAC;AACJ,CAAC,CAAC;AATW,QAAA,yCAAyC,6CASpD;AAEF;;;;GAIG;AACI,MAAM,oDAAoD,GAAG,CAClE,GAAQ,EACmD,EAAE;IAC7D,OAAO,CACL,CAAC,OAAO,GAAG,KAAK,QAAQ,IAAI,OAAO,GAAG,KAAK,UAAU,CAAC;QACtD,OAAO,GAAG,CAAC,SAAS,KAAK,QAAQ;QACjC,OAAO,GAAG,CAAC,IAAI,KAAK,QAAQ;QAC5B,OAAO,GAAG,CAAC,YAAY,KAAK,QAAQ;QACpC,OAAO,GAAG,CAAC,QAAQ,IAAI,QAAQ,CAChC,CAAC;AACJ,CAAC,CAAC;AAVW,QAAA,oDAAoD,wDAU/D;AAEF;;;;GAIG;AACI,MAAM,+CAA+C,GAAG,CAAC,GAAQ,EAAwD,EAAE;IAChI,OAAO,CAAC,OAAO,GAAG,KAAK,QAAQ,IAAI,OAAO,GAAG,KAAK,UAAU,CAAC,IAAI,OAAO,GAAG,CAAC,oBAAoB,KAAK,QAAQ,CAAC;AAChH,CAAC,CAAC;AAFW,QAAA,+CAA+C,mDAE1D;AAEF;;GAEG;AACH,MAAa,uCAAuC;IAClD;;;;;OAKG;IACH,MAAM,CAAC,kBAAkB,CACvB,QAAkB,EAClB,OAAyE;QAEzE,MAAM,mBAAmB,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,QAAQ,EAA0B,EAAE;YACpF,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC;YAC3C,GAAG,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,YAAY,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;YAClD,OAAO,GAAG,CAAC;QACb,CAAC,EAAE,EAA4B,CAAC,CAAC;QAEjC,OAAO;YACL,mBAAmB;YACnB,GAAG,OAAO;SACX,CAAC;IACJ,CAAC;;AArBH,0FAsBC","sourcesContent":["import * as fs from 'fs';\nimport * as path from 'path';\nimport { isSqlDbType } from '@aws-amplify/graphql-transformer-core';\nimport {\n  SQLLambdaModelDataSourceStrategy,\n  SqlModelDataSourceDbConnectionConfig,\n  SqlModelDataSourceSsmDbConnectionConfig,\n  SqlModelDataSourceSecretsManagerDbConnectionConfig,\n  SqlModelDataSourceSsmDbConnectionStringConfig,\n} from './model-datasource-strategy-types';\n\n/**\n * Type predicate that returns true if the object is a SQLLambdaModelDataSourceStrategy.\n * @param obj the object to inspect\n * @returns true if the object is shaped like a SQLLambdaModelDataSourceStrategy\n */\nexport const isSQLLambdaModelDataSourceStrategy = (obj: any): obj is SQLLambdaModelDataSourceStrategy => {\n  return (\n    (typeof obj === 'object' || typeof obj === 'function') &&\n    typeof obj.name === 'string' &&\n    typeof obj.dbType === 'string' &&\n    isSqlDbType(obj.dbType) &&\n    isSqlModelDataSourceDbConnectionConfig(obj.dbConnectionConfig)\n  );\n};\n\n/**\n * Type predicate that returns true if the object is a SqlModelDataSourceDbConnectionConfig.\n * @param obj the object to inspect\n * @returns true if the object is shaped like a SqlModelDataSourceDbConnectionConfig\n */\nexport const isSqlModelDataSourceDbConnectionConfig = (obj: any): obj is SqlModelDataSourceDbConnectionConfig => {\n  return (\n    isSqlModelDataSourceSsmDbConnectionConfig(obj) ||\n    isSqlModelDataSourceSecretsManagerDbConnectionConfig(obj) ||\n    isSqlModelDataSourceSsmDbConnectionStringConfig(obj)\n  );\n};\n\n/**\n * Type predicate that returns true if the object is a SqlModelDataSourceSsmDbConnectionConfig.\n * @param obj the object to inspect\n * @returns true if the object is shaped like a SqlModelDataSourceSsmDbConnectionConfig\n */\nexport const isSqlModelDataSourceSsmDbConnectionConfig = (obj: any): obj is SqlModelDataSourceSsmDbConnectionConfig => {\n  return (\n    (typeof obj === 'object' || typeof obj === 'function') &&\n    typeof obj.hostnameSsmPath === 'string' &&\n    typeof obj.portSsmPath === 'string' &&\n    typeof obj.usernameSsmPath === 'string' &&\n    typeof obj.passwordSsmPath === 'string' &&\n    typeof obj.databaseNameSsmPath === 'string'\n  );\n};\n\n/**\n * Type predicate that returns true if the object is a SqlModelDataSourceSecretsManagerDbConnectionConfig.\n * @param obj the object to inspect\n * @returns true if the object is shaped like a SqlModelDataSourceSecretsManagerDbConnectionConfig\n */\nexport const isSqlModelDataSourceSecretsManagerDbConnectionConfig = (\n  obj: any,\n): obj is SqlModelDataSourceSecretsManagerDbConnectionConfig => {\n  return (\n    (typeof obj === 'object' || typeof obj === 'function') &&\n    typeof obj.secretArn === 'string' &&\n    typeof obj.port === 'number' &&\n    typeof obj.databaseName === 'string' &&\n    typeof obj.hostname == 'string'\n  );\n};\n\n/**\n * Type predicate that returns true if the object is a SqlModelDataSourceSsmDbConnectionStringConfig.\n * @param obj the object to inspect\n * @returns true if the object is shaped like a SqlModelDataSourceSsmDbConnectionStringConfig\n */\nexport const isSqlModelDataSourceSsmDbConnectionStringConfig = (obj: any): obj is SqlModelDataSourceSsmDbConnectionStringConfig => {\n  return (typeof obj === 'object' || typeof obj === 'function') && typeof obj.connectionUriSsmPath === 'string';\n};\n\n/**\n * Class exposing utilities to produce SQLLambdaModelDataSourceStrategy objects given various inputs.\n */\nexport class SQLLambdaModelDataSourceStrategyFactory {\n  /**\n   * Creates a SQLLambdaModelDataSourceStrategy where the binding's `customSqlStatements` are populated from `sqlFiles`. The key\n   * of the `customSqlStatements` record is the file's base name (that is, the name of the file minus the directory and extension).\n   * @param sqlFiles the list of files to load SQL statements from.\n   * @param options the remaining SQLLambdaModelDataSourceStrategy options.\n   */\n  static fromCustomSqlFiles(\n    sqlFiles: string[],\n    options: Exclude<SQLLambdaModelDataSourceStrategy, 'customSqlStatements'>,\n  ): SQLLambdaModelDataSourceStrategy {\n    const customSqlStatements = sqlFiles.reduce((acc, filePath): Record<string, string> => {\n      const basename = path.parse(filePath).name;\n      acc[basename] = fs.readFileSync(filePath, 'utf8');\n      return acc;\n    }, {} as Record<string, string>);\n\n    return {\n      customSqlStatements,\n      ...options,\n    };\n  }\n}\n"]}
94
+ SQLLambdaModelDataSourceStrategyFactory[_a] = { fqn: "@aws-amplify/graphql-api-construct.SQLLambdaModelDataSourceStrategyFactory", version: "1.9.0-gen2-release-0423.0" };
95
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sql-model-datasource-strategy.js","sourceRoot":"","sources":["../src/sql-model-datasource-strategy.ts"],"names":[],"mappings":";;;;;AAAA,yBAAyB;AACzB,6BAA6B;AAC7B,oFAAoE;AASpE;;;;GAIG;AACI,MAAM,kCAAkC,GAAG,CAAC,GAAQ,EAA2C,EAAE;IACtG,OAAO,CACL,CAAC,OAAO,GAAG,KAAK,QAAQ,IAAI,OAAO,GAAG,KAAK,UAAU,CAAC;QACtD,OAAO,GAAG,CAAC,IAAI,KAAK,QAAQ;QAC5B,OAAO,GAAG,CAAC,MAAM,KAAK,QAAQ;QAC9B,IAAA,sCAAW,EAAC,GAAG,CAAC,MAAM,CAAC;QACvB,IAAA,8CAAsC,EAAC,GAAG,CAAC,kBAAkB,CAAC,CAC/D,CAAC;AACJ,CAAC,CAAC;AARW,QAAA,kCAAkC,sCAQ7C;AAEF;;;;GAIG;AACI,MAAM,sCAAsC,GAAG,CAAC,GAAQ,EAA+C,EAAE;IAC9G,OAAO,CACL,IAAA,iDAAyC,EAAC,GAAG,CAAC;QAC9C,IAAA,4DAAoD,EAAC,GAAG,CAAC;QACzD,IAAA,uDAA+C,EAAC,GAAG,CAAC,CACrD,CAAC;AACJ,CAAC,CAAC;AANW,QAAA,sCAAsC,0CAMjD;AAEF;;;;GAIG;AACI,MAAM,yCAAyC,GAAG,CAAC,GAAQ,EAAkD,EAAE;IACpH,OAAO,CACL,CAAC,OAAO,GAAG,KAAK,QAAQ,IAAI,OAAO,GAAG,KAAK,UAAU,CAAC;QACtD,OAAO,GAAG,CAAC,eAAe,KAAK,QAAQ;QACvC,OAAO,GAAG,CAAC,WAAW,KAAK,QAAQ;QACnC,OAAO,GAAG,CAAC,eAAe,KAAK,QAAQ;QACvC,OAAO,GAAG,CAAC,eAAe,KAAK,QAAQ;QACvC,OAAO,GAAG,CAAC,mBAAmB,KAAK,QAAQ,CAC5C,CAAC;AACJ,CAAC,CAAC;AATW,QAAA,yCAAyC,6CASpD;AAEF;;;;GAIG;AACI,MAAM,oDAAoD,GAAG,CAClE,GAAQ,EACmD,EAAE;IAC7D,OAAO,CACL,CAAC,OAAO,GAAG,KAAK,QAAQ,IAAI,OAAO,GAAG,KAAK,UAAU,CAAC;QACtD,OAAO,GAAG,CAAC,SAAS,KAAK,QAAQ;QACjC,OAAO,GAAG,CAAC,IAAI,KAAK,QAAQ;QAC5B,OAAO,GAAG,CAAC,YAAY,KAAK,QAAQ;QACpC,OAAO,GAAG,CAAC,QAAQ,IAAI,QAAQ,CAChC,CAAC;AACJ,CAAC,CAAC;AAVW,QAAA,oDAAoD,wDAU/D;AAEF;;;;GAIG;AACI,MAAM,+CAA+C,GAAG,CAAC,GAAQ,EAAwD,EAAE;IAChI,OAAO,CACL,CAAC,OAAO,GAAG,KAAK,QAAQ,IAAI,OAAO,GAAG,KAAK,UAAU,CAAC;QACtD,CAAC,OAAO,GAAG,CAAC,oBAAoB,KAAK,QAAQ,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,CAAC,CAC1F,CAAC;AACJ,CAAC,CAAC;AALW,QAAA,+CAA+C,mDAK1D;AAEF;;GAEG;AACH,MAAa,uCAAuC;IAClD;;;;;OAKG;IACH,MAAM,CAAC,kBAAkB,CACvB,QAAkB,EAClB,OAAyE;QAEzE,MAAM,mBAAmB,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,QAAQ,EAA0B,EAAE;YACpF,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC;YAC3C,GAAG,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,YAAY,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;YAClD,OAAO,GAAG,CAAC;QACb,CAAC,EAAE,EAA4B,CAAC,CAAC;QAEjC,OAAO;YACL,mBAAmB;YACnB,GAAG,OAAO;SACX,CAAC;IACJ,CAAC;;AArBH,0FAsBC","sourcesContent":["import * as fs from 'fs';\nimport * as path from 'path';\nimport { isSqlDbType } from '@aws-amplify/graphql-transformer-core';\nimport {\n  SQLLambdaModelDataSourceStrategy,\n  SqlModelDataSourceDbConnectionConfig,\n  SqlModelDataSourceSsmDbConnectionConfig,\n  SqlModelDataSourceSecretsManagerDbConnectionConfig,\n  SqlModelDataSourceSsmDbConnectionStringConfig,\n} from './model-datasource-strategy-types';\n\n/**\n * Type predicate that returns true if the object is a SQLLambdaModelDataSourceStrategy.\n * @param obj the object to inspect\n * @returns true if the object is shaped like a SQLLambdaModelDataSourceStrategy\n */\nexport const isSQLLambdaModelDataSourceStrategy = (obj: any): obj is SQLLambdaModelDataSourceStrategy => {\n  return (\n    (typeof obj === 'object' || typeof obj === 'function') &&\n    typeof obj.name === 'string' &&\n    typeof obj.dbType === 'string' &&\n    isSqlDbType(obj.dbType) &&\n    isSqlModelDataSourceDbConnectionConfig(obj.dbConnectionConfig)\n  );\n};\n\n/**\n * Type predicate that returns true if the object is a SqlModelDataSourceDbConnectionConfig.\n * @param obj the object to inspect\n * @returns true if the object is shaped like a SqlModelDataSourceDbConnectionConfig\n */\nexport const isSqlModelDataSourceDbConnectionConfig = (obj: any): obj is SqlModelDataSourceDbConnectionConfig => {\n  return (\n    isSqlModelDataSourceSsmDbConnectionConfig(obj) ||\n    isSqlModelDataSourceSecretsManagerDbConnectionConfig(obj) ||\n    isSqlModelDataSourceSsmDbConnectionStringConfig(obj)\n  );\n};\n\n/**\n * Type predicate that returns true if the object is a SqlModelDataSourceSsmDbConnectionConfig.\n * @param obj the object to inspect\n * @returns true if the object is shaped like a SqlModelDataSourceSsmDbConnectionConfig\n */\nexport const isSqlModelDataSourceSsmDbConnectionConfig = (obj: any): obj is SqlModelDataSourceSsmDbConnectionConfig => {\n  return (\n    (typeof obj === 'object' || typeof obj === 'function') &&\n    typeof obj.hostnameSsmPath === 'string' &&\n    typeof obj.portSsmPath === 'string' &&\n    typeof obj.usernameSsmPath === 'string' &&\n    typeof obj.passwordSsmPath === 'string' &&\n    typeof obj.databaseNameSsmPath === 'string'\n  );\n};\n\n/**\n * Type predicate that returns true if the object is a SqlModelDataSourceSecretsManagerDbConnectionConfig.\n * @param obj the object to inspect\n * @returns true if the object is shaped like a SqlModelDataSourceSecretsManagerDbConnectionConfig\n */\nexport const isSqlModelDataSourceSecretsManagerDbConnectionConfig = (\n  obj: any,\n): obj is SqlModelDataSourceSecretsManagerDbConnectionConfig => {\n  return (\n    (typeof obj === 'object' || typeof obj === 'function') &&\n    typeof obj.secretArn === 'string' &&\n    typeof obj.port === 'number' &&\n    typeof obj.databaseName === 'string' &&\n    typeof obj.hostname == 'string'\n  );\n};\n\n/**\n * Type predicate that returns true if the object is a SqlModelDataSourceSsmDbConnectionStringConfig.\n * @param obj the object to inspect\n * @returns true if the object is shaped like a SqlModelDataSourceSsmDbConnectionStringConfig\n */\nexport const isSqlModelDataSourceSsmDbConnectionStringConfig = (obj: any): obj is SqlModelDataSourceSsmDbConnectionStringConfig => {\n  return (\n    (typeof obj === 'object' || typeof obj === 'function') &&\n    (typeof obj.connectionUriSsmPath === 'string' || Array.isArray(obj.connectionUriSsmPath))\n  );\n};\n\n/**\n * Class exposing utilities to produce SQLLambdaModelDataSourceStrategy objects given various inputs.\n */\nexport class SQLLambdaModelDataSourceStrategyFactory {\n  /**\n   * Creates a SQLLambdaModelDataSourceStrategy where the binding's `customSqlStatements` are populated from `sqlFiles`. The key\n   * of the `customSqlStatements` record is the file's base name (that is, the name of the file minus the directory and extension).\n   * @param sqlFiles the list of files to load SQL statements from.\n   * @param options the remaining SQLLambdaModelDataSourceStrategy options.\n   */\n  static fromCustomSqlFiles(\n    sqlFiles: string[],\n    options: Exclude<SQLLambdaModelDataSourceStrategy, 'customSqlStatements'>,\n  ): SQLLambdaModelDataSourceStrategy {\n    const customSqlStatements = sqlFiles.reduce((acc, filePath): Record<string, string> => {\n      const basename = path.parse(filePath).name;\n      acc[basename] = fs.readFileSync(filePath, 'utf8');\n      return acc;\n    }, {} as Record<string, string>);\n\n    return {\n      customSqlStatements,\n      ...options,\n    };\n  }\n}\n"]}
@@ -3,7 +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
- # [3.5.0-gen2-release-0418-2.0](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-auth-transformer@3.4.4...@aws-amplify/graphql-auth-transformer@3.5.0-gen2-release-0418-2.0) (2024-04-18)
6
+ # [3.5.0-gen2-release-0423.0](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-auth-transformer@3.4.4...@aws-amplify/graphql-auth-transformer@3.5.0-gen2-release-0423.0) (2024-04-23)
7
+
8
+ ### Bug Fixes
9
+
10
+ - relational bidirectionality validation and improved error messages ([#2482](https://github.com/aws-amplify/amplify-category-api/issues/2482)) ([568fbc3](https://github.com/aws-amplify/amplify-category-api/commit/568fbc365e4945693f685ba8896d2e5f14031f2d))
7
11
 
8
12
  ### Features
9
13
 
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aws-amplify/graphql-auth-transformer",
3
- "version": "3.5.0-gen2-release-0418-2.0",
3
+ "version": "3.5.0-gen2-release-0423.0",
4
4
  "description": "Amplify GraphQL @auth transformer",
5
5
  "repository": {
6
6
  "type": "git",
@@ -29,23 +29,23 @@
29
29
  "extract-api": "ts-node ../../scripts/extract-api.ts"
30
30
  },
31
31
  "dependencies": {
32
- "@aws-amplify/graphql-directives": "1.1.0-gen2-release-0418-2.0",
33
- "@aws-amplify/graphql-model-transformer": "2.9.0-gen2-release-0418-2.0",
34
- "@aws-amplify/graphql-relational-transformer": "2.5.0-gen2-release-0418-2.0",
35
- "@aws-amplify/graphql-transformer-core": "2.6.1-gen2-release-0418-2.0",
36
- "@aws-amplify/graphql-transformer-interfaces": "3.7.0-gen2-release-0418-2.0",
32
+ "@aws-amplify/graphql-directives": "1.1.0-gen2-release-0423.0",
33
+ "@aws-amplify/graphql-model-transformer": "2.9.0-gen2-release-0423.0",
34
+ "@aws-amplify/graphql-relational-transformer": "2.5.0-gen2-release-0423.0",
35
+ "@aws-amplify/graphql-transformer-core": "2.7.0-gen2-release-0423.0",
36
+ "@aws-amplify/graphql-transformer-interfaces": "3.7.0-gen2-release-0423.0",
37
37
  "graphql": "^15.5.0",
38
38
  "graphql-mapping-template": "4.20.15",
39
- "graphql-transformer-common": "4.30.1-gen2-release-0418-2.0",
39
+ "graphql-transformer-common": "4.30.1-gen2-release-0423.0",
40
40
  "lodash": "^4.17.21",
41
41
  "md5": "^2.3.0"
42
42
  },
43
43
  "devDependencies": {
44
- "@aws-amplify/graphql-function-transformer": "2.1.21-gen2-release-0418-2.0",
45
- "@aws-amplify/graphql-index-transformer": "2.4.0-gen2-release-0418-2.0",
46
- "@aws-amplify/graphql-searchable-transformer": "2.7.0-gen2-release-0418-2.0",
47
- "@aws-amplify/graphql-sql-transformer": "0.3.0-gen2-release-0418-2.0",
48
- "@aws-amplify/graphql-transformer-test-utils": "0.5.1-gen2-release-0418-2.0",
44
+ "@aws-amplify/graphql-function-transformer": "2.1.21-gen2-release-0423.0",
45
+ "@aws-amplify/graphql-index-transformer": "2.4.0-gen2-release-0423.0",
46
+ "@aws-amplify/graphql-searchable-transformer": "2.7.0-gen2-release-0423.0",
47
+ "@aws-amplify/graphql-sql-transformer": "0.3.0-gen2-release-0423.0",
48
+ "@aws-amplify/graphql-transformer-test-utils": "0.5.1-gen2-release-0423.0",
49
49
  "@types/node": "^12.12.6"
50
50
  },
51
51
  "peerDependencies": {
@@ -87,5 +87,5 @@
87
87
  "/__tests__/"
88
88
  ]
89
89
  },
90
- "gitHead": "1752c32dcd54a85370c3ea3f298e25fe25909d93"
90
+ "gitHead": "f450cc3e4a785bd0068a1cdb070c424328b64a8c"
91
91
  }
@@ -3,7 +3,7 @@
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
- ## [2.3.4-gen2-release-0418-2.0](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-default-value-transformer@2.3.3...@aws-amplify/graphql-default-value-transformer@2.3.4-gen2-release-0418-2.0) (2024-04-18)
6
+ ## [2.3.4-gen2-release-0423.0](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-default-value-transformer@2.3.3...@aws-amplify/graphql-default-value-transformer@2.3.4-gen2-release-0423.0) (2024-04-23)
7
7
 
8
8
  **Note:** Version bump only for package @aws-amplify/graphql-default-value-transformer
9
9
 
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aws-amplify/graphql-default-value-transformer",
3
- "version": "2.3.4-gen2-release-0418-2.0",
3
+ "version": "2.3.4-gen2-release-0423.0",
4
4
  "description": "Amplify GraphQL default value transformer",
5
5
  "repository": {
6
6
  "type": "git",
@@ -29,17 +29,17 @@
29
29
  "extract-api": "ts-node ../../scripts/extract-api.ts"
30
30
  },
31
31
  "dependencies": {
32
- "@aws-amplify/graphql-directives": "1.1.0-gen2-release-0418-2.0",
33
- "@aws-amplify/graphql-transformer-core": "2.6.1-gen2-release-0418-2.0",
34
- "@aws-amplify/graphql-transformer-interfaces": "3.7.0-gen2-release-0418-2.0",
32
+ "@aws-amplify/graphql-directives": "1.1.0-gen2-release-0423.0",
33
+ "@aws-amplify/graphql-transformer-core": "2.7.0-gen2-release-0423.0",
34
+ "@aws-amplify/graphql-transformer-interfaces": "3.7.0-gen2-release-0423.0",
35
35
  "graphql": "^15.5.0",
36
36
  "graphql-mapping-template": "4.20.15",
37
- "graphql-transformer-common": "4.30.1-gen2-release-0418-2.0",
37
+ "graphql-transformer-common": "4.30.1-gen2-release-0423.0",
38
38
  "libphonenumber-js": "1.9.47"
39
39
  },
40
40
  "devDependencies": {
41
- "@aws-amplify/graphql-model-transformer": "2.9.0-gen2-release-0418-2.0",
42
- "@aws-amplify/graphql-transformer-test-utils": "0.5.1-gen2-release-0418-2.0"
41
+ "@aws-amplify/graphql-model-transformer": "2.9.0-gen2-release-0423.0",
42
+ "@aws-amplify/graphql-transformer-test-utils": "0.5.1-gen2-release-0423.0"
43
43
  },
44
44
  "jest": {
45
45
  "transform": {
@@ -76,5 +76,5 @@
76
76
  "/__tests__/"
77
77
  ]
78
78
  },
79
- "gitHead": "1752c32dcd54a85370c3ea3f298e25fe25909d93"
79
+ "gitHead": "f450cc3e4a785bd0068a1cdb070c424328b64a8c"
80
80
  }
@@ -3,7 +3,7 @@
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.1.0-gen2-release-0418-2.0](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-directives@1.0.1...@aws-amplify/graphql-directives@1.1.0-gen2-release-0418-2.0) (2024-04-18)
6
+ # [1.1.0-gen2-release-0423.0](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-directives@1.0.1...@aws-amplify/graphql-directives@1.1.0-gen2-release-0423.0) (2024-04-23)
7
7
 
8
8
  ### Features
9
9
 
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aws-amplify/graphql-directives",
3
- "version": "1.1.0-gen2-release-0418-2.0",
3
+ "version": "1.1.0-gen2-release-0423.0",
4
4
  "description": "Directive definitions for Amplify GraphQL transformers.",
5
5
  "repository": {
6
6
  "type": "git",
@@ -62,5 +62,5 @@
62
62
  "src/directives/directive.ts"
63
63
  ]
64
64
  },
65
- "gitHead": "1752c32dcd54a85370c3ea3f298e25fe25909d93"
65
+ "gitHead": "f450cc3e4a785bd0068a1cdb070c424328b64a8c"
66
66
  }
@@ -3,7 +3,7 @@
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
- ## [2.1.21-gen2-release-0418-2.0](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-function-transformer@2.1.20...@aws-amplify/graphql-function-transformer@2.1.21-gen2-release-0418-2.0) (2024-04-18)
6
+ ## [2.1.21-gen2-release-0423.0](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-function-transformer@2.1.20...@aws-amplify/graphql-function-transformer@2.1.21-gen2-release-0423.0) (2024-04-23)
7
7
 
8
8
  **Note:** Version bump only for package @aws-amplify/graphql-function-transformer
9
9
 
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aws-amplify/graphql-function-transformer",
3
- "version": "2.1.21-gen2-release-0418-2.0",
3
+ "version": "2.1.21-gen2-release-0423.0",
4
4
  "description": "Amplify GraphQL @function transformer",
5
5
  "repository": {
6
6
  "type": "git",
@@ -28,15 +28,15 @@
28
28
  "extract-api": "ts-node ../../scripts/extract-api.ts"
29
29
  },
30
30
  "dependencies": {
31
- "@aws-amplify/graphql-directives": "1.1.0-gen2-release-0418-2.0",
32
- "@aws-amplify/graphql-transformer-core": "2.6.1-gen2-release-0418-2.0",
33
- "@aws-amplify/graphql-transformer-interfaces": "3.7.0-gen2-release-0418-2.0",
31
+ "@aws-amplify/graphql-directives": "1.1.0-gen2-release-0423.0",
32
+ "@aws-amplify/graphql-transformer-core": "2.7.0-gen2-release-0423.0",
33
+ "@aws-amplify/graphql-transformer-interfaces": "3.7.0-gen2-release-0423.0",
34
34
  "graphql": "^15.5.0",
35
35
  "graphql-mapping-template": "4.20.15",
36
- "graphql-transformer-common": "4.30.1-gen2-release-0418-2.0"
36
+ "graphql-transformer-common": "4.30.1-gen2-release-0423.0"
37
37
  },
38
38
  "devDependencies": {
39
- "@aws-amplify/graphql-transformer-test-utils": "0.5.1-gen2-release-0418-2.0"
39
+ "@aws-amplify/graphql-transformer-test-utils": "0.5.1-gen2-release-0423.0"
40
40
  },
41
41
  "peerDependencies": {
42
42
  "aws-cdk-lib": "^2.80.0",
@@ -79,5 +79,5 @@
79
79
  "/__tests__/"
80
80
  ]
81
81
  },
82
- "gitHead": "1752c32dcd54a85370c3ea3f298e25fe25909d93"
82
+ "gitHead": "f450cc3e4a785bd0068a1cdb070c424328b64a8c"
83
83
  }