@aws-amplify/graphql-api-construct 1.18.3-ai-next.0 → 1.18.4
Sign up to get free protection for your applications and to get access to all the features.
- package/.jsii +548 -176
- package/API.md +17 -0
- package/CHANGELOG.md +5 -1
- package/jest.config.js +5 -0
- package/lib/amplify-dynamodb-table-wrapper.js +1 -1
- package/lib/amplify-graphql-api.js +4 -3
- package/lib/amplify-graphql-definition.js +1 -1
- package/lib/index.d.ts +2 -0
- package/lib/index.js +27 -2
- package/lib/log-config-types.d.ts +78 -0
- package/lib/log-config-types.js +8 -0
- package/lib/sql-model-datasource-strategy.js +1 -1
- package/lib/types.d.ts +5 -0
- package/lib/types.js +11 -1
- package/node_modules/@aws-amplify/graphql-auth-transformer/CHANGELOG.md +8 -0
- package/node_modules/@aws-amplify/graphql-auth-transformer/LICENSE +201 -0
- package/node_modules/@aws-amplify/graphql-auth-transformer/jest.config.js +12 -0
- package/node_modules/@aws-amplify/graphql-auth-transformer/package.json +15 -54
- package/node_modules/@aws-amplify/graphql-conversation-transformer/CHANGELOG.md +6 -2
- package/node_modules/@aws-amplify/graphql-conversation-transformer/jest.config.js +10 -0
- package/node_modules/@aws-amplify/graphql-conversation-transformer/package.json +12 -48
- package/node_modules/@aws-amplify/graphql-default-value-transformer/CHANGELOG.md +8 -0
- package/node_modules/@aws-amplify/graphql-default-value-transformer/LICENSE +201 -0
- package/node_modules/@aws-amplify/graphql-default-value-transformer/jest.config.js +12 -0
- package/node_modules/@aws-amplify/graphql-default-value-transformer/package.json +9 -49
- package/node_modules/@aws-amplify/graphql-directives/CHANGELOG.md +4 -0
- package/node_modules/@aws-amplify/graphql-directives/jest.config.js +6 -0
- package/node_modules/@aws-amplify/graphql-directives/package.json +1 -42
- package/node_modules/@aws-amplify/graphql-function-transformer/CHANGELOG.md +8 -0
- package/node_modules/@aws-amplify/graphql-function-transformer/LICENSE +201 -0
- package/node_modules/@aws-amplify/graphql-function-transformer/jest.config.js +12 -0
- package/node_modules/@aws-amplify/graphql-function-transformer/package.json +9 -48
- package/node_modules/@aws-amplify/graphql-generation-transformer/CHANGELOG.md +8 -0
- package/node_modules/@aws-amplify/graphql-generation-transformer/LICENSE +201 -0
- package/node_modules/@aws-amplify/graphql-generation-transformer/jest.config.js +9 -0
- package/node_modules/@aws-amplify/graphql-generation-transformer/package.json +9 -44
- package/node_modules/@aws-amplify/graphql-http-transformer/CHANGELOG.md +8 -0
- package/node_modules/@aws-amplify/graphql-http-transformer/LICENSE +201 -0
- package/node_modules/@aws-amplify/graphql-http-transformer/jest.config.js +12 -0
- package/node_modules/@aws-amplify/graphql-http-transformer/package.json +9 -48
- package/node_modules/@aws-amplify/graphql-index-transformer/CHANGELOG.md +8 -0
- package/node_modules/@aws-amplify/graphql-index-transformer/LICENSE +201 -0
- package/node_modules/@aws-amplify/graphql-index-transformer/jest.config.js +12 -0
- package/node_modules/@aws-amplify/graphql-index-transformer/package.json +10 -46
- package/node_modules/@aws-amplify/graphql-maps-to-transformer/CHANGELOG.md +8 -0
- package/node_modules/@aws-amplify/graphql-maps-to-transformer/LICENSE +201 -0
- package/node_modules/@aws-amplify/graphql-maps-to-transformer/jest.config.js +12 -0
- package/node_modules/@aws-amplify/graphql-maps-to-transformer/lib/assets/mapping-lambda.zip +0 -0
- package/node_modules/@aws-amplify/graphql-maps-to-transformer/package.json +13 -49
- package/node_modules/@aws-amplify/graphql-model-transformer/CHANGELOG.md +8 -0
- package/node_modules/@aws-amplify/graphql-model-transformer/LICENSE +201 -0
- package/node_modules/@aws-amplify/graphql-model-transformer/jest.config.js +12 -0
- package/node_modules/@aws-amplify/graphql-model-transformer/lib/rds-lambda.zip +0 -0
- package/node_modules/@aws-amplify/graphql-model-transformer/lib/rds-notification-lambda.zip +0 -0
- package/node_modules/@aws-amplify/graphql-model-transformer/lib/rds-patching-lambda.zip +0 -0
- package/node_modules/@aws-amplify/graphql-model-transformer/package.json +9 -49
- package/node_modules/@aws-amplify/graphql-predictions-transformer/CHANGELOG.md +8 -0
- package/node_modules/@aws-amplify/graphql-predictions-transformer/LICENSE +201 -0
- package/node_modules/@aws-amplify/graphql-predictions-transformer/jest.config.js +5 -0
- package/node_modules/@aws-amplify/graphql-predictions-transformer/lib/predictionsLambdaFunction.zip +0 -0
- package/node_modules/@aws-amplify/graphql-predictions-transformer/package.json +9 -48
- package/node_modules/@aws-amplify/graphql-relational-transformer/CHANGELOG.md +8 -0
- package/node_modules/@aws-amplify/graphql-relational-transformer/LICENSE +201 -0
- package/node_modules/@aws-amplify/graphql-relational-transformer/jest.config.js +12 -0
- package/node_modules/@aws-amplify/graphql-relational-transformer/package.json +11 -47
- package/node_modules/@aws-amplify/graphql-searchable-transformer/CHANGELOG.md +8 -0
- package/node_modules/@aws-amplify/graphql-searchable-transformer/LICENSE +201 -0
- package/node_modules/@aws-amplify/graphql-searchable-transformer/jest.config.js +12 -0
- package/node_modules/@aws-amplify/graphql-searchable-transformer/lib/streaming-lambda.zip +0 -0
- package/node_modules/@aws-amplify/graphql-searchable-transformer/package.json +10 -52
- package/node_modules/@aws-amplify/graphql-sql-transformer/CHANGELOG.md +8 -0
- package/node_modules/@aws-amplify/graphql-sql-transformer/LICENSE +201 -0
- package/node_modules/@aws-amplify/graphql-sql-transformer/jest.config.js +12 -0
- package/node_modules/@aws-amplify/graphql-sql-transformer/package.json +10 -49
- package/node_modules/@aws-amplify/graphql-transformer/API.md +2 -0
- package/node_modules/@aws-amplify/graphql-transformer/CHANGELOG.md +5 -1
- package/node_modules/@aws-amplify/graphql-transformer/jest.config.js +12 -0
- package/node_modules/@aws-amplify/graphql-transformer/lib/graphql-transformer.d.ts +2 -1
- package/node_modules/@aws-amplify/graphql-transformer/lib/graphql-transformer.d.ts.map +1 -1
- package/node_modules/@aws-amplify/graphql-transformer/lib/graphql-transformer.js +2 -1
- package/node_modules/@aws-amplify/graphql-transformer/lib/graphql-transformer.js.map +1 -1
- package/node_modules/@aws-amplify/graphql-transformer/package.json +20 -61
- package/node_modules/@aws-amplify/graphql-transformer/src/graphql-transformer.ts +4 -0
- package/node_modules/@aws-amplify/graphql-transformer-core/API.md +3 -3
- package/node_modules/@aws-amplify/graphql-transformer-core/CHANGELOG.md +8 -0
- package/node_modules/@aws-amplify/graphql-transformer-core/LICENSE +201 -0
- package/node_modules/@aws-amplify/graphql-transformer-core/jest.config.js +12 -0
- package/node_modules/@aws-amplify/graphql-transformer-core/lib/graphql-api.d.ts +4 -3
- package/node_modules/@aws-amplify/graphql-transformer-core/lib/graphql-api.d.ts.map +1 -1
- package/node_modules/@aws-amplify/graphql-transformer-core/lib/graphql-api.js +27 -7
- package/node_modules/@aws-amplify/graphql-transformer-core/lib/graphql-api.js.map +1 -1
- package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformation/transform.d.ts +4 -3
- package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformation/transform.d.ts.map +1 -1
- package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformation/transform.js +5 -3
- package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformation/transform.js.map +1 -1
- package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformer-context/index.d.ts +3 -1
- package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformer-context/index.d.ts.map +1 -1
- package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformer-context/index.js +2 -1
- package/node_modules/@aws-amplify/graphql-transformer-core/lib/transformer-context/index.js.map +1 -1
- package/node_modules/@aws-amplify/graphql-transformer-core/package.json +7 -46
- package/node_modules/@aws-amplify/graphql-transformer-interfaces/API.md +12 -0
- package/node_modules/@aws-amplify/graphql-transformer-interfaces/CHANGELOG.md +4 -0
- package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/transformer-context/index.d.ts +1 -0
- package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/transformer-context/index.d.ts.map +1 -1
- package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/transformer-context/logConfig.d.ts +8 -0
- package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/transformer-context/logConfig.d.ts.map +1 -0
- package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/transformer-context/logConfig.js +3 -0
- package/node_modules/@aws-amplify/graphql-transformer-interfaces/lib/transformer-context/logConfig.js.map +1 -0
- package/node_modules/@aws-amplify/graphql-transformer-interfaces/package.json +2 -35
- package/node_modules/@aws-amplify/graphql-transformer-interfaces/src/transformer-context/index.ts +1 -0
- package/node_modules/@aws-amplify/graphql-transformer-interfaces/src/transformer-context/logConfig.ts +8 -0
- package/node_modules/@aws-amplify/graphql-transformer-interfaces/tsconfig.tsbuildinfo +1 -1
- package/node_modules/graphql-mapping-template/CHANGELOG.md +4 -0
- package/node_modules/graphql-mapping-template/jest.config.js +12 -0
- package/node_modules/graphql-mapping-template/package.json +1 -41
- package/node_modules/graphql-transformer-common/CHANGELOG.md +4 -0
- package/node_modules/graphql-transformer-common/jest.config.js +12 -0
- package/node_modules/graphql-transformer-common/package.json +2 -42
- package/package.json +82 -123
- package/src/amplify-graphql-api.ts +2 -0
- package/src/index.ts +35 -0
- package/src/log-config-types.ts +84 -0
- package/src/types.ts +105 -0
package/lib/types.js
CHANGED
@@ -1,3 +1,13 @@
|
|
1
1
|
"use strict";
|
2
|
+
// ############################################################################
|
3
|
+
// Note that sections of this file are excluded from test coverage metrics with
|
4
|
+
// 'c8 ignore' comments. If you add code to this file, suppress non-executable
|
5
|
+
// code from coverage metrics by using a `c8 ignore`. If the code is
|
6
|
+
// executable, you MUST NOT suppress it from coverage metrics.
|
7
|
+
//
|
8
|
+
// `ignore` statements must only span a single block of code. Do not apply an
|
9
|
+
// `ignore` statement to multiple blocks, or the entire file.
|
10
|
+
// ############################################################################
|
2
11
|
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';\nimport { CustomSqlDataSourceStrategy, ModelDataSourceStrategy } from './model-datasource-strategy-types';\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   * @deprecated Use 'IdentityPoolAuthorizationConfig.identityPoolId' instead.\n   * See https://docs.amplify.aws/cli/react/tools/cli/migration/iam-auth-updates-for-cdk-construct for details.\n   */\n  readonly identityPoolId?: string;\n\n  /**\n   * Authenticated user role, applies to { provider: iam, allow: private } access.\n   *\n   * @deprecated Use 'IdentityPoolAuthorizationConfig.authenticatedUserRole' instead.\n   * See https://docs.amplify.aws/cli/react/tools/cli/migration/iam-auth-updates-for-cdk-construct for details.\n   */\n  readonly authenticatedUserRole?: IRole;\n\n  /**\n   * Unauthenticated user role, applies to { provider: iam, allow: public } access.\n   *\n   * @deprecated Use 'IdentityPoolAuthorizationConfig.unauthenticatedUserRole' instead.\n   * See https://docs.amplify.aws/cli/react/tools/cli/migration/iam-auth-updates-for-cdk-construct for details.\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   * @deprecated Use 'enableIamAuthorizationMode' and IAM Policy to control access for IAM principals.\n   * See https://docs.amplify.aws/cli/react/tools/cli/migration/iam-auth-updates-for-cdk-construct for details.\n   */\n  readonly allowListedRoles?: (IRole | string)[];\n\n  /**\n   * Enables access for IAM principals. If enabled @auth directive rules are not applied.\n   * Instead, access should be defined by IAM Policy, see https://docs.aws.amazon.com/service-authorization/latest/reference/list_awsappsync.html.\n   *\n   * Does not apply to authenticated and unauthenticated IAM Roles attached to Cognito Identity Pool.\n   * Use IdentityPoolAuthorizationConfig to configure their access.\n   */\n  readonly enableIamAuthorizationMode?: boolean;\n}\n\n/**\n * Configuration for Cognito Identity Pool Authorization on the Graphql Api.\n * @struct - required since this interface begins with an 'I'\n */\nexport interface IdentityPoolAuthorizationConfig {\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/**\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 to allow IAM-based access to this API.\n   * This applies to any IAM principal except Amazon Cognito identity pool's authenticated and unauthenticated roles.\n   * This behavior was has recently been improved.\n   * See https://docs.amplify.aws/cli/react/tools/cli/migration/iam-auth-updates-for-cdk-construct for details.\n   */\n  readonly iamConfig?: IAMAuthorizationConfig;\n\n  /**\n   * Cognito Identity Pool config, required if an 'identityPool' auth provider is specified in the Api.\n   * Applies to 'public' and 'private' auth strategies.\n   */\n  readonly identityPoolConfig?: IdentityPoolAuthorizationConfig;\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 * @deprecated use DataStoreConfiguration instead.\n */\nexport interface ConflictResolution extends DataStoreConfiguration {}\n\n/**\n * Project level configuration for DataStore\n */\nexport interface DataStoreConfiguration {\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   * When enabled, suppresses default behavior of redacting relational fields when auth rules do not exactly match.\n   * @default false\n   */\n  readonly subscriptionsInheritPrimaryAuth: 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   * When enabled, suppresses default behavior of redacting relational fields when auth rules do not exactly match.\n   * @default false\n   */\n  readonly subscriptionsInheritPrimaryAuth?: 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   * When enabled, sandbox deployment will be faster by skipping the creation of the Hotswap friendly resources.\n   *\n   * @default false\n   * @internal\n   * WARNING: Although this has `public` access, it is intended for internal use and should not be used directly.\n   * The behavior of this may change without warning.\n   */\n  readonly _provisionHotswapFriendlyResources?: 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   * @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   * @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   * @deprecated use dataStoreConfiguration instead.\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.129.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 outputStorageStrategy is provided a default strategy will be used.\n   */\n  readonly outputStorageStrategy?: IBackendOutputStorageStrategy;\n\n  /**\n   * Configure DataStore conflict resolution on the Api. Conflict resolution 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 dataStoreConfiguration?: DataStoreConfiguration;\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 Amplify DynamoDb Table L1 resource wrapper, keyed by model type name.\n   */\n  readonly amplifyDynamoDbTables: Record<string, AmplifyDynamoDbTableWrapper>;\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 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"]}
|
12
|
+
/* c8 ignore stop */
|
13
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":";AAAA,+EAA+E;AAC/E,+EAA+E;AAC/E,8EAA8E;AAC9E,oEAAoE;AACpE,8DAA8D;AAC9D,EAAE;AACF,6EAA6E;AAC7E,6DAA6D;AAC7D,+EAA+E;;AAi/B/E,oBAAoB","sourcesContent":["// ############################################################################\n// Note that sections of this file are excluded from test coverage metrics with\n// 'c8 ignore' comments. If you add code to this file, suppress non-executable\n// code from coverage metrics by using a `c8 ignore`. If the code is\n// executable, you MUST NOT suppress it from coverage metrics.\n//\n// `ignore` statements must only span a single block of code. Do not apply an\n// `ignore` statement to multiple blocks, or the entire file.\n// ############################################################################\n\n/* c8 ignore start */\nimport { Duration, CfnResource, NestedStack } from 'aws-cdk-lib';\n/* c8 ignore stop */\n\n/* c8 ignore start */\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';\n/* c8 ignore stop */\n\n/* c8 ignore start */\nimport { CfnTable, ITable } from 'aws-cdk-lib/aws-dynamodb';\n/* c8 ignore stop */\n\n/* c8 ignore start */\nimport { IRole, CfnRole } from 'aws-cdk-lib/aws-iam';\n/* c8 ignore stop */\n\n/* c8 ignore start */\nimport { IUserPool } from 'aws-cdk-lib/aws-cognito';\n/* c8 ignore stop */\n\n/* c8 ignore start */\nimport { IFunction, CfnFunction } from 'aws-cdk-lib/aws-lambda';\n/* c8 ignore stop */\n\n/* c8 ignore start */\nimport { IBucket } from 'aws-cdk-lib/aws-s3';\n/* c8 ignore stop */\n\n/* c8 ignore start */\nimport { AmplifyDynamoDbTableWrapper } from './amplify-dynamodb-table-wrapper';\n/* c8 ignore stop */\n\n/* c8 ignore start */\nimport { CustomSqlDataSourceStrategy, ModelDataSourceStrategy } from './model-datasource-strategy-types';\n/* c8 ignore stop */\n\n/* c8 ignore start */\nimport { Logging } from './log-config-types';\n/* c8 ignore stop */\n\n/**\n * Configuration for IAM Authorization on the Graphql Api.\n * @struct - required since this interface begins with an 'I'\n */\n/* c8 ignore start */\nexport interface IAMAuthorizationConfig {\n  /**\n   * ID for the Cognito Identity Pool vending auth and unauth roles.\n   * Format: `<region>:<id string>`\n   *\n   * @deprecated Use 'IdentityPoolAuthorizationConfig.identityPoolId' instead.\n   * See https://docs.amplify.aws/cli/react/tools/cli/migration/iam-auth-updates-for-cdk-construct for details.\n   */\n  readonly identityPoolId?: string;\n\n  /**\n   * Authenticated user role, applies to { provider: iam, allow: private } access.\n   *\n   * @deprecated Use 'IdentityPoolAuthorizationConfig.authenticatedUserRole' instead.\n   * See https://docs.amplify.aws/cli/react/tools/cli/migration/iam-auth-updates-for-cdk-construct for details.\n   */\n  readonly authenticatedUserRole?: IRole;\n\n  /**\n   * Unauthenticated user role, applies to { provider: iam, allow: public } access.\n   *\n   * @deprecated Use 'IdentityPoolAuthorizationConfig.unauthenticatedUserRole' instead.\n   * See https://docs.amplify.aws/cli/react/tools/cli/migration/iam-auth-updates-for-cdk-construct for details.\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   * @deprecated Use 'enableIamAuthorizationMode' and IAM Policy to control access for IAM principals.\n   * See https://docs.amplify.aws/cli/react/tools/cli/migration/iam-auth-updates-for-cdk-construct for details.\n   */\n  readonly allowListedRoles?: (IRole | string)[];\n\n  /**\n   * Enables access for IAM principals. If enabled @auth directive rules are not applied.\n   * Instead, access should be defined by IAM Policy, see https://docs.aws.amazon.com/service-authorization/latest/reference/list_awsappsync.html.\n   *\n   * Does not apply to authenticated and unauthenticated IAM Roles attached to Cognito Identity Pool.\n   * Use IdentityPoolAuthorizationConfig to configure their access.\n   */\n  readonly enableIamAuthorizationMode?: boolean;\n}\n/* c8 ignore stop */\n\n/**\n * Configuration for Cognito Identity Pool Authorization on the Graphql Api.\n * @struct - required since this interface begins with an 'I'\n */\n/* c8 ignore start */\nexport interface IdentityPoolAuthorizationConfig {\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/* c8 ignore stop */\n\n/**\n * Configuration for Cognito UserPool Authorization on the Graphql Api.\n */\n/* c8 ignore start */\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/* c8 ignore stop */\n\n/**\n * Configuration for OpenId Connect Authorization on the Graphql Api.\n */\n/* c8 ignore start */\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/* c8 ignore stop */\n\n/**\n * Configuration for Api Keys on the Graphql Api.\n */\n/* c8 ignore start */\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/* c8 ignore stop */\n\n/**\n * Configuration for Custom Lambda authorization on the Graphql Api.\n */\n/* c8 ignore start */\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/* c8 ignore stop */\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 */\n/* c8 ignore start */\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 to allow IAM-based access to this API.\n   * This applies to any IAM principal except Amazon Cognito identity pool's authenticated and unauthenticated roles.\n   * This behavior was has recently been improved.\n   * See https://docs.amplify.aws/cli/react/tools/cli/migration/iam-auth-updates-for-cdk-construct for details.\n   */\n  readonly iamConfig?: IAMAuthorizationConfig;\n\n  /**\n   * Cognito Identity Pool config, required if an 'identityPool' auth provider is specified in the Api.\n   * Applies to 'public' and 'private' auth strategies.\n   */\n  readonly identityPoolConfig?: IdentityPoolAuthorizationConfig;\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/* c8 ignore stop */\n\n/**\n * Whether or not to use a version field to track conflict detection.\n */\n/* c8 ignore start */\nexport type ConflictDetectionType = 'VERSION' | 'NONE';\n/* c8 ignore stop */\n\n/**\n * Common parameters for conflict resolution.\n */\n/* c8 ignore start */\nexport interface ConflictResolutionStrategyBase {\n  /**\n   * The conflict detection type used for resolution.\n   */\n  readonly detectionType: ConflictDetectionType;\n}\n/* c8 ignore stop */\n\n/**\n * Enable optimistic concurrency on the project.\n */\n/* c8 ignore start */\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/* c8 ignore stop */\n\n/**\n * Enable automerge on the project.\n */\n/* c8 ignore start */\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/* c8 ignore stop */\n\n/**\n * Enable custom sync on the project, powered by a lambda.\n */\n/* c8 ignore start */\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 */\n/* c8 ignore start */\nexport type ConflictResolutionStrategy =\n  | AutomergeConflictResolutionStrategy\n  | OptimisticConflictResolutionStrategy\n  | CustomConflictResolutionStrategy;\n/* c8 ignore stop */\n\n/**\n * Project level configuration for conflict resolution.\n * @deprecated use DataStoreConfiguration instead.\n */\n/* c8 ignore start */\n// eslint-disable-next-line @typescript-eslint/no-empty-interface\nexport interface ConflictResolution extends DataStoreConfiguration {}\n/* c8 ignore stop */\n\n/**\n * Project level configuration for DataStore\n */\n/* c8 ignore start */\nexport interface DataStoreConfiguration {\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/* c8 ignore stop */\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 */\n/* c8 ignore start */\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/* c8 ignore stop */\n\n/**\n * Common slot parameters.\n */\n/* c8 ignore start */\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/* c8 ignore stop */\n\n/**\n * Slot types for Mutation Resolvers.\n */\n/* c8 ignore start */\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/* c8 ignore stop */\n\n/**\n * Slot types for Query Resolvers.\n */\n/* c8 ignore start */\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/* c8 ignore stop */\n\n/**\n * Slot types for Subscription Resolvers.\n */\n/* c8 ignore start */\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/* c8 ignore stop */\n\n/**\n * Input params to uniquely identify the slot which is being overridden.\n */\n/* c8 ignore start */\nexport type FunctionSlot = MutationFunctionSlot | QueryFunctionSlot | SubscriptionFunctionSlot;\n/* c8 ignore stop */\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 */\n/* c8 ignore start */\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   * When enabled, suppresses default behavior of redacting relational fields when auth rules do not exactly match.\n   * @default false\n   */\n  readonly subscriptionsInheritPrimaryAuth: 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/* c8 ignore stop */\n\n/**\n * A utility interface equivalent to Partial<TranslationBehavior>.\n */\n/* c8 ignore start */\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   * When enabled, suppresses default behavior of redacting relational fields when auth rules do not exactly match.\n   * @default false\n   */\n  readonly subscriptionsInheritPrimaryAuth?: 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   * When enabled, sandbox deployment will be faster by skipping the creation of the Hotswap friendly resources.\n   *\n   * @default false\n   * @internal\n   * WARNING: Although this has `public` access, it is intended for internal use and should not be used directly.\n   * The behavior of this may change without warning.\n   */\n  readonly _provisionHotswapFriendlyResources?: boolean;\n}\n/* c8 ignore stop */\n\n/**\n * Graphql Api definition, which can be implemented in multiple ways.\n */\n/* c8 ignore start */\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   * @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   * @returns a list of mappings from custom SQL commands to data sources\n   */\n  readonly customSqlDataSourceStrategies?: CustomSqlDataSourceStrategy[];\n}\n/* c8 ignore stop */\n\n/**\n * Entry representing the required output from the backend for codegen generate commands to work.\n */\n/* c8 ignore start */\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/* c8 ignore stop */\n\n/**\n * Backend output strategy used to write config required for codegen tasks.\n */\n/* c8 ignore start */\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/* c8 ignore stop */\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 */\n/* c8 ignore start */\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   * @deprecated use dataStoreConfiguration instead.\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.129.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 outputStorageStrategy is provided a default strategy will be used.\n   */\n  readonly outputStorageStrategy?: IBackendOutputStorageStrategy;\n\n  /**\n   * Configure DataStore conflict resolution on the Api. Conflict resolution 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 dataStoreConfiguration?: DataStoreConfiguration;\n\n  /**\n   * Specifies the logging configuration when writing GraphQL operations and tracing to Amazon CloudWatch for an AWS AppSync GraphQL API.\n   */\n  readonly logging?: Logging;\n}\n/* c8 ignore stop */\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 */\n/* c8 ignore start */\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 Amplify DynamoDb Table L1 resource wrapper, keyed by model type name.\n   */\n  readonly amplifyDynamoDbTables: Record<string, AmplifyDynamoDbTableWrapper>;\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/* c8 ignore stop */\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 */\n/* c8 ignore start */\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 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/* c8 ignore stop */\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 */\n/* c8 ignore start */\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/* c8 ignore stop */\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
|
+
## [4.1.9](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-auth-transformer@4.1.8...@aws-amplify/graphql-auth-transformer@4.1.9) (2024-12-23)
|
7
|
+
|
8
|
+
**Note:** Version bump only for package @aws-amplify/graphql-auth-transformer
|
9
|
+
|
10
|
+
## [4.1.8](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-auth-transformer@4.1.7...@aws-amplify/graphql-auth-transformer@4.1.8) (2024-12-17)
|
11
|
+
|
12
|
+
**Note:** Version bump only for package @aws-amplify/graphql-auth-transformer
|
13
|
+
|
6
14
|
## [4.1.7](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-auth-transformer@4.1.6...@aws-amplify/graphql-auth-transformer@4.1.7) (2024-11-14)
|
7
15
|
|
8
16
|
**Note:** Version bump only for package @aws-amplify/graphql-auth-transformer
|
@@ -0,0 +1,201 @@
|
|
1
|
+
Apache License
|
2
|
+
Version 2.0, January 2004
|
3
|
+
http://www.apache.org/licenses/
|
4
|
+
|
5
|
+
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
|
6
|
+
|
7
|
+
1. Definitions.
|
8
|
+
|
9
|
+
"License" shall mean the terms and conditions for use, reproduction,
|
10
|
+
and distribution as defined by Sections 1 through 9 of this document.
|
11
|
+
|
12
|
+
"Licensor" shall mean the copyright owner or entity authorized by
|
13
|
+
the copyright owner that is granting the License.
|
14
|
+
|
15
|
+
"Legal Entity" shall mean the union of the acting entity and all
|
16
|
+
other entities that control, are controlled by, or are under common
|
17
|
+
control with that entity. For the purposes of this definition,
|
18
|
+
"control" means (i) the power, direct or indirect, to cause the
|
19
|
+
direction or management of such entity, whether by contract or
|
20
|
+
otherwise, or (ii) ownership of fifty percent (50%) or more of the
|
21
|
+
outstanding shares, or (iii) beneficial ownership of such entity.
|
22
|
+
|
23
|
+
"You" (or "Your") shall mean an individual or Legal Entity
|
24
|
+
exercising permissions granted by this License.
|
25
|
+
|
26
|
+
"Source" form shall mean the preferred form for making modifications,
|
27
|
+
including but not limited to software source code, documentation
|
28
|
+
source, and configuration files.
|
29
|
+
|
30
|
+
"Object" form shall mean any form resulting from mechanical
|
31
|
+
transformation or translation of a Source form, including but
|
32
|
+
not limited to compiled object code, generated documentation,
|
33
|
+
and conversions to other media types.
|
34
|
+
|
35
|
+
"Work" shall mean the work of authorship, whether in Source or
|
36
|
+
Object form, made available under the License, as indicated by a
|
37
|
+
copyright notice that is included in or attached to the work
|
38
|
+
(an example is provided in the Appendix below).
|
39
|
+
|
40
|
+
"Derivative Works" shall mean any work, whether in Source or Object
|
41
|
+
form, that is based on (or derived from) the Work and for which the
|
42
|
+
editorial revisions, annotations, elaborations, or other modifications
|
43
|
+
represent, as a whole, an original work of authorship. For the purposes
|
44
|
+
of this License, Derivative Works shall not include works that remain
|
45
|
+
separable from, or merely link (or bind by name) to the interfaces of,
|
46
|
+
the Work and Derivative Works thereof.
|
47
|
+
|
48
|
+
"Contribution" shall mean any work of authorship, including
|
49
|
+
the original version of the Work and any modifications or additions
|
50
|
+
to that Work or Derivative Works thereof, that is intentionally
|
51
|
+
submitted to Licensor for inclusion in the Work by the copyright owner
|
52
|
+
or by an individual or Legal Entity authorized to submit on behalf of
|
53
|
+
the copyright owner. For the purposes of this definition, "submitted"
|
54
|
+
means any form of electronic, verbal, or written communication sent
|
55
|
+
to the Licensor or its representatives, including but not limited to
|
56
|
+
communication on electronic mailing lists, source code control systems,
|
57
|
+
and issue tracking systems that are managed by, or on behalf of, the
|
58
|
+
Licensor for the purpose of discussing and improving the Work, but
|
59
|
+
excluding communication that is conspicuously marked or otherwise
|
60
|
+
designated in writing by the copyright owner as "Not a Contribution."
|
61
|
+
|
62
|
+
"Contributor" shall mean Licensor and any individual or Legal Entity
|
63
|
+
on behalf of whom a Contribution has been received by Licensor and
|
64
|
+
subsequently incorporated within the Work.
|
65
|
+
|
66
|
+
2. Grant of Copyright License. Subject to the terms and conditions of
|
67
|
+
this License, each Contributor hereby grants to You a perpetual,
|
68
|
+
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
69
|
+
copyright license to reproduce, prepare Derivative Works of,
|
70
|
+
publicly display, publicly perform, sublicense, and distribute the
|
71
|
+
Work and such Derivative Works in Source or Object form.
|
72
|
+
|
73
|
+
3. Grant of Patent License. Subject to the terms and conditions of
|
74
|
+
this License, each Contributor hereby grants to You a perpetual,
|
75
|
+
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
76
|
+
(except as stated in this section) patent license to make, have made,
|
77
|
+
use, offer to sell, sell, import, and otherwise transfer the Work,
|
78
|
+
where such license applies only to those patent claims licensable
|
79
|
+
by such Contributor that are necessarily infringed by their
|
80
|
+
Contribution(s) alone or by combination of their Contribution(s)
|
81
|
+
with the Work to which such Contribution(s) was submitted. If You
|
82
|
+
institute patent litigation against any entity (including a
|
83
|
+
cross-claim or counterclaim in a lawsuit) alleging that the Work
|
84
|
+
or a Contribution incorporated within the Work constitutes direct
|
85
|
+
or contributory patent infringement, then any patent licenses
|
86
|
+
granted to You under this License for that Work shall terminate
|
87
|
+
as of the date such litigation is filed.
|
88
|
+
|
89
|
+
4. Redistribution. You may reproduce and distribute copies of the
|
90
|
+
Work or Derivative Works thereof in any medium, with or without
|
91
|
+
modifications, and in Source or Object form, provided that You
|
92
|
+
meet the following conditions:
|
93
|
+
|
94
|
+
(a) You must give any other recipients of the Work or
|
95
|
+
Derivative Works a copy of this License; and
|
96
|
+
|
97
|
+
(b) You must cause any modified files to carry prominent notices
|
98
|
+
stating that You changed the files; and
|
99
|
+
|
100
|
+
(c) You must retain, in the Source form of any Derivative Works
|
101
|
+
that You distribute, all copyright, patent, trademark, and
|
102
|
+
attribution notices from the Source form of the Work,
|
103
|
+
excluding those notices that do not pertain to any part of
|
104
|
+
the Derivative Works; and
|
105
|
+
|
106
|
+
(d) If the Work includes a "NOTICE" text file as part of its
|
107
|
+
distribution, then any Derivative Works that You distribute must
|
108
|
+
include a readable copy of the attribution notices contained
|
109
|
+
within such NOTICE file, excluding those notices that do not
|
110
|
+
pertain to any part of the Derivative Works, in at least one
|
111
|
+
of the following places: within a NOTICE text file distributed
|
112
|
+
as part of the Derivative Works; within the Source form or
|
113
|
+
documentation, if provided along with the Derivative Works; or,
|
114
|
+
within a display generated by the Derivative Works, if and
|
115
|
+
wherever such third-party notices normally appear. The contents
|
116
|
+
of the NOTICE file are for informational purposes only and
|
117
|
+
do not modify the License. You may add Your own attribution
|
118
|
+
notices within Derivative Works that You distribute, alongside
|
119
|
+
or as an addendum to the NOTICE text from the Work, provided
|
120
|
+
that such additional attribution notices cannot be construed
|
121
|
+
as modifying the License.
|
122
|
+
|
123
|
+
You may add Your own copyright statement to Your modifications and
|
124
|
+
may provide additional or different license terms and conditions
|
125
|
+
for use, reproduction, or distribution of Your modifications, or
|
126
|
+
for any such Derivative Works as a whole, provided Your use,
|
127
|
+
reproduction, and distribution of the Work otherwise complies with
|
128
|
+
the conditions stated in this License.
|
129
|
+
|
130
|
+
5. Submission of Contributions. Unless You explicitly state otherwise,
|
131
|
+
any Contribution intentionally submitted for inclusion in the Work
|
132
|
+
by You to the Licensor shall be under the terms and conditions of
|
133
|
+
this License, without any additional terms or conditions.
|
134
|
+
Notwithstanding the above, nothing herein shall supersede or modify
|
135
|
+
the terms of any separate license agreement you may have executed
|
136
|
+
with Licensor regarding such Contributions.
|
137
|
+
|
138
|
+
6. Trademarks. This License does not grant permission to use the trade
|
139
|
+
names, trademarks, service marks, or product names of the Licensor,
|
140
|
+
except as required for reasonable and customary use in describing the
|
141
|
+
origin of the Work and reproducing the content of the NOTICE file.
|
142
|
+
|
143
|
+
7. Disclaimer of Warranty. Unless required by applicable law or
|
144
|
+
agreed to in writing, Licensor provides the Work (and each
|
145
|
+
Contributor provides its Contributions) on an "AS IS" BASIS,
|
146
|
+
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
147
|
+
implied, including, without limitation, any warranties or conditions
|
148
|
+
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
|
149
|
+
PARTICULAR PURPOSE. You are solely responsible for determining the
|
150
|
+
appropriateness of using or redistributing the Work and assume any
|
151
|
+
risks associated with Your exercise of permissions under this License.
|
152
|
+
|
153
|
+
8. Limitation of Liability. In no event and under no legal theory,
|
154
|
+
whether in tort (including negligence), contract, or otherwise,
|
155
|
+
unless required by applicable law (such as deliberate and grossly
|
156
|
+
negligent acts) or agreed to in writing, shall any Contributor be
|
157
|
+
liable to You for damages, including any direct, indirect, special,
|
158
|
+
incidental, or consequential damages of any character arising as a
|
159
|
+
result of this License or out of the use or inability to use the
|
160
|
+
Work (including but not limited to damages for loss of goodwill,
|
161
|
+
work stoppage, computer failure or malfunction, or any and all
|
162
|
+
other commercial damages or losses), even if such Contributor
|
163
|
+
has been advised of the possibility of such damages.
|
164
|
+
|
165
|
+
9. Accepting Warranty or Additional Liability. While redistributing
|
166
|
+
the Work or Derivative Works thereof, You may choose to offer,
|
167
|
+
and charge a fee for, acceptance of support, warranty, indemnity,
|
168
|
+
or other liability obligations and/or rights consistent with this
|
169
|
+
License. However, in accepting such obligations, You may act only
|
170
|
+
on Your own behalf and on Your sole responsibility, not on behalf
|
171
|
+
of any other Contributor, and only if You agree to indemnify,
|
172
|
+
defend, and hold each Contributor harmless for any liability
|
173
|
+
incurred by, or claims asserted against, such Contributor by reason
|
174
|
+
of your accepting any such warranty or additional liability.
|
175
|
+
|
176
|
+
END OF TERMS AND CONDITIONS
|
177
|
+
|
178
|
+
APPENDIX: How to apply the Apache License to your work.
|
179
|
+
|
180
|
+
To apply the Apache License to your work, attach the following
|
181
|
+
boilerplate notice, with the fields enclosed by brackets "{}"
|
182
|
+
replaced with your own identifying information. (Don't include
|
183
|
+
the brackets!) The text should be enclosed in the appropriate
|
184
|
+
comment syntax for the file format. We also recommend that a
|
185
|
+
file or class name and description of purpose be included on the
|
186
|
+
same "printed page" as the copyright notice for easier
|
187
|
+
identification within third-party archives.
|
188
|
+
|
189
|
+
Copyright 2017 - 2022 Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
190
|
+
|
191
|
+
Licensed under the Apache License, Version 2.0 (the "License");
|
192
|
+
you may not use this file except in compliance with the License.
|
193
|
+
You may obtain a copy of the License at
|
194
|
+
|
195
|
+
http://www.apache.org/licenses/LICENSE-2.0
|
196
|
+
|
197
|
+
Unless required by applicable law or agreed to in writing, software
|
198
|
+
distributed under the License is distributed on an "AS IS" BASIS,
|
199
|
+
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
200
|
+
See the License for the specific language governing permissions and
|
201
|
+
limitations under the License.
|
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@aws-amplify/graphql-auth-transformer",
|
3
|
-
"version": "4.1.
|
3
|
+
"version": "4.1.9",
|
4
4
|
"description": "Amplify GraphQL @auth transformer",
|
5
5
|
"repository": {
|
6
6
|
"type": "git",
|
@@ -30,67 +30,28 @@
|
|
30
30
|
"extract-api": "ts-node ../../scripts/extract-api.ts"
|
31
31
|
},
|
32
32
|
"dependencies": {
|
33
|
-
"@aws-amplify/graphql-directives": "2.6.
|
34
|
-
"@aws-amplify/graphql-model-transformer": "3.1.
|
35
|
-
"@aws-amplify/graphql-relational-transformer": "3.1.
|
36
|
-
"@aws-amplify/graphql-transformer-core": "3.3.
|
37
|
-
"@aws-amplify/graphql-transformer-interfaces": "4.2.
|
33
|
+
"@aws-amplify/graphql-directives": "2.6.1",
|
34
|
+
"@aws-amplify/graphql-model-transformer": "3.1.3",
|
35
|
+
"@aws-amplify/graphql-relational-transformer": "3.1.3",
|
36
|
+
"@aws-amplify/graphql-transformer-core": "3.3.3",
|
37
|
+
"@aws-amplify/graphql-transformer-interfaces": "4.2.1",
|
38
38
|
"graphql": "^15.5.0",
|
39
|
-
"graphql-mapping-template": "5.0.
|
40
|
-
"graphql-transformer-common": "5.1.
|
39
|
+
"graphql-mapping-template": "5.0.2",
|
40
|
+
"graphql-transformer-common": "5.1.2",
|
41
41
|
"lodash": "^4.17.21",
|
42
42
|
"md5": "^2.3.0"
|
43
43
|
},
|
44
44
|
"devDependencies": {
|
45
|
-
"@aws-amplify/graphql-function-transformer": "3.1.
|
46
|
-
"@aws-amplify/graphql-index-transformer": "3.0.
|
47
|
-
"@aws-amplify/graphql-searchable-transformer": "3.0.
|
48
|
-
"@aws-amplify/graphql-sql-transformer": "0.4.
|
49
|
-
"@aws-amplify/graphql-transformer-test-utils": "1.0.
|
45
|
+
"@aws-amplify/graphql-function-transformer": "3.1.8",
|
46
|
+
"@aws-amplify/graphql-index-transformer": "3.0.11",
|
47
|
+
"@aws-amplify/graphql-searchable-transformer": "3.0.11",
|
48
|
+
"@aws-amplify/graphql-sql-transformer": "0.4.11",
|
49
|
+
"@aws-amplify/graphql-transformer-test-utils": "1.0.10",
|
50
50
|
"@types/node": "^18.0.0"
|
51
51
|
},
|
52
52
|
"peerDependencies": {
|
53
|
-
"aws-cdk-lib": "^2.
|
53
|
+
"aws-cdk-lib": "^2.168.0",
|
54
54
|
"constructs": "^10.3.0"
|
55
55
|
},
|
56
|
-
"
|
57
|
-
"testEnvironmentOptions": {
|
58
|
-
"url": "http://localhost"
|
59
|
-
},
|
60
|
-
"transform": {
|
61
|
-
"^.+\\.tsx?$": "ts-jest"
|
62
|
-
},
|
63
|
-
"testRegex": "(src/__tests__/.*.test.ts)$",
|
64
|
-
"moduleFileExtensions": [
|
65
|
-
"ts",
|
66
|
-
"tsx",
|
67
|
-
"js",
|
68
|
-
"jsx",
|
69
|
-
"json",
|
70
|
-
"node"
|
71
|
-
],
|
72
|
-
"collectCoverage": true,
|
73
|
-
"coverageProvider": "v8",
|
74
|
-
"coverageThreshold": {
|
75
|
-
"global": {
|
76
|
-
"branches": 88,
|
77
|
-
"functions": 90,
|
78
|
-
"lines": 90
|
79
|
-
}
|
80
|
-
},
|
81
|
-
"coverageReporters": [
|
82
|
-
"clover",
|
83
|
-
"text"
|
84
|
-
],
|
85
|
-
"collectCoverageFrom": [
|
86
|
-
"src/**/*.ts"
|
87
|
-
],
|
88
|
-
"coveragePathIgnorePatterns": [
|
89
|
-
"/__tests__/"
|
90
|
-
],
|
91
|
-
"snapshotFormat": {
|
92
|
-
"escapeString": true,
|
93
|
-
"printBasicPrototype": true
|
94
|
-
}
|
95
|
-
}
|
56
|
+
"gitHead": "a1ec8b0438f8177d3bde902a040f285bd78bc7cb"
|
96
57
|
}
|
@@ -3,11 +3,15 @@
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
5
5
|
|
6
|
-
## [1.1.
|
6
|
+
## [1.1.4](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-conversation-transformer@1.1.3...@aws-amplify/graphql-conversation-transformer@1.1.4) (2024-12-23)
|
7
|
+
|
8
|
+
**Note:** Version bump only for package @aws-amplify/graphql-conversation-transformer
|
9
|
+
|
10
|
+
## [1.1.3](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-conversation-transformer@1.1.2...@aws-amplify/graphql-conversation-transformer@1.1.3) (2024-12-17)
|
7
11
|
|
8
12
|
### Bug Fixes
|
9
13
|
|
10
|
-
- **conversation:** handle enums in data tool selection sets ([
|
14
|
+
- **conversation:** handle enums in data tool selection sets ([#3045](https://github.com/aws-amplify/amplify-category-api/issues/3045)) ([7466aaa](https://github.com/aws-amplify/amplify-category-api/commit/7466aaaf8e6779cd72899701ae5e7e3df665e9de))
|
11
15
|
|
12
16
|
## [1.1.2](https://github.com/aws-amplify/amplify-category-api/compare/@aws-amplify/graphql-conversation-transformer@1.1.1...@aws-amplify/graphql-conversation-transformer@1.1.2) (2024-11-20)
|
13
17
|
|
@@ -0,0 +1,10 @@
|
|
1
|
+
const baseConfig = require('../../jest.config.base.js'); // eslint-disable-line @typescript-eslint/no-var-requires
|
2
|
+
|
3
|
+
module.exports = {
|
4
|
+
...baseConfig,
|
5
|
+
modulePathIgnorePatterns: ['templates'],
|
6
|
+
snapshotFormat: {
|
7
|
+
escapeString: false,
|
8
|
+
printBasicPrototype: false,
|
9
|
+
},
|
10
|
+
};
|