@aws-amplify/graphql-api-construct
Version:
AppSync GraphQL Api Construct using Amplify GraphQL Transformer.
116 lines • 19.1 kB
JavaScript
;
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.AmplifyDynamoDbTableWrapper = exports.SSEType = void 0;
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const aws_cdk_lib_1 = require("aws-cdk-lib");
const AMPLIFY_DYNAMODB_TABLE_RESOURCE_TYPE = 'Custom::AmplifyDynamoDBTable';
/**
* Server Side Encryption Type Values
* - `KMS` - Server-side encryption that uses AWS KMS. The key is stored in your account and is managed by KMS (AWS KMS charges apply).
*/
var SSEType;
(function (SSEType) {
SSEType["KMS"] = "KMS";
})(SSEType || (exports.SSEType = SSEType = {}));
/**
* Wrapper class around Custom::AmplifyDynamoDBTable custom resource, to simplify
* the override experience a bit. This is NOT a construct, just an easier way to access
* the generated construct.
* This is a wrapper intended to mimic the `aws_cdk_lib.aws_dynamodb.Table` functionality more-or-less.
* Notable differences is the addition of TKTK properties, to account for the fact that they're constructor props
* in the CDK construct, as well as the removal of all from*, grant*, and metric* methods implemented by Table.
*/
class AmplifyDynamoDbTableWrapper {
/**
* Return true and perform type narrowing if a given input appears to be capable of
* @param x the object to check.
* @returns whether or not the resource is an underlying amplify dynamodb table resource.
*/
static isAmplifyDynamoDbTableResource(x) {
return x instanceof aws_cdk_lib_1.CfnResource && x.cfnResourceType === AMPLIFY_DYNAMODB_TABLE_RESOURCE_TYPE;
}
/**
* Create the wrapper given an underlying CfnResource that is an instance of Custom::AmplifyDynamoDBTable.
* @param resource the Cfn resource.
*/
constructor(resource) {
this.resource = resource;
if (resource.cfnResourceType !== AMPLIFY_DYNAMODB_TABLE_RESOURCE_TYPE) {
throw new Error(`Only CfnResource with type ${AMPLIFY_DYNAMODB_TABLE_RESOURCE_TYPE} can be used in AmplifyDynamoDbTable`);
}
}
/**
* Set the deletion policy of the resource based on the removal policy specified.
* @param policy removal policy to set
*/
applyRemovalPolicy(policy) {
this.resource.applyRemovalPolicy(policy);
}
/**
* Specify how you are charged for read and write throughput and how you manage capacity.
*/
set billingMode(billingMode) {
this.resource.addPropertyOverride('billingMode', billingMode);
}
/**
* The name of TTL attribute.
*/
set timeToLiveAttribute(timeToLiveSpecification) {
this.resource.addPropertyOverride('timeToLiveSpecification', timeToLiveSpecification);
}
/**
* Whether point-in-time recovery is enabled.
*/
set pointInTimeRecoveryEnabled(pointInTimeRecoveryEnabled) {
this.resource.addPropertyOverride('pointInTimeRecoverySpecification', { pointInTimeRecoveryEnabled });
}
/**
* Whether point-in-time recovery is enabled
* and recoveryPeriodInDays is set.
*/
set pointInTimeRecoverySpecification(pointInTimeRecoverySpecification) {
this.resource.addPropertyOverride('pointInTimeRecoverySpecification', pointInTimeRecoverySpecification);
}
/**
* Update the provisioned throughput for the base table.
*/
set provisionedThroughput(provisionedThroughput) {
this.resource.addPropertyOverride('provisionedThroughput', provisionedThroughput);
}
/**
* Set the provisionedThroughtput for a specified GSI by name.
* @param indexName the index to specify a provisionedThroughput config for
* @param provisionedThroughput the config to set
*/
setGlobalSecondaryIndexProvisionedThroughput(indexName, provisionedThroughput) {
const gsis = Object.entries(this.resource.rawOverrides?.Properties?.globalSecondaryIndexes ?? {});
const foundGsis = gsis.filter(([_, gsiConfig]) => indexName === gsiConfig.indexName).map(([gsiIndex]) => gsiIndex);
if (foundGsis.length !== 1) {
throw new Error(`Index with name ${indexName} not found in table definition`);
}
this.resource.addPropertyOverride(`globalSecondaryIndexes.${foundGsis[0]}.provisionedThroughput`, provisionedThroughput);
}
/**
* Set the ddb stream specification on the table.
*/
set streamSpecification(streamSpecification) {
this.resource.addPropertyOverride('streamSpecification', streamSpecification);
}
/**
* Set the ddb server-side encryption specification on the table.
*/
set sseSpecification(sseSpecification) {
this.resource.addPropertyOverride('sseSpecification', sseSpecification);
}
/**
* Set table deletion protection.
*/
set deletionProtectionEnabled(deletionProtectionEnabled) {
this.resource.addPropertyOverride('deletionProtectionEnabled', deletionProtectionEnabled);
}
}
exports.AmplifyDynamoDbTableWrapper = AmplifyDynamoDbTableWrapper;
_a = JSII_RTTI_SYMBOL_1;
AmplifyDynamoDbTableWrapper[_a] = { fqn: "@aws-amplify/graphql-api-construct.AmplifyDynamoDbTableWrapper", version: "1.20.3" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"amplify-dynamodb-table-wrapper.js","sourceRoot":"","sources":["../src/amplify-dynamodb-table-wrapper.ts"],"names":[],"mappings":"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","sourcesContent":["import { CfnResource, RemovalPolicy } from 'aws-cdk-lib';\nimport { BillingMode, StreamViewType } from 'aws-cdk-lib/aws-dynamodb';\n\nconst AMPLIFY_DYNAMODB_TABLE_RESOURCE_TYPE = 'Custom::AmplifyDynamoDBTable';\n\n/**\n * Shape for TTL config.\n */\nexport interface TimeToLiveSpecification {\n  /**\n   * Boolean determining if the ttl is enabled or not.\n   */\n  readonly enabled: boolean;\n\n  /**\n   * Attribute name to apply to the ttl spec.\n   */\n  readonly attributeName?: string;\n}\n\n/**\n * Reference to PointInTimeRecovey Specification\n * for continuous backups\n */\nexport interface PointInTimeRecoverySpecification {\n  /**\n   * Indicates whether point in time recovery is enabled (true) or disabled (false) on the table.\n   */\n  readonly pointInTimeRecoveryEnabled: boolean;\n  /**\n   * The number of preceding days for which continuous backups are taken and maintained.\n   * Your table data is only recoverable to any point-in-time from within the configured recovery period.\n   * If no value is provided, the value will default to 35.\n   */\n  readonly recoveryPeriodInDays?: number;\n}\n\n/**\n * Wrapper for provisioned throughput config in DDB.\n */\nexport interface ProvisionedThroughput {\n  /**\n   * The read capacity units on the table or index.\n   */\n  readonly readCapacityUnits: number;\n\n  /**\n   * The write capacity units on the table or index.\n   */\n  readonly writeCapacityUnits: number;\n}\n\n/**\n * Server Side Encryption Type Values\n * - `KMS` - Server-side encryption that uses AWS KMS. The key is stored in your account and is managed by KMS (AWS KMS charges apply).\n */\nexport enum SSEType {\n  KMS = 'KMS',\n}\n\n/**\n * Represents the settings used to enable server-side encryption.\n */\nexport interface SSESpecification {\n  /**\n   * Indicates whether server-side encryption is done using an AWS managed key or an AWS owned key.\n   * If enabled (true), server-side encryption type is set to `KMS` and an AWS managed key is used ( AWS KMS charges apply).\n   * If disabled (false) or not specified, server-side encryption is set to AWS owned key.\n   */\n  readonly sseEnabled: boolean;\n\n  /**\n   * The AWS KMS key that should be used for the AWS KMS encryption.\n   * To specify a key, use its key ID, Amazon Resource Name (ARN), alias name, or alias ARN. Note that you should only provide\n   * this parameter if the key is different from the default DynamoDB key `alias/aws/dynamodb` .\n   */\n  readonly kmsMasterKeyId?: string;\n\n  /**\n   * Server-side encryption type. The only supported value is:\n   * `KMS` Server-side encryption that uses AWS Key Management Service.\n   *   The key is stored in your account and is managed by AWS KMS ( AWS KMS charges apply).\n   */\n  readonly sseType?: SSEType;\n}\n\n/**\n * Represents the DynamoDB Streams configuration for a table in DynamoDB.\n */\nexport interface StreamSpecification {\n  /**\n   * When an item in the table is modified, `StreamViewType` determines what information is written to the stream for this table.\n   * Valid values for `StreamViewType` are:\n   * - `KEYS_ONLY` - Only the key attributes of the modified item are written to the stream.\n   * - `NEW_IMAGE` - The entire item, as it appears after it was modified, is written to the stream.\n   * - `OLD_IMAGE` - The entire item, as it appeared before it was modified, is written to the stream.\n   * - `NEW_AND_OLD_IMAGES` - Both the new and the old item images of the item are written to the stream.\n   */\n  readonly streamViewType: StreamViewType;\n}\n\n/**\n * Wrapper class around Custom::AmplifyDynamoDBTable custom resource, to simplify\n * the override experience a bit. This is NOT a construct, just an easier way to access\n * the generated construct.\n * This is a wrapper intended to mimic the `aws_cdk_lib.aws_dynamodb.Table` functionality more-or-less.\n * Notable differences is the addition of TKTK properties, to account for the fact that they're constructor props\n * in the CDK construct, as well as the removal of all from*, grant*, and metric* methods implemented by Table.\n */\nexport class AmplifyDynamoDbTableWrapper {\n  /**\n   * Return true and perform type narrowing if a given input appears to be capable of\n   * @param x the object to check.\n   * @returns whether or not the resource is an underlying amplify dynamodb table resource.\n   */\n  static isAmplifyDynamoDbTableResource(x: any): x is CfnResource {\n    return x instanceof CfnResource && x.cfnResourceType === AMPLIFY_DYNAMODB_TABLE_RESOURCE_TYPE;\n  }\n\n  /**\n   * Create the wrapper given an underlying CfnResource that is an instance of Custom::AmplifyDynamoDBTable.\n   * @param resource the Cfn resource.\n   */\n  constructor(private readonly resource: CfnResource) {\n    if (resource.cfnResourceType !== AMPLIFY_DYNAMODB_TABLE_RESOURCE_TYPE) {\n      throw new Error(`Only CfnResource with type ${AMPLIFY_DYNAMODB_TABLE_RESOURCE_TYPE} can be used in AmplifyDynamoDbTable`);\n    }\n  }\n\n  /**\n   * Set the deletion policy of the resource based on the removal policy specified.\n   * @param policy removal policy to set\n   */\n  applyRemovalPolicy(policy: RemovalPolicy): void {\n    this.resource.applyRemovalPolicy(policy);\n  }\n\n  /**\n   * Specify how you are charged for read and write throughput and how you manage capacity.\n   */\n  set billingMode(billingMode: BillingMode) {\n    this.resource.addPropertyOverride('billingMode', billingMode);\n  }\n\n  /**\n   * The name of TTL attribute.\n   */\n  set timeToLiveAttribute(timeToLiveSpecification: TimeToLiveSpecification) {\n    this.resource.addPropertyOverride('timeToLiveSpecification', timeToLiveSpecification);\n  }\n\n  /**\n   * Whether point-in-time recovery is enabled.\n   */\n  set pointInTimeRecoveryEnabled(pointInTimeRecoveryEnabled: boolean) {\n    this.resource.addPropertyOverride('pointInTimeRecoverySpecification', { pointInTimeRecoveryEnabled });\n  }\n\n  /**\n   * Whether point-in-time recovery is enabled\n   * and recoveryPeriodInDays is set.\n   */\n  set pointInTimeRecoverySpecification(pointInTimeRecoverySpecification: PointInTimeRecoverySpecification) {\n    this.resource.addPropertyOverride('pointInTimeRecoverySpecification', pointInTimeRecoverySpecification);\n  }\n\n  /**\n   * Update the provisioned throughput for the base table.\n   */\n  set provisionedThroughput(provisionedThroughput: ProvisionedThroughput) {\n    this.resource.addPropertyOverride('provisionedThroughput', provisionedThroughput);\n  }\n\n  /**\n   * Set the provisionedThroughtput for a specified GSI by name.\n   * @param indexName the index to specify a provisionedThroughput config for\n   * @param provisionedThroughput the config to set\n   */\n  setGlobalSecondaryIndexProvisionedThroughput(indexName: string, provisionedThroughput: ProvisionedThroughput): void {\n    const gsis: Array<[string, { indexName: string }]> = Object.entries(\n      (this.resource as any).rawOverrides?.Properties?.globalSecondaryIndexes ?? {},\n    );\n    const foundGsis = gsis.filter(([_, gsiConfig]) => indexName === gsiConfig.indexName).map(([gsiIndex]) => gsiIndex);\n    if (foundGsis.length !== 1) {\n      throw new Error(`Index with name ${indexName} not found in table definition`);\n    }\n    this.resource.addPropertyOverride(`globalSecondaryIndexes.${foundGsis[0]}.provisionedThroughput`, provisionedThroughput);\n  }\n\n  /**\n   * Set the ddb stream specification on the table.\n   */\n  set streamSpecification(streamSpecification: StreamSpecification) {\n    this.resource.addPropertyOverride('streamSpecification', streamSpecification);\n  }\n\n  /**\n   * Set the ddb server-side encryption specification on the table.\n   */\n  set sseSpecification(sseSpecification: SSESpecification) {\n    this.resource.addPropertyOverride('sseSpecification', sseSpecification);\n  }\n\n  /**\n   * Set table deletion protection.\n   */\n  set deletionProtectionEnabled(deletionProtectionEnabled: boolean) {\n    this.resource.addPropertyOverride('deletionProtectionEnabled', deletionProtectionEnabled);\n  }\n}\n"]}