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

Sign up to get free protection for your applications and to get access to all the features.
Files changed (152) hide show
  1. package/.jsii +384 -253
  2. package/API.md +16 -4
  3. package/CHANGELOG.md +12 -0
  4. package/lib/amplify-dynamodb-table-wrapper.js +1 -1
  5. package/lib/amplify-graphql-api.d.ts +1 -1
  6. package/lib/amplify-graphql-api.js +16 -5
  7. package/lib/amplify-graphql-definition.d.ts +4 -3
  8. package/lib/amplify-graphql-definition.js +8 -16
  9. package/lib/index.d.ts +3 -1
  10. package/lib/index.js +19 -2
  11. package/lib/internal/data-source-config.d.ts +21 -2
  12. package/lib/internal/data-source-config.js +72 -33
  13. package/lib/internal/model-type-name.d.ts +2 -2
  14. package/lib/internal/model-type-name.js +4 -4
  15. package/lib/model-datasource-strategy.d.ts +116 -0
  16. package/lib/model-datasource-strategy.js +10 -0
  17. package/lib/sql-model-datasource-strategy.d.ts +1 -1
  18. package/lib/sql-model-datasource-strategy.js +5 -1
  19. package/lib/types.d.ts +16 -124
  20. package/lib/types.js +1 -1
  21. package/node_modules/@aws-amplify/graphql-auth-transformer/CHANGELOG.md +8 -0
  22. package/node_modules/@aws-amplify/graphql-auth-transformer/package.json +10 -10
  23. package/node_modules/@aws-amplify/graphql-default-value-transformer/CHANGELOG.md +8 -0
  24. package/node_modules/@aws-amplify/graphql-default-value-transformer/package.json +7 -7
  25. package/node_modules/@aws-amplify/graphql-function-transformer/CHANGELOG.md +8 -0
  26. package/node_modules/@aws-amplify/graphql-function-transformer/package.json +6 -6
  27. package/node_modules/@aws-amplify/graphql-http-transformer/CHANGELOG.md +8 -0
  28. package/node_modules/@aws-amplify/graphql-http-transformer/package.json +6 -6
  29. package/node_modules/@aws-amplify/graphql-index-transformer/CHANGELOG.md +8 -0
  30. package/node_modules/@aws-amplify/graphql-index-transformer/package.json +7 -7
  31. package/node_modules/@aws-amplify/graphql-maps-to-transformer/CHANGELOG.md +8 -0
  32. package/node_modules/@aws-amplify/graphql-maps-to-transformer/lib/assets/mapping-lambda.zip +0 -0
  33. package/node_modules/@aws-amplify/graphql-maps-to-transformer/package.json +10 -10
  34. package/node_modules/@aws-amplify/graphql-model-transformer/API.md +16 -0
  35. package/node_modules/@aws-amplify/graphql-model-transformer/CHANGELOG.md +12 -0
  36. package/node_modules/@aws-amplify/graphql-model-transformer/lib/index.d.ts +1 -0
  37. package/node_modules/@aws-amplify/graphql-model-transformer/lib/index.d.ts.map +1 -1
  38. package/node_modules/@aws-amplify/graphql-model-transformer/lib/index.js +3 -1
  39. package/node_modules/@aws-amplify/graphql-model-transformer/lib/index.js.map +1 -1
  40. package/node_modules/@aws-amplify/graphql-model-transformer/lib/rds-lambda.zip +0 -0
  41. package/node_modules/@aws-amplify/graphql-model-transformer/lib/rds-notification-lambda.zip +0 -0
  42. package/node_modules/@aws-amplify/graphql-model-transformer/lib/rds-patching-lambda.zip +0 -0
  43. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resolvers/rds/resolver.d.ts +4 -2
  44. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resolvers/rds/resolver.d.ts.map +1 -1
  45. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resolvers/rds/resolver.js +30 -86
  46. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resolvers/rds/resolver.js.map +1 -1
  47. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resources/rds-model-resource-generator.d.ts +2 -3
  48. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resources/rds-model-resource-generator.d.ts.map +1 -1
  49. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resources/rds-model-resource-generator.js +36 -18
  50. package/node_modules/@aws-amplify/graphql-model-transformer/lib/resources/rds-model-resource-generator.js.map +1 -1
  51. package/node_modules/@aws-amplify/graphql-model-transformer/package.json +6 -6
  52. package/node_modules/@aws-amplify/graphql-predictions-transformer/CHANGELOG.md +8 -0
  53. package/node_modules/@aws-amplify/graphql-predictions-transformer/lib/predictionsLambdaFunction.zip +0 -0
  54. package/node_modules/@aws-amplify/graphql-predictions-transformer/package.json +6 -6
  55. package/node_modules/@aws-amplify/graphql-relational-transformer/CHANGELOG.md +10 -0
  56. package/node_modules/@aws-amplify/graphql-relational-transformer/package.json +8 -8
  57. package/node_modules/@aws-amplify/graphql-searchable-transformer/CHANGELOG.md +8 -0
  58. package/node_modules/@aws-amplify/graphql-searchable-transformer/lib/streaming-lambda.zip +0 -0
  59. package/node_modules/@aws-amplify/graphql-searchable-transformer/package.json +7 -7
  60. package/node_modules/@aws-amplify/graphql-sql-transformer/CHANGELOG.md +10 -0
  61. package/node_modules/@aws-amplify/graphql-sql-transformer/lib/graphql-sql-transformer.d.ts.map +1 -1
  62. package/node_modules/@aws-amplify/graphql-sql-transformer/lib/graphql-sql-transformer.js +15 -1
  63. package/node_modules/@aws-amplify/graphql-sql-transformer/lib/graphql-sql-transformer.js.map +1 -1
  64. package/node_modules/@aws-amplify/graphql-sql-transformer/package.json +7 -7
  65. package/node_modules/@aws-amplify/graphql-transformer/API.md +3 -1
  66. package/node_modules/@aws-amplify/graphql-transformer/CHANGELOG.md +10 -0
  67. package/node_modules/@aws-amplify/graphql-transformer/lib/graphql-transformer.d.ts +2 -1
  68. package/node_modules/@aws-amplify/graphql-transformer/lib/graphql-transformer.d.ts.map +1 -1
  69. package/node_modules/@aws-amplify/graphql-transformer/lib/graphql-transformer.js +2 -1
  70. package/node_modules/@aws-amplify/graphql-transformer/lib/graphql-transformer.js.map +1 -1
  71. package/node_modules/@aws-amplify/graphql-transformer/package.json +15 -15
  72. package/node_modules/@aws-amplify/graphql-transformer/src/graphql-transformer.ts +4 -1
  73. package/node_modules/@aws-amplify/graphql-transformer-core/API.md +35 -5
  74. package/node_modules/@aws-amplify/graphql-transformer-core/CHANGELOG.md +12 -0
  75. package/node_modules/@aws-amplify/graphql-transformer-core/lib/index.d.ts +1 -1
  76. package/node_modules/@aws-amplify/graphql-transformer-core/lib/index.d.ts.map +1 -1
  77. package/node_modules/@aws-amplify/graphql-transformer-core/lib/index.js +19 -13
  78. package/node_modules/@aws-amplify/graphql-transformer-core/lib/index.js.map +1 -1
  79. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformation/transform.d.ts.map +1 -1
  80. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformation/transform.js +20 -2
  81. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformation/transform.js.map +1 -1
  82. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformation/types.d.ts +2 -1
  83. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformation/types.d.ts.map +1 -1
  84. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformer-context/index.d.ts +24 -6
  85. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformer-context/index.d.ts.map +1 -1
  86. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformer-context/index.js +16 -14
  87. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformer-context/index.js.map +1 -1
  88. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformer-context/stack-manager.d.ts.map +1 -1
  89. package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformer-context/stack-manager.js.map +1 -1
  90. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/graphql-utils.d.ts +14 -0
  91. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/graphql-utils.d.ts.map +1 -0
  92. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/graphql-utils.js +23 -0
  93. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/graphql-utils.js.map +1 -0
  94. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/index.d.ts +2 -0
  95. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/index.d.ts.map +1 -1
  96. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/index.js +16 -0
  97. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/index.js.map +1 -1
  98. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/model-datasource-strategy-utils.d.ts +11 -0
  99. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/model-datasource-strategy-utils.d.ts.map +1 -0
  100. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/model-datasource-strategy-utils.js +84 -0
  101. package/node_modules/@aws-amplify/graphql-transformer-core/lib/utils/model-datasource-strategy-utils.js.map +1 -0
  102. package/node_modules/@aws-amplify/graphql-transformer-core/package.json +4 -4
  103. package/node_modules/@aws-amplify/graphql-transformer-interfaces/API.md +89 -5
  104. package/node_modules/@aws-amplify/graphql-transformer-interfaces/CHANGELOG.md +6 -0
  105. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/graphql-api-provider.d.ts +0 -17
  106. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/graphql-api-provider.d.ts.map +1 -1
  107. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/graphql-api-provider.js.map +1 -1
  108. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/index.d.ts +2 -1
  109. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/index.d.ts.map +1 -1
  110. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/index.js +1 -0
  111. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/index.js.map +1 -1
  112. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/model-datasource/index.d.ts +2 -0
  113. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/model-datasource/index.d.ts.map +1 -0
  114. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/model-datasource/index.js +18 -0
  115. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/model-datasource/index.js.map +1 -0
  116. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/model-datasource/types.d.ts +55 -0
  117. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/model-datasource/types.d.ts.map +1 -0
  118. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/model-datasource/types.js +3 -0
  119. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/model-datasource/types.js.map +1 -0
  120. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/transform-host-provider.d.ts +2 -1
  121. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/transform-host-provider.d.ts.map +1 -1
  122. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/transformer-context/index.d.ts +1 -1
  123. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/transformer-context/index.d.ts.map +1 -1
  124. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/transformer-context/transformer-context-provider.d.ts +6 -4
  125. package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/transformer-context/transformer-context-provider.d.ts.map +1 -1
  126. package/node_modules/@aws-amplify/graphql-transformer-interfaces/package.json +3 -2
  127. package/node_modules/@aws-amplify/graphql-transformer-interfaces/src/graphql-api-provider.ts +1 -41
  128. package/node_modules/@aws-amplify/graphql-transformer-interfaces/src/index.ts +1 -4
  129. package/node_modules/@aws-amplify/graphql-transformer-interfaces/src/model-datasource/index.ts +1 -0
  130. package/node_modules/@aws-amplify/graphql-transformer-interfaces/src/model-datasource/types.ts +163 -0
  131. package/node_modules/@aws-amplify/graphql-transformer-interfaces/src/transform-host-provider.ts +1 -1
  132. package/node_modules/@aws-amplify/graphql-transformer-interfaces/src/transformer-context/index.ts +4 -3
  133. package/node_modules/@aws-amplify/graphql-transformer-interfaces/src/transformer-context/transformer-context-provider.ts +6 -7
  134. package/node_modules/@aws-amplify/graphql-transformer-interfaces/src/transformer-context/transformer-datasource-provider.ts +2 -2
  135. package/node_modules/@aws-amplify/graphql-transformer-interfaces/tsconfig.tsbuildinfo +1 -1
  136. package/node_modules/graphql-transformer-common/API.md +11 -4
  137. package/node_modules/graphql-transformer-common/CHANGELOG.md +6 -0
  138. package/node_modules/graphql-transformer-common/lib/ResourceConstants.d.ts +11 -4
  139. package/node_modules/graphql-transformer-common/lib/ResourceConstants.d.ts.map +1 -1
  140. package/node_modules/graphql-transformer-common/lib/ResourceConstants.js +11 -4
  141. package/node_modules/graphql-transformer-common/lib/ResourceConstants.js.map +1 -1
  142. package/node_modules/graphql-transformer-common/package.json +2 -3
  143. package/package.json +17 -17
  144. package/src/amplify-graphql-api.ts +20 -5
  145. package/src/amplify-graphql-definition.ts +8 -15
  146. package/src/index.ts +3 -11
  147. package/src/internal/data-source-config.ts +89 -35
  148. package/src/internal/model-type-name.ts +3 -3
  149. package/src/model-datasource-strategy.ts +149 -0
  150. package/src/sql-model-datasource-strategy.ts +1 -1
  151. package/src/types.ts +17 -151
  152. /package/node_modules/{graphql-transformer-common → @aws-amplify/graphql-transformer-interfaces}/LICENSE +0 -0
package/lib/types.js CHANGED
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"","sourcesContent":["import { Duration, CfnResource, NestedStack } from 'aws-cdk-lib';\nimport {\n  CfnGraphQLApi,\n  CfnGraphQLSchema,\n  CfnApiKey,\n  CfnResolver,\n  CfnFunctionConfiguration,\n  CfnDataSource,\n  IGraphqlApi,\n  MappingTemplate,\n  BaseDataSource,\n  Code,\n  FunctionRuntime,\n} from 'aws-cdk-lib/aws-appsync';\nimport { CfnTable, ITable } from 'aws-cdk-lib/aws-dynamodb';\nimport { IRole, CfnRole } from 'aws-cdk-lib/aws-iam';\nimport { IUserPool } from 'aws-cdk-lib/aws-cognito';\nimport { IFunction, CfnFunction } from 'aws-cdk-lib/aws-lambda';\nimport { IBucket } from 'aws-cdk-lib/aws-s3';\nimport { AmplifyDynamoDbTableWrapper } from './amplify-dynamodb-table-wrapper';\n\n/**\n * Configuration for IAM Authorization on the Graphql Api.\n * @struct - required since this interface begins with an 'I'\n */\nexport interface IAMAuthorizationConfig {\n  /**\n   * ID for the Cognito Identity Pool vending auth and unauth roles.\n   * Format: `<region>:<id string>`\n   */\n  readonly identityPoolId: string;\n\n  /**\n   * Authenticated user role, applies to { provider: iam, allow: private } access.\n   */\n  readonly authenticatedUserRole: IRole;\n\n  /**\n   * Unauthenticated user role, applies to { provider: iam, allow: public } access.\n   */\n  readonly unauthenticatedUserRole: IRole;\n\n  /**\n   * A list of IAM roles which will be granted full read/write access to the generated model if IAM auth is enabled.\n   * If an IRole is provided, the role `name` will be used for matching.\n   * If a string is provided, the raw value will be used for matching.\n   */\n  readonly allowListedRoles?: (IRole | string)[];\n}\n\n/**\n * Configuration for Cognito UserPool Authorization on the Graphql Api.\n */\nexport interface UserPoolAuthorizationConfig {\n  /**\n   * The Cognito User Pool which is used to authenticated JWT tokens, and vends group and user information.\n   */\n  readonly userPool: IUserPool;\n}\n\n/**\n * Configuration for OpenId Connect Authorization on the Graphql Api.\n */\nexport interface OIDCAuthorizationConfig {\n  /**\n   * The issuer for the OIDC configuration.\n   */\n  readonly oidcProviderName: string;\n\n  /**\n   * Url for the OIDC token issuer.\n   */\n  readonly oidcIssuerUrl: string;\n\n  /**\n   * The client identifier of the Relying party at the OpenID identity provider.\n   * A regular expression can be specified so AppSync can validate against multiple client identifiers at a time. Example\n   */\n  readonly clientId?: string;\n\n  /**\n   * The duration an OIDC token is valid after being authenticated by OIDC provider.\n   * auth_time claim in OIDC token is required for this validation to work.\n   */\n  readonly tokenExpiryFromAuth: Duration;\n\n  /**\n   * The duration an OIDC token is valid after being issued to a user.\n   * This validation uses iat claim of OIDC token.\n   */\n  readonly tokenExpiryFromIssue: Duration;\n}\n\n/**\n * Configuration for Api Keys on the Graphql Api.\n */\nexport interface ApiKeyAuthorizationConfig {\n  /**\n   * Optional description for the Api Key to attach to the Api.\n   */\n  readonly description?: string;\n\n  /**\n   * A duration representing the time from Cloudformation deploy until expiry.\n   */\n  readonly expires: Duration;\n}\n\n/**\n * Configuration for Custom Lambda authorization on the Graphql Api.\n */\nexport interface LambdaAuthorizationConfig {\n  /**\n   * The authorizer lambda function.\n   */\n  readonly function: IFunction;\n\n  /**\n   * How long the results are cached.\n   */\n  readonly ttl: Duration;\n}\n\n/**\n * Authorization Modes to apply to the Api.\n * At least one modes must be provided, and if more than one are provided a defaultAuthorizationMode must be specified.\n * For more information on Amplify Api auth, refer to https://docs.amplify.aws/cli/graphql/authorization-rules/#authorization-strategies\n */\nexport interface AuthorizationModes {\n  /**\n   * Default auth mode to provide to the Api, required if more than one config type is specified.\n   */\n  readonly defaultAuthorizationMode?: 'AWS_IAM' | 'AMAZON_COGNITO_USER_POOLS' | 'OPENID_CONNECT' | 'API_KEY' | 'AWS_LAMBDA';\n\n  /**\n   * IAM Auth config, required if an 'iam' auth provider is specified in the Api.\n   * Applies to 'public' and 'private' auth strategies.\n   */\n  readonly iamConfig?: IAMAuthorizationConfig;\n\n  /**\n   * Cognito UserPool config, required if a 'userPools' auth provider is specified in the Api.\n   * Applies to 'owner', 'private', and 'group' auth strategies.\n   */\n  readonly userPoolConfig?: UserPoolAuthorizationConfig;\n\n  /**\n   * Cognito OIDC config, required if a 'oidc' auth provider is specified in the Api.\n   * Applies to 'owner', 'private', and 'group' auth strategies.\n   */\n  readonly oidcConfig?: OIDCAuthorizationConfig;\n\n  /**\n   * AppSync Api Key config, required if a 'apiKey' auth provider is specified in the Api.\n   * Applies to 'public' auth strategy.\n   */\n  readonly apiKeyConfig?: ApiKeyAuthorizationConfig;\n\n  /**\n   * Lambda config, required if a 'function' auth provider is specified in the Api.\n   * Applies to 'custom' auth strategy.\n   */\n  readonly lambdaConfig?: LambdaAuthorizationConfig;\n\n  /**\n   * A list of roles granted full R/W access to the Api.\n   * @deprecated, use iamConfig.allowListedRoles instead.\n   */\n  readonly adminRoles?: IRole[];\n}\n\n/**\n * Whether or not to use a version field to track conflict detection.\n */\nexport type ConflictDetectionType = 'VERSION' | 'NONE';\n\n/**\n * Common parameters for conflict resolution.\n */\nexport interface ConflictResolutionStrategyBase {\n  /**\n   * The conflict detection type used for resolution.\n   */\n  readonly detectionType: ConflictDetectionType;\n}\n\n/**\n * Enable optimistic concurrency on the project.\n */\nexport interface AutomergeConflictResolutionStrategy extends ConflictResolutionStrategyBase {\n  /**\n   * This conflict resolution strategy executes an auto-merge.\n   * For more information, refer to https://docs.aws.amazon.com/appsync/latest/devguide/conflict-detection-and-sync.html#conflict-detection-and-resolution\n   */\n  readonly handlerType: 'AUTOMERGE';\n}\n\n/**\n * Enable automerge on the project.\n */\nexport interface OptimisticConflictResolutionStrategy extends ConflictResolutionStrategyBase {\n  /**\n   * This conflict resolution strategy the _version to perform optimistic concurrency.\n   * For more information, refer to https://docs.aws.amazon.com/appsync/latest/devguide/conflict-detection-and-sync.html#conflict-detection-and-resolution\n   */\n  readonly handlerType: 'OPTIMISTIC_CONCURRENCY';\n}\n\n/**\n * Enable custom sync on the project, powered by a lambda.\n */\nexport interface CustomConflictResolutionStrategy extends ConflictResolutionStrategyBase {\n  /**\n   * This conflict resolution strategy uses a lambda handler type.\n   * For more information, refer to https://docs.aws.amazon.com/appsync/latest/devguide/conflict-detection-and-sync.html#conflict-detection-and-resolution\n\n   */\n  readonly handlerType: 'LAMBDA';\n\n  /**\n   * The function which will be invoked for conflict resolution.\n   */\n  readonly conflictHandler: IFunction;\n}\n\n/**\n * Conflict Resolution Strategy to apply to the project or a particular model.\n */\nexport type ConflictResolutionStrategy =\n  | AutomergeConflictResolutionStrategy\n  | OptimisticConflictResolutionStrategy\n  | CustomConflictResolutionStrategy;\n\n/**\n * Project level configuration for conflict resolution.\n */\nexport interface ConflictResolution {\n  /**\n   * Project-wide config for conflict resolution. Applies to all non-overridden models.\n   */\n  readonly project?: ConflictResolutionStrategy;\n\n  /**\n   * Model-specific conflict resolution overrides.\n   */\n  readonly models?: Record<string, ConflictResolutionStrategy>;\n}\n\n/**\n * Params exposed to support configuring and overriding pipelined slots. This allows configuration of the underlying function,\n * including the request and response mapping templates.\n */\nexport interface FunctionSlotOverride {\n  /**\n   * Override request mapping template for the function slot. Executed before the datasource is invoked.\n   */\n  readonly requestMappingTemplate?: MappingTemplate;\n\n  /**\n   * Override response mapping template for the function slot. Executed after the datasource is invoked.\n   */\n  readonly responseMappingTemplate?: MappingTemplate;\n}\n\n/**\n * Common slot parameters.\n */\nexport interface FunctionSlotBase {\n  /**\n   * The field to attach this function to on the Api definition.\n   */\n  readonly fieldName: string;\n\n  /**\n   * The slot index to use to inject this into the execution pipeline.\n   * For more information on slotting, refer to https://docs.amplify.aws/cli/graphql/custom-business-logic/#extend-amplify-generated-resolvers\n   */\n  readonly slotIndex: number;\n\n  /**\n   * The overridden behavior for this slot.\n   */\n  readonly function: FunctionSlotOverride;\n}\n\n/**\n * Slot types for Mutation Resolvers.\n */\nexport interface MutationFunctionSlot extends FunctionSlotBase {\n  /**\n   * This slot type applies to the Mutation type on the Api definition.\n   */\n  readonly typeName: 'Mutation';\n\n  /**\n   * The slot name to inject this behavior into.\n   * For more information on slotting, refer to https://docs.amplify.aws/cli/graphql/custom-business-logic/#extend-amplify-generated-resolvers\n   */\n  readonly slotName: 'init' | 'preAuth' | 'auth' | 'postAuth' | 'preUpdate' | 'postUpdate' | 'finish';\n}\n\n/**\n * Slot types for Query Resolvers.\n */\nexport interface QueryFunctionSlot extends FunctionSlotBase {\n  /**\n   * This slot type applies to the Query type on the Api definition.\n   */\n  readonly typeName: 'Query';\n\n  /**\n   * The slot name to inject this behavior into.\n   * For more information on slotting, refer to https://docs.amplify.aws/cli/graphql/custom-business-logic/#extend-amplify-generated-resolvers\n   */\n  readonly slotName: 'init' | 'preAuth' | 'auth' | 'postAuth' | 'preDataLoad' | 'postDataLoad' | 'finish';\n}\n\n/**\n * Slot types for Subscription Resolvers.\n */\nexport interface SubscriptionFunctionSlot extends FunctionSlotBase {\n  /**\n   * This slot type applies to the Subscription type on the Api definition.\n   */\n  readonly typeName: 'Subscription';\n\n  /**\n   * The slot name to inject this behavior into.\n   * For more information on slotting, refer to https://docs.amplify.aws/cli/graphql/custom-business-logic/#extend-amplify-generated-resolvers\n   */\n  readonly slotName: 'init' | 'preAuth' | 'auth' | 'postAuth' | 'preSubscribe';\n}\n\n/**\n * Input params to uniquely identify the slot which is being overridden.\n */\nexport type FunctionSlot = MutationFunctionSlot | QueryFunctionSlot | SubscriptionFunctionSlot;\n\n/**\n * Strongly typed set of shared parameters for all transformers, and core layer.\n * This is intended to replace feature flags, to ensure param coercion happens in\n * a single location, and isn't spread around the transformers, where they can\n * have different default behaviors.\n */\nexport interface TranslationBehavior {\n  /**\n   * Restore parity w/ GQLv1 @model parameter behavior, where setting a single field doesn't implicitly set the other fields to null.\n   * @default true\n   */\n  readonly shouldDeepMergeDirectiveConfigDefaults: boolean;\n\n  /**\n   * Disable resolver deduping, this can sometimes cause problems because dedupe ordering isn't stable today, which can\n   * lead to circular dependencies across stacks if models are reordered.\n   * @default true\n   */\n  readonly disableResolverDeduping: boolean;\n\n  /**\n   * Enabling sandbox mode will enable api key auth on all models in the transformed schema.\n   * @default false\n   */\n  readonly sandboxModeEnabled: boolean;\n\n  /**\n   * Ensure that oidc and userPool auth use the `sub` field in the for the username field, which disallows new users with the same\n   * id to access data from a deleted user in the pool.\n   * @default true\n   */\n  readonly useSubUsernameForDefaultIdentityClaim: boolean;\n\n  /**\n   * Ensure that the owner field is still populated even if a static iam or group authorization applies.\n   * @default true\n   */\n  readonly populateOwnerFieldForStaticGroupAuth: boolean;\n\n  /**\n   * If enabled, disable api key resource generation even if specified as an auth rule on the construct.\n   * This is a legacy parameter from the Graphql Transformer existing in Amplify CLI, not recommended to change.\n   * @default false\n   */\n  readonly suppressApiKeyGeneration: boolean;\n\n  /**\n   * If disabled, generated @index as an LSI instead of a GSI.\n   * @default true\n   */\n  readonly secondaryKeyAsGSI: boolean;\n\n  /**\n   * Automate generation of query names, and as a result attaching all indexes as queries to the generated Api.\n   * If enabled, @index can be provided a null name field to disable the generation of the query on the Api.\n   * @default true\n   */\n  readonly enableAutoIndexQueryNames: boolean;\n\n  /**\n   * Enable custom primary key support, there's no good reason to disable this unless trying not to update a legacy app.\n   * @default true\n   */\n  readonly respectPrimaryKeyAttributesOnConnectionField: boolean;\n\n  readonly enableSearchNodeToNodeEncryption: boolean;\n\n  /**\n   * When enabled, internal cfn outputs which existed in Amplify-generated apps will continue to be emitted.\n   * @default false\n   */\n  readonly enableTransformerCfnOutputs: boolean;\n\n  /**\n   * The following schema updates require replacement of the underlying DynamoDB table:\n   *\n   *  - Removing or renaming a model\n   *  - Modifying the primary key of a model\n   *  - Modifying a Local Secondary Index of a model (only applies to projects with secondaryKeyAsGSI turned off)\n   *\n   * ALL DATA WILL BE LOST when the table replacement happens. When enabled, destructive updates are allowed.\n   * This will only affect DynamoDB tables with provision strategy \"AMPLIFY_TABLE\".\n   * @default false\n   * @experimental\n   */\n  readonly allowDestructiveGraphqlSchemaUpdates: boolean;\n\n  /**\n   * This behavior will only come into effect when both \"allowDestructiveGraphqlSchemaUpdates\" and this value are set to true\n   * When enabled, any GSI update operation will replace the table instead of iterative deployment, which will WIPE ALL EXISTING DATA but cost much less time for deployment\n   * This will only affect DynamoDB tables with provision strategy \"AMPLIFY_TABLE\".\n   * @default false\n   * @experimental\n   */\n  readonly replaceTableUponGsiUpdate: boolean;\n}\n\n/**\n * A utility interface equivalent to Partial<TranslationBehavior>.\n */\nexport interface PartialTranslationBehavior {\n  /**\n   * Restore parity w/ GQLv1 @model parameter behavior, where setting a single field doesn't implicitly set the other fields to null.\n   * @default true\n   */\n  readonly shouldDeepMergeDirectiveConfigDefaults?: boolean;\n\n  /**\n   * Disable resolver deduping, this can sometimes cause problems because dedupe ordering isn't stable today, which can\n   * lead to circular dependencies across stacks if models are reordered.\n   * @default true\n   */\n  readonly disableResolverDeduping?: boolean;\n\n  /**\n   * Enabling sandbox mode will enable api key auth on all models in the transformed schema.\n   * @default false\n   */\n  readonly sandboxModeEnabled?: boolean;\n\n  /**\n   * Ensure that oidc and userPool auth use the `sub` field in the for the username field, which disallows new users with the same\n   * id to access data from a deleted user in the pool.\n   * @default true\n   */\n  readonly useSubUsernameForDefaultIdentityClaim?: boolean;\n\n  /**\n   * Ensure that the owner field is still populated even if a static iam or group authorization applies.\n   * @default true\n   */\n  readonly populateOwnerFieldForStaticGroupAuth?: boolean;\n\n  /**\n   * If enabled, disable api key resource generation even if specified as an auth rule on the construct.\n   * This is a legacy parameter from the Graphql Transformer existing in Amplify CLI, not recommended to change.\n   * @default false\n   */\n  readonly suppressApiKeyGeneration?: boolean;\n\n  /**\n   * If disabled, generated @index as an LSI instead of a GSI.\n   * @default true\n   */\n  readonly secondaryKeyAsGSI?: boolean;\n\n  /**\n   * Automate generation of query names, and as a result attaching all indexes as queries to the generated Api.\n   * If enabled, @index can be provided a null name field to disable the generation of the query on the Api.\n   * @default true\n   */\n  readonly enableAutoIndexQueryNames?: boolean;\n\n  /**\n   * Enable custom primary key support, there's no good reason to disable this unless trying not to update a legacy app.\n   * @default true\n   */\n  readonly respectPrimaryKeyAttributesOnConnectionField?: boolean;\n\n  /**\n   * If enabled, set nodeToNodeEncryption on the searchable domain (if one exists). Not recommended for use, prefer\n   * to use `Object.values(resources.additionalResources['AWS::Elasticsearch::Domain']).forEach((domain: CfnDomain) => {\n   *   domain.NodeToNodeEncryptionOptions = { Enabled: True };\n   * });\n   * @default false\n   */\n  readonly enableSearchNodeToNodeEncryption?: boolean;\n\n  /**\n   * When enabled, internal cfn outputs which existed in Amplify-generated apps will continue to be emitted.\n   * @default false\n   */\n  readonly enableTransformerCfnOutputs?: boolean;\n\n  /**\n   * The following schema updates require replacement of the underlying DynamoDB table:\n   *\n   *  - Removing or renaming a model\n   *  - Modifying the primary key of a model\n   *  - Modifying a Local Secondary Index of a model (only applies to projects with secondaryKeyAsGSI turned off)\n   *\n   * ALL DATA WILL BE LOST when the table replacement happens. When enabled, destructive updates are allowed.\n   * This will only affect DynamoDB tables with provision strategy \"AMPLIFY_TABLE\".\n   * @default false\n   * @experimental\n   */\n  readonly allowDestructiveGraphqlSchemaUpdates?: boolean;\n\n  /**\n   * This behavior will only come into effect when both \"allowDestructiveGraphqlSchemaUpdates\" and this value are set to true\n   * When enabled, any global secondary index update operation will replace the table instead of iterative deployment, which will WIPE ALL EXISTING DATA but cost much less time for deployment\n   * This will only affect DynamoDB tables with provision strategy \"AMPLIFY_TABLE\".\n   * @default false\n   * @experimental\n   */\n  readonly replaceTableUponGsiUpdate?: boolean;\n}\n\n/**\n * Graphql Api definition, which can be implemented in multiple ways.\n */\nexport interface IAmplifyGraphqlDefinition {\n  /**\n   * Return the schema definition as a graphql string, with amplify directives allowed.\n   * @returns the rendered schema.\n   */\n  readonly schema: string;\n\n  /**\n   * Retrieve any function slots defined explicitly in the Api definition.\n   * @returns generated function slots\n   */\n  readonly functionSlots: FunctionSlot[];\n\n  /**\n   * Retrieve the references to any lambda functions used in the definition.\n   * Useful for wiring through aws_lambda.Function constructs into the definition directly,\n   * and generated references to invoke them.\n   * @returns any lambda functions, keyed by their referenced 'name' in the generated schema.\n   */\n  readonly referencedLambdaFunctions?: Record<string, IFunction>;\n\n  /**\n   * Retrieve the datasource strategy mapping. The default strategy is to use DynamoDB from CloudFormation.\n   *\n   * **NOTE** Explicitly specifying the 'dataSourceStrategies' configuration option is in preview and is not recommended to use with\n   * production systems. For production, use the static factory methods `fromString` or `fromFiles`.\n   * @experimental\n   * @returns datasource strategy mapping\n   */\n  readonly dataSourceStrategies: Record<string, ModelDataSourceStrategy>;\n}\n\n/**\n * Entry representing the required output from the backend for codegen generate commands to work.\n */\nexport interface IBackendOutputEntry {\n  /**\n   * The protocol version for this backend output.\n   */\n  readonly version: string;\n\n  /**\n   * The string-map payload of generated config values.\n   */\n  readonly payload: Record<string, string>;\n}\n\n/**\n * Backend output strategy used to write config required for codegen tasks.\n */\nexport interface IBackendOutputStorageStrategy {\n  /**\n   * Add an entry to backend output.\n   * @param keyName the key\n   * @param backendOutputEntry the record to store in the backend output\n   */\n  // eslint-disable-next-line @typescript-eslint/method-signature-style\n  addBackendOutputEntry(keyName: string, backendOutputEntry: IBackendOutputEntry): void;\n}\n\n/**\n * Input props for the AmplifyGraphqlApi construct. Specifies what the input to transform into an Api, and configurations for\n * the transformation process.\n */\nexport interface AmplifyGraphqlApiProps {\n  /**\n   * The definition to transform in a full Api.\n   * Can be constructed via the AmplifyGraphqlDefinition class.\n   */\n  readonly definition: IAmplifyGraphqlDefinition;\n\n  /**\n   * Name to be used for the AppSync Api.\n   * Default: construct id.\n   */\n  readonly apiName?: string;\n\n  /**\n   * Required auth modes for the Api. This object must be a superset of the configured auth providers in the Api definition.\n   * For more information, refer to https://docs.amplify.aws/cli/graphql/authorization-rules/\n   */\n  readonly authorizationModes: AuthorizationModes;\n\n  /**\n   * Lambda functions referenced in the definitions's @function directives. The keys of this object are expected to be the\n   * function name provided in the definition, and value is the function that name refers to. If a name is not found in this\n   * map, then it is interpreted as the `functionName`, and an arn will be constructed using the current aws account and region\n   * (or overridden values, if set in the directive).\n   */\n  readonly functionNameMap?: Record<string, IFunction>;\n\n  /**\n   * Configure conflict resolution on the Api, which is required to enable DataStore Api functionality.\n   * For more information, refer to https://docs.amplify.aws/lib/datastore/getting-started/q/platform/js/\n   */\n  readonly conflictResolution?: ConflictResolution;\n\n  /**\n   * StackMappings override the assigned nested stack on a per-resource basis. Only applies to resolvers, and takes the form\n   * { <logicalId>: <stackName> }\n   * It is not recommended to use this parameter unless you are encountering stack resource count limits, and worth noting that\n   * after initial deployment AppSync resolvers cannot be moved between nested stacks, they will need to be removed from the app,\n   * then re-added from a new stack.\n   */\n  readonly stackMappings?: Record<string, string>;\n\n  /**\n   * Overrides for a given slot in the generated resolver pipelines. For more information about what slots are available,\n   * refer to https://docs.amplify.aws/cli/graphql/custom-business-logic/#override-amplify-generated-resolvers.\n   */\n  readonly functionSlots?: FunctionSlot[];\n\n  /**\n   * Provide a list of additional custom transformers which are injected into the transform process.\n   * These custom transformers must be implemented with aws-cdk-lib >=2.80.0, and @aws-amplify/graphql-transformer-core >= 2.1.1\n   * @experimental\n   */\n  readonly transformerPlugins?: any[];\n\n  /**\n   * If using predictions, a bucket must be provided which will be used to search for assets.\n   */\n  readonly predictionsBucket?: IBucket;\n\n  /**\n   * This replaces feature flags from the Api construct, for general information on what these parameters do,\n   * refer to https://docs.amplify.aws/cli/reference/feature-flags/#graphQLTransformer\n   */\n  readonly translationBehavior?: PartialTranslationBehavior;\n\n  /**\n   * Strategy to store construct outputs. If no outputStorageStrategey is provided a default strategy will be used.\n   */\n  readonly outputStorageStrategy?: IBackendOutputStorageStrategy;\n}\n\n/**\n * L1 CDK resources from the Api which were generated as part of the transform.\n * These are potentially stored under nested stacks, but presented organized by type instead.\n */\nexport interface AmplifyGraphqlApiCfnResources {\n  /**\n   * The Generated AppSync Api L1 Resource\n   */\n  readonly cfnGraphqlApi: CfnGraphQLApi;\n\n  /**\n   * The Generated AppSync Schema L1 Resource\n   */\n  readonly cfnGraphqlSchema: CfnGraphQLSchema;\n\n  /**\n   * The Generated AppSync Api Key L1 Resource\n   */\n  readonly cfnApiKey?: CfnApiKey;\n\n  /**\n   * The Generated AppSync Resolver L1 Resources, keyed by logicalId.\n   */\n  readonly cfnResolvers: Record<string, CfnResolver>;\n\n  /**\n   * The Generated AppSync Function L1 Resources, keyed by logicalId.\n   */\n  readonly cfnFunctionConfigurations: Record<string, CfnFunctionConfiguration>;\n\n  /**\n   * The Generated AppSync DataSource L1 Resources, keyed by logicalId.\n   */\n  readonly cfnDataSources: Record<string, CfnDataSource>;\n\n  /**\n   * The Generated DynamoDB Table L1 Resources, keyed by logicalId.\n   */\n  readonly cfnTables: Record<string, CfnTable>;\n\n  /**\n   * The Generated IAM Role L1 Resources, keyed by logicalId.\n   */\n  readonly cfnRoles: Record<string, CfnRole>;\n\n  /**\n   * The Generated Lambda Function L1 Resources, keyed by function name.\n   */\n  readonly cfnFunctions: Record<string, CfnFunction>;\n\n  /**\n   * Remaining L1 resources generated, keyed by logicalId.\n   */\n  readonly additionalCfnResources: Record<string, CfnResource>;\n}\n\n/**\n * Accessible resources from the Api which were generated as part of the transform.\n * These are potentially stored under nested stacks, but presented organized by type instead.\n */\nexport interface AmplifyGraphqlApiResources {\n  /**\n   * The Generated AppSync Api L2 Resource, includes the Schema.\n   */\n  readonly graphqlApi: IGraphqlApi;\n\n  /**\n   * The Generated DynamoDB Table L2 Resources, keyed by logicalId.\n   */\n  readonly tables: Record<string, ITable>;\n\n  /**\n   * The Generated Amplify DynamoDb Table wrapped if produced, keyed by name.\n   */\n  readonly amplifyDynamoDbTables: Record<string, AmplifyDynamoDbTableWrapper>;\n\n  /**\n   * The Generated IAM Role L2 Resources, keyed by logicalId.\n   */\n  readonly roles: Record<string, IRole>;\n\n  /**\n   * The Generated Lambda Function L1 Resources, keyed by function name.\n   */\n  readonly functions: Record<string, IFunction>;\n\n  /**\n   * L1 Cfn Resources, for when dipping down a level of abstraction is desirable.\n   */\n  readonly cfnResources: AmplifyGraphqlApiCfnResources;\n\n  /**\n   * Nested Stacks generated by the Api Construct.\n   */\n  readonly nestedStacks: Record<string, NestedStack>;\n}\n\n/**\n * Input type properties when adding a new appsync.AppsyncFunction to the generated API.\n * This is equivalent to the Omit<appsync.AppsyncFunctionProps, 'api'>.\n */\nexport interface AddFunctionProps {\n  /**\n   * the data source linked to this AppSync Function\n   */\n  readonly dataSource: BaseDataSource;\n\n  /**\n   * the name of the AppSync Function\n   */\n  readonly name: string;\n\n  /**\n   * the description for this AppSync Function\n   *\n   * @default - no description\n   */\n  readonly description?: string;\n\n  /**\n   * the request mapping template for the AppSync Function\n   *\n   * @default - no request mapping template\n   */\n  readonly requestMappingTemplate?: MappingTemplate;\n\n  /**\n   * the response mapping template for the AppSync Function\n   *\n   * @default - no response mapping template\n   */\n  readonly responseMappingTemplate?: MappingTemplate;\n\n  /**\n   * The functions runtime\n   *\n   * @default - no function runtime, VTL mapping templates used\n   */\n  readonly runtime?: FunctionRuntime;\n\n  /**\n   * The function code\n   *\n   * @default - no code is used\n   */\n  readonly code?: Code;\n}\n\n/**\n * All known ModelDataSourceStrategies. Concrete strategies vary widely in their requirements and implementations.\n * @experimental\n */\nexport type ModelDataSourceStrategy =\n  | DefaultDynamoDbModelDataSourceStrategy\n  | AmplifyDynamoDbModelDataSourceStrategy\n  | SQLLambdaModelDataSourceStrategy;\n\n// TODO: Make this the source of truth for database type definitions used throughout the construct & transformer\nexport type ModelDataSourceStrategyDbType = 'DYNAMODB';\n\n/**\n * Use default CloudFormation type 'AWS::DynamoDB::Table' to provision table.\n * @experimental\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 * @experimental\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 *\n * @experimental\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: 'MYSQL' | 'POSTGRES';\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   * An optional override for the default SQL Lambda Layer\n   */\n  readonly sqlLambdaLayerMapping?: SQLLambdaLayerMapping;\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 * @experimental\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 * @experimental\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 * @experimental\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 * Maps a given AWS region to the SQL Lambda layer version ARN for that region. `key` is the region; the `value` is the Lambda Layer version\n * ARN\n */\nexport type SQLLambdaLayerMapping = Record<string, string>;\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 * @experimental\n */\nexport interface SqlModelDataSourceDbConnectionConfig {\n  /** The Secure Systems Manager parameter containing the hostname of the database. For RDS-based SQL data sources, this can be the hostname\n   * of a database proxy, cluster, or instance.\n   */\n  readonly hostnameSsmPath: string;\n\n  /** The Secure Systems Manager parameter containing the port number of the database proxy, cluster, or instance. */\n  readonly portSsmPath: string;\n\n  /** The Secure Systems Manager parameter containing the username to use when connecting to the database. */\n  readonly usernameSsmPath: string;\n\n  /** The Secure Systems Manager parameter containing the password to use when connecting to the database. */\n  readonly passwordSsmPath: string;\n\n  /** The Secure Systems Manager parameter containing the database name. */\n  readonly databaseNameSsmPath: string;\n}\n"]}
3
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"","sourcesContent":["import { Duration, CfnResource, NestedStack } from 'aws-cdk-lib';\nimport {\n  CfnGraphQLApi,\n  CfnGraphQLSchema,\n  CfnApiKey,\n  CfnResolver,\n  CfnFunctionConfiguration,\n  CfnDataSource,\n  IGraphqlApi,\n  MappingTemplate,\n  BaseDataSource,\n  Code,\n  FunctionRuntime,\n} from 'aws-cdk-lib/aws-appsync';\nimport { CfnTable, ITable } from 'aws-cdk-lib/aws-dynamodb';\nimport { IRole, CfnRole } from 'aws-cdk-lib/aws-iam';\nimport { IUserPool } from 'aws-cdk-lib/aws-cognito';\nimport { IFunction, CfnFunction } from 'aws-cdk-lib/aws-lambda';\nimport { IBucket } from 'aws-cdk-lib/aws-s3';\nimport { AmplifyDynamoDbTableWrapper } from './amplify-dynamodb-table-wrapper';\nimport { CustomSqlDataSourceStrategy, ModelDataSourceStrategy } from './model-datasource-strategy';\n\n/**\n * Configuration for IAM Authorization on the Graphql Api.\n * @struct - required since this interface begins with an 'I'\n */\nexport interface IAMAuthorizationConfig {\n  /**\n   * ID for the Cognito Identity Pool vending auth and unauth roles.\n   * Format: `<region>:<id string>`\n   */\n  readonly identityPoolId: string;\n\n  /**\n   * Authenticated user role, applies to { provider: iam, allow: private } access.\n   */\n  readonly authenticatedUserRole: IRole;\n\n  /**\n   * Unauthenticated user role, applies to { provider: iam, allow: public } access.\n   */\n  readonly unauthenticatedUserRole: IRole;\n\n  /**\n   * A list of IAM roles which will be granted full read/write access to the generated model if IAM auth is enabled.\n   * If an IRole is provided, the role `name` will be used for matching.\n   * If a string is provided, the raw value will be used for matching.\n   */\n  readonly allowListedRoles?: (IRole | string)[];\n}\n\n/**\n * Configuration for Cognito UserPool Authorization on the Graphql Api.\n */\nexport interface UserPoolAuthorizationConfig {\n  /**\n   * The Cognito User Pool which is used to authenticated JWT tokens, and vends group and user information.\n   */\n  readonly userPool: IUserPool;\n}\n\n/**\n * Configuration for OpenId Connect Authorization on the Graphql Api.\n */\nexport interface OIDCAuthorizationConfig {\n  /**\n   * The issuer for the OIDC configuration.\n   */\n  readonly oidcProviderName: string;\n\n  /**\n   * Url for the OIDC token issuer.\n   */\n  readonly oidcIssuerUrl: string;\n\n  /**\n   * The client identifier of the Relying party at the OpenID identity provider.\n   * A regular expression can be specified so AppSync can validate against multiple client identifiers at a time. Example\n   */\n  readonly clientId?: string;\n\n  /**\n   * The duration an OIDC token is valid after being authenticated by OIDC provider.\n   * auth_time claim in OIDC token is required for this validation to work.\n   */\n  readonly tokenExpiryFromAuth: Duration;\n\n  /**\n   * The duration an OIDC token is valid after being issued to a user.\n   * This validation uses iat claim of OIDC token.\n   */\n  readonly tokenExpiryFromIssue: Duration;\n}\n\n/**\n * Configuration for Api Keys on the Graphql Api.\n */\nexport interface ApiKeyAuthorizationConfig {\n  /**\n   * Optional description for the Api Key to attach to the Api.\n   */\n  readonly description?: string;\n\n  /**\n   * A duration representing the time from Cloudformation deploy until expiry.\n   */\n  readonly expires: Duration;\n}\n\n/**\n * Configuration for Custom Lambda authorization on the Graphql Api.\n */\nexport interface LambdaAuthorizationConfig {\n  /**\n   * The authorizer lambda function.\n   */\n  readonly function: IFunction;\n\n  /**\n   * How long the results are cached.\n   */\n  readonly ttl: Duration;\n}\n\n/**\n * Authorization Modes to apply to the Api.\n * At least one modes must be provided, and if more than one are provided a defaultAuthorizationMode must be specified.\n * For more information on Amplify Api auth, refer to https://docs.amplify.aws/cli/graphql/authorization-rules/#authorization-strategies\n */\nexport interface AuthorizationModes {\n  /**\n   * Default auth mode to provide to the Api, required if more than one config type is specified.\n   */\n  readonly defaultAuthorizationMode?: 'AWS_IAM' | 'AMAZON_COGNITO_USER_POOLS' | 'OPENID_CONNECT' | 'API_KEY' | 'AWS_LAMBDA';\n\n  /**\n   * IAM Auth config, required if an 'iam' auth provider is specified in the Api.\n   * Applies to 'public' and 'private' auth strategies.\n   */\n  readonly iamConfig?: IAMAuthorizationConfig;\n\n  /**\n   * Cognito UserPool config, required if a 'userPools' auth provider is specified in the Api.\n   * Applies to 'owner', 'private', and 'group' auth strategies.\n   */\n  readonly userPoolConfig?: UserPoolAuthorizationConfig;\n\n  /**\n   * Cognito OIDC config, required if a 'oidc' auth provider is specified in the Api.\n   * Applies to 'owner', 'private', and 'group' auth strategies.\n   */\n  readonly oidcConfig?: OIDCAuthorizationConfig;\n\n  /**\n   * AppSync Api Key config, required if a 'apiKey' auth provider is specified in the Api.\n   * Applies to 'public' auth strategy.\n   */\n  readonly apiKeyConfig?: ApiKeyAuthorizationConfig;\n\n  /**\n   * Lambda config, required if a 'function' auth provider is specified in the Api.\n   * Applies to 'custom' auth strategy.\n   */\n  readonly lambdaConfig?: LambdaAuthorizationConfig;\n\n  /**\n   * A list of roles granted full R/W access to the Api.\n   * @deprecated, use iamConfig.allowListedRoles instead.\n   */\n  readonly adminRoles?: IRole[];\n}\n\n/**\n * Whether or not to use a version field to track conflict detection.\n */\nexport type ConflictDetectionType = 'VERSION' | 'NONE';\n\n/**\n * Common parameters for conflict resolution.\n */\nexport interface ConflictResolutionStrategyBase {\n  /**\n   * The conflict detection type used for resolution.\n   */\n  readonly detectionType: ConflictDetectionType;\n}\n\n/**\n * Enable optimistic concurrency on the project.\n */\nexport interface AutomergeConflictResolutionStrategy extends ConflictResolutionStrategyBase {\n  /**\n   * This conflict resolution strategy executes an auto-merge.\n   * For more information, refer to https://docs.aws.amazon.com/appsync/latest/devguide/conflict-detection-and-sync.html#conflict-detection-and-resolution\n   */\n  readonly handlerType: 'AUTOMERGE';\n}\n\n/**\n * Enable automerge on the project.\n */\nexport interface OptimisticConflictResolutionStrategy extends ConflictResolutionStrategyBase {\n  /**\n   * This conflict resolution strategy the _version to perform optimistic concurrency.\n   * For more information, refer to https://docs.aws.amazon.com/appsync/latest/devguide/conflict-detection-and-sync.html#conflict-detection-and-resolution\n   */\n  readonly handlerType: 'OPTIMISTIC_CONCURRENCY';\n}\n\n/**\n * Enable custom sync on the project, powered by a lambda.\n */\nexport interface CustomConflictResolutionStrategy extends ConflictResolutionStrategyBase {\n  /**\n   * This conflict resolution strategy uses a lambda handler type.\n   * For more information, refer to https://docs.aws.amazon.com/appsync/latest/devguide/conflict-detection-and-sync.html#conflict-detection-and-resolution\n\n   */\n  readonly handlerType: 'LAMBDA';\n\n  /**\n   * The function which will be invoked for conflict resolution.\n   */\n  readonly conflictHandler: IFunction;\n}\n\n/**\n * Conflict Resolution Strategy to apply to the project or a particular model.\n */\nexport type ConflictResolutionStrategy =\n  | AutomergeConflictResolutionStrategy\n  | OptimisticConflictResolutionStrategy\n  | CustomConflictResolutionStrategy;\n\n/**\n * Project level configuration for conflict resolution.\n */\nexport interface ConflictResolution {\n  /**\n   * Project-wide config for conflict resolution. Applies to all non-overridden models.\n   */\n  readonly project?: ConflictResolutionStrategy;\n\n  /**\n   * Model-specific conflict resolution overrides.\n   */\n  readonly models?: Record<string, ConflictResolutionStrategy>;\n}\n\n/**\n * Params exposed to support configuring and overriding pipelined slots. This allows configuration of the underlying function,\n * including the request and response mapping templates.\n */\nexport interface FunctionSlotOverride {\n  /**\n   * Override request mapping template for the function slot. Executed before the datasource is invoked.\n   */\n  readonly requestMappingTemplate?: MappingTemplate;\n\n  /**\n   * Override response mapping template for the function slot. Executed after the datasource is invoked.\n   */\n  readonly responseMappingTemplate?: MappingTemplate;\n}\n\n/**\n * Common slot parameters.\n */\nexport interface FunctionSlotBase {\n  /**\n   * The field to attach this function to on the Api definition.\n   */\n  readonly fieldName: string;\n\n  /**\n   * The slot index to use to inject this into the execution pipeline.\n   * For more information on slotting, refer to https://docs.amplify.aws/cli/graphql/custom-business-logic/#extend-amplify-generated-resolvers\n   */\n  readonly slotIndex: number;\n\n  /**\n   * The overridden behavior for this slot.\n   */\n  readonly function: FunctionSlotOverride;\n}\n\n/**\n * Slot types for Mutation Resolvers.\n */\nexport interface MutationFunctionSlot extends FunctionSlotBase {\n  /**\n   * This slot type applies to the Mutation type on the Api definition.\n   */\n  readonly typeName: 'Mutation';\n\n  /**\n   * The slot name to inject this behavior into.\n   * For more information on slotting, refer to https://docs.amplify.aws/cli/graphql/custom-business-logic/#extend-amplify-generated-resolvers\n   */\n  readonly slotName: 'init' | 'preAuth' | 'auth' | 'postAuth' | 'preUpdate' | 'postUpdate' | 'finish';\n}\n\n/**\n * Slot types for Query Resolvers.\n */\nexport interface QueryFunctionSlot extends FunctionSlotBase {\n  /**\n   * This slot type applies to the Query type on the Api definition.\n   */\n  readonly typeName: 'Query';\n\n  /**\n   * The slot name to inject this behavior into.\n   * For more information on slotting, refer to https://docs.amplify.aws/cli/graphql/custom-business-logic/#extend-amplify-generated-resolvers\n   */\n  readonly slotName: 'init' | 'preAuth' | 'auth' | 'postAuth' | 'preDataLoad' | 'postDataLoad' | 'finish';\n}\n\n/**\n * Slot types for Subscription Resolvers.\n */\nexport interface SubscriptionFunctionSlot extends FunctionSlotBase {\n  /**\n   * This slot type applies to the Subscription type on the Api definition.\n   */\n  readonly typeName: 'Subscription';\n\n  /**\n   * The slot name to inject this behavior into.\n   * For more information on slotting, refer to https://docs.amplify.aws/cli/graphql/custom-business-logic/#extend-amplify-generated-resolvers\n   */\n  readonly slotName: 'init' | 'preAuth' | 'auth' | 'postAuth' | 'preSubscribe';\n}\n\n/**\n * Input params to uniquely identify the slot which is being overridden.\n */\nexport type FunctionSlot = MutationFunctionSlot | QueryFunctionSlot | SubscriptionFunctionSlot;\n\n/**\n * Strongly typed set of shared parameters for all transformers, and core layer.\n * This is intended to replace feature flags, to ensure param coercion happens in\n * a single location, and isn't spread around the transformers, where they can\n * have different default behaviors.\n */\nexport interface TranslationBehavior {\n  /**\n   * Restore parity w/ GQLv1 @model parameter behavior, where setting a single field doesn't implicitly set the other fields to null.\n   * @default true\n   */\n  readonly shouldDeepMergeDirectiveConfigDefaults: boolean;\n\n  /**\n   * Disable resolver deduping, this can sometimes cause problems because dedupe ordering isn't stable today, which can\n   * lead to circular dependencies across stacks if models are reordered.\n   * @default true\n   */\n  readonly disableResolverDeduping: boolean;\n\n  /**\n   * Enabling sandbox mode will enable api key auth on all models in the transformed schema.\n   * @default false\n   */\n  readonly sandboxModeEnabled: boolean;\n\n  /**\n   * Ensure that oidc and userPool auth use the `sub` field in the for the username field, which disallows new users with the same\n   * id to access data from a deleted user in the pool.\n   * @default true\n   */\n  readonly useSubUsernameForDefaultIdentityClaim: boolean;\n\n  /**\n   * Ensure that the owner field is still populated even if a static iam or group authorization applies.\n   * @default true\n   */\n  readonly populateOwnerFieldForStaticGroupAuth: boolean;\n\n  /**\n   * If enabled, disable api key resource generation even if specified as an auth rule on the construct.\n   * This is a legacy parameter from the Graphql Transformer existing in Amplify CLI, not recommended to change.\n   * @default false\n   */\n  readonly suppressApiKeyGeneration: boolean;\n\n  /**\n   * If disabled, generated @index as an LSI instead of a GSI.\n   * @default true\n   */\n  readonly secondaryKeyAsGSI: boolean;\n\n  /**\n   * Automate generation of query names, and as a result attaching all indexes as queries to the generated Api.\n   * If enabled, @index can be provided a null name field to disable the generation of the query on the Api.\n   * @default true\n   */\n  readonly enableAutoIndexQueryNames: boolean;\n\n  /**\n   * Enable custom primary key support, there's no good reason to disable this unless trying not to update a legacy app.\n   * @default true\n   */\n  readonly respectPrimaryKeyAttributesOnConnectionField: boolean;\n\n  readonly enableSearchNodeToNodeEncryption: boolean;\n\n  /**\n   * When enabled, internal cfn outputs which existed in Amplify-generated apps will continue to be emitted.\n   * @default false\n   */\n  readonly enableTransformerCfnOutputs: boolean;\n\n  /**\n   * The following schema updates require replacement of the underlying DynamoDB table:\n   *\n   *  - Removing or renaming a model\n   *  - Modifying the primary key of a model\n   *  - Modifying a Local Secondary Index of a model (only applies to projects with secondaryKeyAsGSI turned off)\n   *\n   * ALL DATA WILL BE LOST when the table replacement happens. When enabled, destructive updates are allowed.\n   * This will only affect DynamoDB tables with provision strategy \"AMPLIFY_TABLE\".\n   * @default false\n   * @experimental\n   */\n  readonly allowDestructiveGraphqlSchemaUpdates: boolean;\n\n  /**\n   * This behavior will only come into effect when both \"allowDestructiveGraphqlSchemaUpdates\" and this value are set to true\n   *\n   * When enabled, any GSI update operation will replace the table instead of iterative deployment, which will WIPE ALL EXISTING DATA but\n   * cost much less time for deployment This will only affect DynamoDB tables with provision strategy \"AMPLIFY_TABLE\".\n   * @default false\n   * @experimental\n   */\n  readonly replaceTableUponGsiUpdate: boolean;\n}\n\n/**\n * A utility interface equivalent to Partial<TranslationBehavior>.\n */\nexport interface PartialTranslationBehavior {\n  /**\n   * Restore parity w/ GQLv1 @model parameter behavior, where setting a single field doesn't implicitly set the other fields to null.\n   * @default true\n   */\n  readonly shouldDeepMergeDirectiveConfigDefaults?: boolean;\n\n  /**\n   * Disable resolver deduping, this can sometimes cause problems because dedupe ordering isn't stable today, which can\n   * lead to circular dependencies across stacks if models are reordered.\n   * @default true\n   */\n  readonly disableResolverDeduping?: boolean;\n\n  /**\n   * Enabling sandbox mode will enable api key auth on all models in the transformed schema.\n   * @default false\n   */\n  readonly sandboxModeEnabled?: boolean;\n\n  /**\n   * Ensure that oidc and userPool auth use the `sub` field in the for the username field, which disallows new users with the same\n   * id to access data from a deleted user in the pool.\n   * @default true\n   */\n  readonly useSubUsernameForDefaultIdentityClaim?: boolean;\n\n  /**\n   * Ensure that the owner field is still populated even if a static iam or group authorization applies.\n   * @default true\n   */\n  readonly populateOwnerFieldForStaticGroupAuth?: boolean;\n\n  /**\n   * If enabled, disable api key resource generation even if specified as an auth rule on the construct.\n   * This is a legacy parameter from the Graphql Transformer existing in Amplify CLI, not recommended to change.\n   * @default false\n   */\n  readonly suppressApiKeyGeneration?: boolean;\n\n  /**\n   * If disabled, generated @index as an LSI instead of a GSI.\n   * @default true\n   */\n  readonly secondaryKeyAsGSI?: boolean;\n\n  /**\n   * Automate generation of query names, and as a result attaching all indexes as queries to the generated Api.\n   * If enabled, @index can be provided a null name field to disable the generation of the query on the Api.\n   * @default true\n   */\n  readonly enableAutoIndexQueryNames?: boolean;\n\n  /**\n   * Enable custom primary key support, there's no good reason to disable this unless trying not to update a legacy app.\n   * @default true\n   */\n  readonly respectPrimaryKeyAttributesOnConnectionField?: boolean;\n\n  /**\n   * If enabled, set nodeToNodeEncryption on the searchable domain (if one exists). Not recommended for use, prefer\n   * to use `Object.values(resources.additionalResources['AWS::Elasticsearch::Domain']).forEach((domain: CfnDomain) => {\n   *   domain.NodeToNodeEncryptionOptions = { Enabled: True };\n   * });\n   * @default false\n   */\n  readonly enableSearchNodeToNodeEncryption?: boolean;\n\n  /**\n   * When enabled, internal cfn outputs which existed in Amplify-generated apps will continue to be emitted.\n   * @default false\n   */\n  readonly enableTransformerCfnOutputs?: boolean;\n\n  /**\n   * The following schema updates require replacement of the underlying DynamoDB table:\n   *\n   *  - Removing or renaming a model\n   *  - Modifying the primary key of a model\n   *  - Modifying a Local Secondary Index of a model (only applies to projects with secondaryKeyAsGSI turned off)\n   *\n   * ALL DATA WILL BE LOST when the table replacement happens. When enabled, destructive updates are allowed.\n   * This will only affect DynamoDB tables with provision strategy \"AMPLIFY_TABLE\".\n   * @default false\n   * @experimental\n   */\n  readonly allowDestructiveGraphqlSchemaUpdates?: boolean;\n\n  /**\n   * This behavior will only come into effect when both \"allowDestructiveGraphqlSchemaUpdates\" and this value are set to true\n   *\n   * When enabled, any global secondary index update operation will replace the table instead of iterative deployment, which will WIPE ALL\n   * EXISTING DATA but cost much less time for deployment This will only affect DynamoDB tables with provision strategy \"AMPLIFY_TABLE\".\n   * @default false\n   * @experimental\n   */\n  readonly replaceTableUponGsiUpdate?: boolean;\n}\n\n/**\n * Graphql Api definition, which can be implemented in multiple ways.\n */\nexport interface IAmplifyGraphqlDefinition {\n  /**\n   * Return the schema definition as a graphql string, with amplify directives allowed.\n   * @returns the rendered schema.\n   */\n  readonly schema: string;\n\n  /**\n   * Retrieve any function slots defined explicitly in the Api definition.\n   * @returns generated function slots\n   */\n  readonly functionSlots: FunctionSlot[];\n\n  /**\n   * Retrieve the references to any lambda functions used in the definition.\n   * Useful for wiring through aws_lambda.Function constructs into the definition directly,\n   * and generated references to invoke them.\n   * @returns any lambda functions, keyed by their referenced 'name' in the generated schema.\n   */\n  readonly referencedLambdaFunctions?: Record<string, IFunction>;\n\n  /**\n   * Retrieve the datasource strategy mapping. The default strategy is to use DynamoDB from CloudFormation.\n   *\n   * **NOTE** Explicitly specifying the 'dataSourceStrategies' configuration option is in preview and is not recommended to use with\n   * production systems. For production, use the static factory methods `fromString` or `fromFiles`.\n   * @experimental\n   * @returns datasource strategy mapping\n   */\n  readonly dataSourceStrategies: Record<string, ModelDataSourceStrategy>;\n\n  /**\n   * An array of custom Query or Mutation SQL commands to the data sources that resolves them.\n   *\n   * **NOTE** Explicitly specifying the 'customSqlDataSourceStrategies' configuration option is in preview and is not recommended to use\n   * with production systems. For production, use the static factory methods `fromString` or `fromFiles`.\n   * @experimental\n   * @returns a list of mappings from custom SQL commands to data sources\n   */\n  readonly customSqlDataSourceStrategies?: CustomSqlDataSourceStrategy[];\n}\n\n/**\n * Entry representing the required output from the backend for codegen generate commands to work.\n */\nexport interface IBackendOutputEntry {\n  /**\n   * The protocol version for this backend output.\n   */\n  readonly version: string;\n\n  /**\n   * The string-map payload of generated config values.\n   */\n  readonly payload: Record<string, string>;\n}\n\n/**\n * Backend output strategy used to write config required for codegen tasks.\n */\nexport interface IBackendOutputStorageStrategy {\n  /**\n   * Add an entry to backend output.\n   * @param keyName the key\n   * @param backendOutputEntry the record to store in the backend output\n   */\n  // eslint-disable-next-line @typescript-eslint/method-signature-style\n  addBackendOutputEntry(keyName: string, backendOutputEntry: IBackendOutputEntry): void;\n}\n\n/**\n * Input props for the AmplifyGraphqlApi construct. Specifies what the input to transform into an Api, and configurations for\n * the transformation process.\n */\nexport interface AmplifyGraphqlApiProps {\n  /**\n   * The definition to transform in a full Api.\n   * Can be constructed via the AmplifyGraphqlDefinition class.\n   */\n  readonly definition: IAmplifyGraphqlDefinition;\n\n  /**\n   * Name to be used for the AppSync Api.\n   * Default: construct id.\n   */\n  readonly apiName?: string;\n\n  /**\n   * Required auth modes for the Api. This object must be a superset of the configured auth providers in the Api definition.\n   * For more information, refer to https://docs.amplify.aws/cli/graphql/authorization-rules/\n   */\n  readonly authorizationModes: AuthorizationModes;\n\n  /**\n   * Lambda functions referenced in the definitions's @function directives. The keys of this object are expected to be the\n   * function name provided in the definition, and value is the function that name refers to. If a name is not found in this\n   * map, then it is interpreted as the `functionName`, and an arn will be constructed using the current aws account and region\n   * (or overridden values, if set in the directive).\n   */\n  readonly functionNameMap?: Record<string, IFunction>;\n\n  /**\n   * Configure conflict resolution on the Api, which is required to enable DataStore Api functionality.\n   * For more information, refer to https://docs.amplify.aws/lib/datastore/getting-started/q/platform/js/\n   */\n  readonly conflictResolution?: ConflictResolution;\n\n  /**\n   * StackMappings override the assigned nested stack on a per-resource basis. Only applies to resolvers, and takes the form\n   * { <logicalId>: <stackName> }\n   * It is not recommended to use this parameter unless you are encountering stack resource count limits, and worth noting that\n   * after initial deployment AppSync resolvers cannot be moved between nested stacks, they will need to be removed from the app,\n   * then re-added from a new stack.\n   */\n  readonly stackMappings?: Record<string, string>;\n\n  /**\n   * Overrides for a given slot in the generated resolver pipelines. For more information about what slots are available,\n   * refer to https://docs.amplify.aws/cli/graphql/custom-business-logic/#override-amplify-generated-resolvers.\n   */\n  readonly functionSlots?: FunctionSlot[];\n\n  /**\n   * Provide a list of additional custom transformers which are injected into the transform process.\n   * These custom transformers must be implemented with aws-cdk-lib >=2.80.0, and @aws-amplify/graphql-transformer-core >= 2.1.1\n   * @experimental\n   */\n  readonly transformerPlugins?: any[];\n\n  /**\n   * If using predictions, a bucket must be provided which will be used to search for assets.\n   */\n  readonly predictionsBucket?: IBucket;\n\n  /**\n   * This replaces feature flags from the Api construct, for general information on what these parameters do,\n   * refer to https://docs.amplify.aws/cli/reference/feature-flags/#graphQLTransformer\n   */\n  readonly translationBehavior?: PartialTranslationBehavior;\n\n  /**\n   * Strategy to store construct outputs. If no outputStorageStrategey is provided a default strategy will be used.\n   */\n  readonly outputStorageStrategy?: IBackendOutputStorageStrategy;\n}\n\n/**\n * L1 CDK resources from the Api which were generated as part of the transform.\n * These are potentially stored under nested stacks, but presented organized by type instead.\n */\nexport interface AmplifyGraphqlApiCfnResources {\n  /**\n   * The Generated AppSync Api L1 Resource\n   */\n  readonly cfnGraphqlApi: CfnGraphQLApi;\n\n  /**\n   * The Generated AppSync Schema L1 Resource\n   */\n  readonly cfnGraphqlSchema: CfnGraphQLSchema;\n\n  /**\n   * The Generated AppSync Api Key L1 Resource\n   */\n  readonly cfnApiKey?: CfnApiKey;\n\n  /**\n   * The Generated AppSync Resolver L1 Resources, keyed by logicalId.\n   */\n  readonly cfnResolvers: Record<string, CfnResolver>;\n\n  /**\n   * The Generated AppSync Function L1 Resources, keyed by logicalId.\n   */\n  readonly cfnFunctionConfigurations: Record<string, CfnFunctionConfiguration>;\n\n  /**\n   * The Generated AppSync DataSource L1 Resources, keyed by logicalId.\n   */\n  readonly cfnDataSources: Record<string, CfnDataSource>;\n\n  /**\n   * The Generated DynamoDB Table L1 Resources, keyed by logicalId.\n   */\n  readonly cfnTables: Record<string, CfnTable>;\n\n  /**\n   * The Generated IAM Role L1 Resources, keyed by logicalId.\n   */\n  readonly cfnRoles: Record<string, CfnRole>;\n\n  /**\n   * The Generated Lambda Function L1 Resources, keyed by function name.\n   */\n  readonly cfnFunctions: Record<string, CfnFunction>;\n\n  /**\n   * Remaining L1 resources generated, keyed by logicalId.\n   */\n  readonly additionalCfnResources: Record<string, CfnResource>;\n}\n\n/**\n * Accessible resources from the Api which were generated as part of the transform.\n * These are potentially stored under nested stacks, but presented organized by type instead.\n */\nexport interface AmplifyGraphqlApiResources {\n  /**\n   * The Generated AppSync Api L2 Resource, includes the Schema.\n   */\n  readonly graphqlApi: IGraphqlApi;\n\n  /**\n   * The Generated DynamoDB Table L2 Resources, keyed by logicalId.\n   */\n  readonly tables: Record<string, ITable>;\n\n  /**\n   * The Generated Amplify DynamoDb Table wrapped if produced, keyed by name.\n   */\n  readonly amplifyDynamoDbTables: Record<string, AmplifyDynamoDbTableWrapper>;\n\n  /**\n   * The Generated IAM Role L2 Resources, keyed by logicalId.\n   */\n  readonly roles: Record<string, IRole>;\n\n  /**\n   * The Generated Lambda Function L1 Resources, keyed by function name.\n   */\n  readonly functions: Record<string, IFunction>;\n\n  /**\n   * L1 Cfn Resources, for when dipping down a level of abstraction is desirable.\n   */\n  readonly cfnResources: AmplifyGraphqlApiCfnResources;\n\n  /**\n   * Nested Stacks generated by the Api Construct.\n   */\n  readonly nestedStacks: Record<string, NestedStack>;\n}\n\n/**\n * Input type properties when adding a new appsync.AppsyncFunction to the generated API.\n * This is equivalent to the Omit<appsync.AppsyncFunctionProps, 'api'>.\n */\nexport interface AddFunctionProps {\n  /**\n   * the data source linked to this AppSync Function\n   */\n  readonly dataSource: BaseDataSource;\n\n  /**\n   * the name of the AppSync Function\n   */\n  readonly name: string;\n\n  /**\n   * the description for this AppSync Function\n   *\n   * @default - no description\n   */\n  readonly description?: string;\n\n  /**\n   * the request mapping template for the AppSync Function\n   *\n   * @default - no request mapping template\n   */\n  readonly requestMappingTemplate?: MappingTemplate;\n\n  /**\n   * the response mapping template for the AppSync Function\n   *\n   * @default - no response mapping template\n   */\n  readonly responseMappingTemplate?: MappingTemplate;\n\n  /**\n   * The functions runtime\n   *\n   * @default - no function runtime, VTL mapping templates used\n   */\n  readonly runtime?: FunctionRuntime;\n\n  /**\n   * The function code\n   *\n   * @default - no code is used\n   */\n  readonly code?: Code;\n}\n"]}
@@ -3,6 +3,14 @@
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.2.3](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-auth-transformer@3.2.2...@aws-amplify/graphql-auth-transformer@3.2.3) (2023-11-22)
7
+
8
+ **Note:** Version bump only for package @aws-amplify/graphql-auth-transformer
9
+
10
+ ## [3.2.2](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-auth-transformer@3.2.1...@aws-amplify/graphql-auth-transformer@3.2.2) (2023-11-18)
11
+
12
+ **Note:** Version bump only for package @aws-amplify/graphql-auth-transformer
13
+
6
14
  ## [3.2.1](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-auth-transformer@3.2.0...@aws-amplify/graphql-auth-transformer@3.2.1) (2023-11-16)
7
15
 
8
16
  **Note:** Version bump only for package @aws-amplify/graphql-auth-transformer
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aws-amplify/graphql-auth-transformer",
3
- "version": "3.2.1",
3
+ "version": "3.2.3",
4
4
  "description": "Amplify GraphQL @auth transformer",
5
5
  "repository": {
6
6
  "type": "git",
@@ -29,20 +29,20 @@
29
29
  "extract-api": "ts-node ../../scripts/extract-api.ts"
30
30
  },
31
31
  "dependencies": {
32
- "@aws-amplify/graphql-model-transformer": "2.3.1",
33
- "@aws-amplify/graphql-relational-transformer": "2.2.1",
34
- "@aws-amplify/graphql-transformer-core": "2.3.1",
35
- "@aws-amplify/graphql-transformer-interfaces": "3.3.0",
32
+ "@aws-amplify/graphql-model-transformer": "2.3.3",
33
+ "@aws-amplify/graphql-relational-transformer": "2.2.3",
34
+ "@aws-amplify/graphql-transformer-core": "2.3.3",
35
+ "@aws-amplify/graphql-transformer-interfaces": "3.3.1",
36
36
  "graphql": "^15.5.0",
37
37
  "graphql-mapping-template": "4.20.12",
38
- "graphql-transformer-common": "4.26.1",
38
+ "graphql-transformer-common": "4.26.2",
39
39
  "lodash": "^4.17.21",
40
40
  "md5": "^2.3.0"
41
41
  },
42
42
  "devDependencies": {
43
- "@aws-amplify/graphql-index-transformer": "2.2.1",
44
- "@aws-amplify/graphql-searchable-transformer": "2.3.1",
45
- "@aws-amplify/graphql-transformer-test-utils": "0.3.1",
43
+ "@aws-amplify/graphql-index-transformer": "2.2.3",
44
+ "@aws-amplify/graphql-searchable-transformer": "2.3.3",
45
+ "@aws-amplify/graphql-transformer-test-utils": "0.3.3",
46
46
  "@types/node": "^12.12.6"
47
47
  },
48
48
  "peerDependencies": {
@@ -72,5 +72,5 @@
72
72
  }
73
73
  }
74
74
  },
75
- "gitHead": "317a141956493f0940bb506470259026edf3b7bc"
75
+ "gitHead": "5256b5955ee204dd56f8074a43406852f8206c54"
76
76
  }
@@ -3,6 +3,14 @@
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.12](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-default-value-transformer@2.1.11...@aws-amplify/graphql-default-value-transformer@2.1.12) (2023-11-22)
7
+
8
+ **Note:** Version bump only for package @aws-amplify/graphql-default-value-transformer
9
+
10
+ ## [2.1.11](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-default-value-transformer@2.1.10...@aws-amplify/graphql-default-value-transformer@2.1.11) (2023-11-18)
11
+
12
+ **Note:** Version bump only for package @aws-amplify/graphql-default-value-transformer
13
+
6
14
  ## [2.1.10](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-default-value-transformer@2.1.9...@aws-amplify/graphql-default-value-transformer@2.1.10) (2023-11-16)
7
15
 
8
16
  **Note:** Version bump only for package @aws-amplify/graphql-default-value-transformer
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aws-amplify/graphql-default-value-transformer",
3
- "version": "2.1.10",
3
+ "version": "2.1.12",
4
4
  "description": "Amplify GraphQL default value transformer",
5
5
  "repository": {
6
6
  "type": "git",
@@ -29,16 +29,16 @@
29
29
  "extract-api": "ts-node ../../scripts/extract-api.ts"
30
30
  },
31
31
  "dependencies": {
32
- "@aws-amplify/graphql-transformer-core": "2.3.1",
33
- "@aws-amplify/graphql-transformer-interfaces": "3.3.0",
32
+ "@aws-amplify/graphql-transformer-core": "2.3.3",
33
+ "@aws-amplify/graphql-transformer-interfaces": "3.3.1",
34
34
  "graphql": "^15.5.0",
35
35
  "graphql-mapping-template": "4.20.12",
36
- "graphql-transformer-common": "4.26.1",
36
+ "graphql-transformer-common": "4.26.2",
37
37
  "libphonenumber-js": "1.9.47"
38
38
  },
39
39
  "devDependencies": {
40
- "@aws-amplify/graphql-model-transformer": "2.3.1",
41
- "@aws-amplify/graphql-transformer-test-utils": "0.3.1"
40
+ "@aws-amplify/graphql-model-transformer": "2.3.3",
41
+ "@aws-amplify/graphql-transformer-test-utils": "0.3.3"
42
42
  },
43
43
  "jest": {
44
44
  "transform": {
@@ -63,5 +63,5 @@
63
63
  }
64
64
  }
65
65
  },
66
- "gitHead": "317a141956493f0940bb506470259026edf3b7bc"
66
+ "gitHead": "5256b5955ee204dd56f8074a43406852f8206c54"
67
67
  }
@@ -3,6 +3,14 @@
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.11](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-function-transformer@2.1.10...@aws-amplify/graphql-function-transformer@2.1.11) (2023-11-22)
7
+
8
+ **Note:** Version bump only for package @aws-amplify/graphql-function-transformer
9
+
10
+ ## [2.1.10](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-function-transformer@2.1.9...@aws-amplify/graphql-function-transformer@2.1.10) (2023-11-18)
11
+
12
+ **Note:** Version bump only for package @aws-amplify/graphql-function-transformer
13
+
6
14
  ## [2.1.9](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-function-transformer@2.1.8...@aws-amplify/graphql-function-transformer@2.1.9) (2023-11-16)
7
15
 
8
16
  **Note:** Version bump only for package @aws-amplify/graphql-function-transformer
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aws-amplify/graphql-function-transformer",
3
- "version": "2.1.9",
3
+ "version": "2.1.11",
4
4
  "description": "Amplify GraphQL @function transformer",
5
5
  "repository": {
6
6
  "type": "git",
@@ -28,14 +28,14 @@
28
28
  "extract-api": "ts-node ../../scripts/extract-api.ts"
29
29
  },
30
30
  "dependencies": {
31
- "@aws-amplify/graphql-transformer-core": "2.3.1",
32
- "@aws-amplify/graphql-transformer-interfaces": "3.3.0",
31
+ "@aws-amplify/graphql-transformer-core": "2.3.3",
32
+ "@aws-amplify/graphql-transformer-interfaces": "3.3.1",
33
33
  "graphql": "^15.5.0",
34
34
  "graphql-mapping-template": "4.20.12",
35
- "graphql-transformer-common": "4.26.1"
35
+ "graphql-transformer-common": "4.26.2"
36
36
  },
37
37
  "devDependencies": {
38
- "@aws-amplify/graphql-transformer-test-utils": "0.3.1"
38
+ "@aws-amplify/graphql-transformer-test-utils": "0.3.3"
39
39
  },
40
40
  "peerDependencies": {
41
41
  "aws-cdk-lib": "^2.80.0",
@@ -66,5 +66,5 @@
66
66
  "overrides"
67
67
  ]
68
68
  },
69
- "gitHead": "317a141956493f0940bb506470259026edf3b7bc"
69
+ "gitHead": "5256b5955ee204dd56f8074a43406852f8206c54"
70
70
  }
@@ -3,6 +3,14 @@
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.11](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-http-transformer@2.1.10...@aws-amplify/graphql-http-transformer@2.1.11) (2023-11-22)
7
+
8
+ **Note:** Version bump only for package @aws-amplify/graphql-http-transformer
9
+
10
+ ## [2.1.10](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-http-transformer@2.1.9...@aws-amplify/graphql-http-transformer@2.1.10) (2023-11-18)
11
+
12
+ **Note:** Version bump only for package @aws-amplify/graphql-http-transformer
13
+
6
14
  ## [2.1.9](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-http-transformer@2.1.8...@aws-amplify/graphql-http-transformer@2.1.9) (2023-11-16)
7
15
 
8
16
  **Note:** Version bump only for package @aws-amplify/graphql-http-transformer
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aws-amplify/graphql-http-transformer",
3
- "version": "2.1.9",
3
+ "version": "2.1.11",
4
4
  "description": "Amplify GraphQL @http transformer",
5
5
  "repository": {
6
6
  "type": "git",
@@ -28,14 +28,14 @@
28
28
  "extract-api": "ts-node ../../scripts/extract-api.ts"
29
29
  },
30
30
  "dependencies": {
31
- "@aws-amplify/graphql-transformer-core": "2.3.1",
32
- "@aws-amplify/graphql-transformer-interfaces": "3.3.0",
31
+ "@aws-amplify/graphql-transformer-core": "2.3.3",
32
+ "@aws-amplify/graphql-transformer-interfaces": "3.3.1",
33
33
  "graphql": "^15.5.0",
34
34
  "graphql-mapping-template": "4.20.12",
35
- "graphql-transformer-common": "4.26.1"
35
+ "graphql-transformer-common": "4.26.2"
36
36
  },
37
37
  "devDependencies": {
38
- "@aws-amplify/graphql-transformer-test-utils": "0.3.1"
38
+ "@aws-amplify/graphql-transformer-test-utils": "0.3.3"
39
39
  },
40
40
  "peerDependencies": {
41
41
  "aws-cdk-lib": "^2.80.0",
@@ -66,5 +66,5 @@
66
66
  "overrides"
67
67
  ]
68
68
  },
69
- "gitHead": "317a141956493f0940bb506470259026edf3b7bc"
69
+ "gitHead": "5256b5955ee204dd56f8074a43406852f8206c54"
70
70
  }
@@ -3,6 +3,14 @@
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.2.3](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-index-transformer@2.2.2...@aws-amplify/graphql-index-transformer@2.2.3) (2023-11-22)
7
+
8
+ **Note:** Version bump only for package @aws-amplify/graphql-index-transformer
9
+
10
+ ## [2.2.2](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-index-transformer@2.2.1...@aws-amplify/graphql-index-transformer@2.2.2) (2023-11-18)
11
+
12
+ **Note:** Version bump only for package @aws-amplify/graphql-index-transformer
13
+
6
14
  ## [2.2.1](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-index-transformer@2.2.0...@aws-amplify/graphql-index-transformer@2.2.1) (2023-11-16)
7
15
 
8
16
  **Note:** Version bump only for package @aws-amplify/graphql-index-transformer
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aws-amplify/graphql-index-transformer",
3
- "version": "2.2.1",
3
+ "version": "2.2.3",
4
4
  "description": "Amplify GraphQL index and key transformers",
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-model-transformer": "2.3.1",
32
- "@aws-amplify/graphql-transformer-core": "2.3.1",
33
- "@aws-amplify/graphql-transformer-interfaces": "3.3.0",
31
+ "@aws-amplify/graphql-model-transformer": "2.3.3",
32
+ "@aws-amplify/graphql-transformer-core": "2.3.3",
33
+ "@aws-amplify/graphql-transformer-interfaces": "3.3.1",
34
34
  "graphql": "^15.5.0",
35
35
  "graphql-mapping-template": "4.20.12",
36
- "graphql-transformer-common": "4.26.1"
36
+ "graphql-transformer-common": "4.26.2"
37
37
  },
38
38
  "devDependencies": {
39
- "@aws-amplify/graphql-transformer-test-utils": "0.3.1"
39
+ "@aws-amplify/graphql-transformer-test-utils": "0.3.3"
40
40
  },
41
41
  "peerDependencies": {
42
42
  "aws-cdk-lib": "^2.80.0",
@@ -64,5 +64,5 @@
64
64
  }
65
65
  }
66
66
  },
67
- "gitHead": "317a141956493f0940bb506470259026edf3b7bc"
67
+ "gitHead": "5256b5955ee204dd56f8074a43406852f8206c54"
68
68
  }
@@ -3,6 +3,14 @@
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.3.3](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-maps-to-transformer@3.3.2...@aws-amplify/graphql-maps-to-transformer@3.3.3) (2023-11-22)
7
+
8
+ **Note:** Version bump only for package @aws-amplify/graphql-maps-to-transformer
9
+
10
+ ## [3.3.2](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-maps-to-transformer@3.3.1...@aws-amplify/graphql-maps-to-transformer@3.3.2) (2023-11-18)
11
+
12
+ **Note:** Version bump only for package @aws-amplify/graphql-maps-to-transformer
13
+
6
14
  ## [3.3.1](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-maps-to-transformer@3.3.0...@aws-amplify/graphql-maps-to-transformer@3.3.1) (2023-11-16)
7
15
 
8
16
  **Note:** Version bump only for package @aws-amplify/graphql-maps-to-transformer
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aws-amplify/graphql-maps-to-transformer",
3
- "version": "3.3.1",
3
+ "version": "3.3.3",
4
4
  "description": "Amplify GraphQL @mapsTo transformer",
5
5
  "repository": {
6
6
  "type": "git",
@@ -30,21 +30,21 @@
30
30
  "extract-api": "ts-node ../../scripts/extract-api.ts"
31
31
  },
32
32
  "dependencies": {
33
- "@aws-amplify/graphql-transformer-core": "2.3.1",
34
- "@aws-amplify/graphql-transformer-interfaces": "3.3.0",
33
+ "@aws-amplify/graphql-transformer-core": "2.3.3",
34
+ "@aws-amplify/graphql-transformer-interfaces": "3.3.1",
35
35
  "graphql-mapping-template": "4.20.12",
36
- "graphql-transformer-common": "4.26.1"
36
+ "graphql-transformer-common": "4.26.2"
37
37
  },
38
38
  "peerDependencies": {
39
39
  "aws-cdk-lib": "^2.80.0",
40
40
  "constructs": "^10.0.5"
41
41
  },
42
42
  "devDependencies": {
43
- "@aws-amplify/graphql-index-transformer": "2.2.1",
44
- "@aws-amplify/graphql-model-transformer": "2.3.1",
45
- "@aws-amplify/graphql-relational-transformer": "2.2.1",
46
- "@aws-amplify/graphql-searchable-transformer": "2.3.1",
47
- "@aws-amplify/graphql-transformer-test-utils": "0.3.1",
43
+ "@aws-amplify/graphql-index-transformer": "2.2.3",
44
+ "@aws-amplify/graphql-model-transformer": "2.3.3",
45
+ "@aws-amplify/graphql-relational-transformer": "2.2.3",
46
+ "@aws-amplify/graphql-searchable-transformer": "2.3.3",
47
+ "@aws-amplify/graphql-transformer-test-utils": "0.3.3",
48
48
  "graphql": "^15.5.0"
49
49
  },
50
50
  "jest": {
@@ -73,5 +73,5 @@
73
73
  }
74
74
  }
75
75
  },
76
- "gitHead": "317a141956493f0940bb506470259026edf3b7bc"
76
+ "gitHead": "5256b5955ee204dd56f8074a43406852f8206c54"
77
77
  }
@@ -7,6 +7,8 @@
7
7
  import { AppSyncDataSourceType } from '@aws-amplify/graphql-transformer-interfaces';
8
8
  import * as cdk from 'aws-cdk-lib';
9
9
  import { DataSourceInstance } from '@aws-amplify/graphql-transformer-interfaces';
10
+ import { DataSourceProvider } from '@aws-amplify/graphql-transformer-interfaces';
11
+ import { DBType } from '@aws-amplify/graphql-transformer-interfaces';
10
12
  import { DirectiveNode } from 'graphql';
11
13
  import { DocumentNode } from 'graphql';
12
14
  import { EnumTypeDefinitionNode } from 'graphql';
@@ -313,6 +315,20 @@ export const OPERATION_KEY = "__operation";
313
315
  // @public (undocumented)
314
316
  export const propagateApiKeyToNestedTypes: (ctx: TransformerContextProvider, def: ObjectTypeDefinitionNode, seenNonModelTypes: Set<string>) => void;
315
317
 
318
+ // Warning: (ae-forgotten-export) The symbol "ModelResourceGenerator" needs to be exported by the entry point index.d.ts
319
+ //
320
+ // @public (undocumented)
321
+ export class RdsModelResourceGenerator extends ModelResourceGenerator {
322
+ // (undocumented)
323
+ generateResources(context: TransformerContextProvider, dbTypeOverride?: DBType): void;
324
+ // (undocumented)
325
+ protected readonly generatorType = "RdsModelResourceGenerator";
326
+ // (undocumented)
327
+ getVTLGenerator(): ModelVTLGenerator;
328
+ // (undocumented)
329
+ setFieldMappingResolverReferences(context: TransformerContextProvider): void;
330
+ }
331
+
316
332
  // @public (undocumented)
317
333
  export class RDSModelVTLGenerator implements ModelVTLGenerator {
318
334
  // (undocumented)
@@ -3,6 +3,18 @@
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.3](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-model-transformer@2.3.2...@aws-amplify/graphql-model-transformer@2.3.3) (2023-11-22)
7
+
8
+ ### Bug Fixes
9
+
10
+ - Allow custom SQL statements without model declarations ([#2087](https://github.com/aws-amplify/amplify-category-api/issues/2087)) ([ea5b26c](https://github.com/aws-amplify/amplify-category-api/commit/ea5b26cd554f5c74b6431cbad6ccf60ab556478f))
11
+
12
+ ## [2.3.2](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-model-transformer@2.3.1...@aws-amplify/graphql-model-transformer@2.3.2) (2023-11-18)
13
+
14
+ ### Bug Fixes
15
+
16
+ - regionalize lambda layer patching SNS topics ([#2079](https://github.com/aws-amplify/amplify-category-api/issues/2079)) ([6006c86](https://github.com/aws-amplify/amplify-category-api/commit/6006c86cd4ee624b24c184fab523fcdcdb38be63))
17
+
6
18
  ## [2.3.1](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-model-transformer@2.3.0...@aws-amplify/graphql-model-transformer@2.3.1) (2023-11-16)
7
19
 
8
20
  ### Bug Fixes
@@ -3,4 +3,5 @@ export { ModelTransformer } from './graphql-model-transformer';
3
3
  export { OPERATION_KEY } from './definitions';
4
4
  export * from './graphql-types';
5
5
  export * from './resolvers';
6
+ export { RdsModelResourceGenerator } from './resources/rds-model-resource-generator';
6
7
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,2BAA2B,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAC7E,OAAO,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;AAC/D,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAC9C,cAAc,iBAAiB,CAAC;AAChC,cAAc,aAAa,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,2BAA2B,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAC7E,OAAO,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;AAC/D,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAC9C,cAAc,iBAAiB,CAAC;AAChC,cAAc,aAAa,CAAC;AAI5B,OAAO,EAAE,yBAAyB,EAAE,MAAM,0CAA0C,CAAC"}
@@ -14,7 +14,7 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
14
  for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
15
  };
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
- exports.OPERATION_KEY = exports.ModelTransformer = exports.SubscriptionLevel = void 0;
17
+ exports.RdsModelResourceGenerator = exports.OPERATION_KEY = exports.ModelTransformer = exports.SubscriptionLevel = void 0;
18
18
  var directive_1 = require("./directive");
19
19
  Object.defineProperty(exports, "SubscriptionLevel", { enumerable: true, get: function () { return directive_1.SubscriptionLevel; } });
20
20
  var graphql_model_transformer_1 = require("./graphql-model-transformer");
@@ -23,4 +23,6 @@ var definitions_1 = require("./definitions");
23
23
  Object.defineProperty(exports, "OPERATION_KEY", { enumerable: true, get: function () { return definitions_1.OPERATION_KEY; } });
24
24
  __exportStar(require("./graphql-types"), exports);
25
25
  __exportStar(require("./resolvers"), exports);
26
+ var rds_model_resource_generator_1 = require("./resources/rds-model-resource-generator");
27
+ Object.defineProperty(exports, "RdsModelResourceGenerator", { enumerable: true, get: function () { return rds_model_resource_generator_1.RdsModelResourceGenerator; } });
26
28
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,yCAA6E;AAAvC,8GAAA,iBAAiB,OAAA;AACvD,yEAA+D;AAAtD,6HAAA,gBAAgB,OAAA;AACzB,6CAA8C;AAArC,4GAAA,aAAa,OAAA;AACtB,kDAAgC;AAChC,8CAA4B"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,yCAA6E;AAAvC,8GAAA,iBAAiB,OAAA;AACvD,yEAA+D;AAAtD,6HAAA,gBAAgB,OAAA;AACzB,6CAA8C;AAArC,4GAAA,aAAa,OAAA;AACtB,kDAAgC;AAChC,8CAA4B;AAI5B,yFAAqF;AAA5E,yIAAA,yBAAyB,OAAA"}