@aws-solutions-constructs/core
Version:
Core CDK Construct for patterns library
99 lines • 17.3 kB
JavaScript
/**
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance
* with the License. A copy of the License is located at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* or in the 'license' file accompanying this file. This file is distributed on an 'AS IS' BASIS, WITHOUT WARRANTIES
* OR CONDITIONS OF ANY KIND, express or implied. See the License for the specific language governing permissions
* and limitations under the License.
*/
Object.defineProperty(exports, "__esModule", { value: true });
exports.buildDynamoDBTable = buildDynamoDBTable;
exports.buildDynamoDBTableWithStream = buildDynamoDBTableWithStream;
exports.getPartitionKeyNameFromTable = getPartitionKeyNameFromTable;
exports.CheckDynamoDBProps = CheckDynamoDBProps;
/*
* The functions found here in the core library are for internal use and can be changed
* or removed outside of a major release. We recommend against calling them directly from client code.
*/
const dynamodb = require("aws-cdk-lib/aws-dynamodb");
const dynamodb_table_defaults_1 = require("./dynamodb-table-defaults");
const utils_1 = require("./utils");
/**
* @internal This is an internal core function and should not be called directly by Solutions Constructs clients.
*/
function buildDynamoDBTable(scope, props) {
// Conditional DynamoDB Table creation
if (props.existingTableObj) {
return { tableInterface: props.existingTableObj, tableObject: props.existingTableObj };
}
else if (props.existingTableInterface) {
return { tableInterface: props.existingTableInterface };
}
else {
const consolidatedTableProps = (0, utils_1.consolidateProps)((0, dynamodb_table_defaults_1.GetDefaultTableProps)(props.dynamoTableProps), props.dynamoTableProps);
const newTable = new dynamodb.Table(scope, 'DynamoTable', consolidatedTableProps);
// AWS Managed encryption keys is acceptable under published best practices
// https://docs.aws.amazon.com/amazondynamodb/latest/developerguide/best-practices-security-preventative.html
(0, utils_1.addCfnGuardSuppressRules)(newTable, ["DYNAMODB_TABLE_ENCRYPTED_KMS"]);
return { tableInterface: newTable, tableObject: newTable };
}
}
/**
* @internal This is an internal core function and should not be called directly by Solutions Constructs clients.
*/
function buildDynamoDBTableWithStream(scope, props) {
// Conditional DynamoDB Table creation
if (!props.existingTableInterface) {
// Set the default props for DynamoDB table
const dynamoTableProps = (0, utils_1.consolidateProps)((0, dynamodb_table_defaults_1.GetDefaultTableWithStreamProps)(props.dynamoTableProps), props.dynamoTableProps);
const dynamoTable = new dynamodb.Table(scope, 'DynamoTable', dynamoTableProps);
// AWS Managed encryption keys is acceptable under published best practices
// https://docs.aws.amazon.com/amazondynamodb/latest/developerguide/best-practices-security-preventative.html
(0, utils_1.addCfnGuardSuppressRules)(dynamoTable, ["DYNAMODB_TABLE_ENCRYPTED_KMS"]);
return { tableInterface: dynamoTable, tableObject: dynamoTable };
}
else {
return { tableInterface: props.existingTableInterface };
}
}
/**
* @internal This is an internal core function and should not be called directly by Solutions Constructs clients.
*/
function getPartitionKeyNameFromTable(table) {
const cfnTable = table.node.findChild('Resource');
const keySchema = cfnTable.keySchema;
const partitionKey = keySchema.find((keyPart) => keyPart.keyType === 'HASH');
if (!partitionKey) {
throw new Error('Partition key for table not defined');
}
return partitionKey.attributeName;
}
function CheckDynamoDBProps(propsObject) {
let errorMessages = '';
let errorFound = false;
if (propsObject.dynamoTableProps && propsObject.existingTableObj) {
errorMessages += 'Error - Either provide existingTableObj or dynamoTableProps, but not both.\n';
errorFound = true;
}
if (propsObject.dynamoTableProps && propsObject.existingTableInterface) {
errorMessages += 'Error - Either provide existingTableInterface or dynamoTableProps, but not both.\n';
errorFound = true;
}
if (propsObject.existingTableObj && propsObject.existingTableInterface) {
errorMessages += 'Error - Either provide existingTableInterface or existingTableObj, but not both.\n';
errorFound = true;
}
if (propsObject.pointInTimeRecovery && propsObject.pointInTimeRecoverySpecification) {
errorMessages += 'Error - Either provide pointInTimeRecovery or pointInTimeRecoverySpecification, but not both.\n';
errorFound = true;
}
if (errorFound) {
throw new Error(errorMessages);
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamodb-table-helper.js","sourceRoot":"","sources":["dynamodb-table-helper.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n *  Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n *\n *  Licensed under the Apache License, Version 2.0 (the \"License\"). You may not use this file except in compliance\n *  with the License. A copy of the License is located at\n *\n *      http://www.apache.org/licenses/LICENSE-2.0\n *\n *  or in the 'license' file accompanying this file. This file is distributed on an 'AS IS' BASIS, WITHOUT WARRANTIES\n *  OR CONDITIONS OF ANY KIND, express or implied. See the License for the specific language governing permissions\n *  and limitations under the License.\n */\n\n/*\n *  The functions found here in the core library are for internal use and can be changed\n *  or removed outside of a major release. We recommend against calling them directly from client code.\n */\n\nimport * as dynamodb from 'aws-cdk-lib/aws-dynamodb';\nimport { GetDefaultTableProps, GetDefaultTableWithStreamProps } from './dynamodb-table-defaults';\nimport { addCfnGuardSuppressRules, consolidateProps } from './utils';\n// Note: To ensure CDKv2 compatibility, keep the import statement for Construct separate\nimport { Construct } from 'constructs';\n\nexport interface BuildDynamoDBTableProps {\n  /**\n   * Optional user provided props to override the default props\n   *\n   * @default - Default props are used\n   */\n  readonly dynamoTableProps?: dynamodb.TableProps,\n  /**\n   * Existing instance of dynamodb table object.\n   * Providing both this and `dynamoTableProps` will cause an error.\n   *\n   * @default - None\n   */\n  readonly existingTableObj?: dynamodb.Table\n  /**\n   * Existing instance of dynamodb interface.\n   * Providing both this and `dynamoTableProps` will cause an error.\n   *\n   * @default - None\n   */\n  readonly existingTableInterface?: dynamodb.ITable\n}\n\nexport interface BuildDynamoDBTableWithStreamProps {\n  /**\n   * Optional user provided props to override the default props\n   *\n   * @default - Default props are used\n   */\n  readonly dynamoTableProps?: dynamodb.TableProps,\n  /**\n   * Existing instance of dynamodb table object.\n   * Providing both this and `dynamoTableProps` will cause an error.\n   *\n   * @default - None\n   */\n  readonly existingTableInterface?: dynamodb.ITable\n}\n\nexport interface BuildDynamoDBTableResponse {\n  readonly tableInterface: dynamodb.ITable,\n  readonly tableObject?: dynamodb.Table,\n}\n\n/**\n * @internal This is an internal core function and should not be called directly by Solutions Constructs clients.\n */\nexport function buildDynamoDBTable(scope: Construct, props: BuildDynamoDBTableProps): BuildDynamoDBTableResponse {\n\n  // Conditional DynamoDB Table creation\n  if (props.existingTableObj) {\n    return { tableInterface: props.existingTableObj, tableObject: props.existingTableObj };\n  } else if (props.existingTableInterface) {\n    return { tableInterface: props.existingTableInterface };\n  } else {\n    const consolidatedTableProps = consolidateProps(GetDefaultTableProps(props.dynamoTableProps), props.dynamoTableProps);\n    const newTable = new dynamodb.Table(scope, 'DynamoTable', consolidatedTableProps);\n    // AWS Managed encryption keys is acceptable under published best practices\n    // https://docs.aws.amazon.com/amazondynamodb/latest/developerguide/best-practices-security-preventative.html\n    addCfnGuardSuppressRules(newTable, [\"DYNAMODB_TABLE_ENCRYPTED_KMS\"]);\n    return { tableInterface: newTable, tableObject: newTable };\n  }\n}\n\nexport interface BuildDynamoDBTableWithStreamResponse {\n  readonly tableInterface: dynamodb.ITable,\n  readonly tableObject?: dynamodb.Table,\n}\n\n/**\n * @internal This is an internal core function and should not be called directly by Solutions Constructs clients.\n */\nexport function buildDynamoDBTableWithStream(scope: Construct, props: BuildDynamoDBTableWithStreamProps): BuildDynamoDBTableWithStreamResponse {\n  // Conditional DynamoDB Table creation\n  if (!props.existingTableInterface) {\n    // Set the default props for DynamoDB table\n    const dynamoTableProps = consolidateProps(GetDefaultTableWithStreamProps(props.dynamoTableProps), props.dynamoTableProps);\n    const dynamoTable: dynamodb.Table = new dynamodb.Table(scope, 'DynamoTable', dynamoTableProps);\n    // AWS Managed encryption keys is acceptable under published best practices\n    // https://docs.aws.amazon.com/amazondynamodb/latest/developerguide/best-practices-security-preventative.html\n    addCfnGuardSuppressRules(dynamoTable, [\"DYNAMODB_TABLE_ENCRYPTED_KMS\"]);\n    return { tableInterface: dynamoTable, tableObject: dynamoTable };\n  } else {\n    return { tableInterface: props.existingTableInterface };\n  }\n}\n\n/**\n * @internal This is an internal core function and should not be called directly by Solutions Constructs clients.\n */\nexport function getPartitionKeyNameFromTable(table: dynamodb.Table): string {\n  const cfnTable = table.node.findChild('Resource') as dynamodb.CfnTable;\n  const keySchema = cfnTable.keySchema as dynamodb.CfnTable.KeySchemaProperty[];\n  const partitionKey = keySchema.find((keyPart: any) => keyPart.keyType === 'HASH');\n  if (!partitionKey) {\n    throw new Error('Partition key for table not defined');\n  }\n  return partitionKey.attributeName;\n}\n\nexport interface DynamoDBProps {\n  readonly dynamoTableProps?: dynamodb.TableProps,\n  readonly existingTableObj?: dynamodb.Table,\n  readonly existingTableInterface?: dynamodb.ITable,\n  readonly pointInTimeRecoverySpecification?: dynamodb.PointInTimeRecoverySpecification,\n  readonly pointInTimeRecovery?: boolean\n}\n\nexport function CheckDynamoDBProps(propsObject: DynamoDBProps | any) {\n  let errorMessages = '';\n  let errorFound = false;\n\n  if (propsObject.dynamoTableProps && propsObject.existingTableObj) {\n    errorMessages += 'Error - Either provide existingTableObj or dynamoTableProps, but not both.\\n';\n    errorFound = true;\n  }\n\n  if (propsObject.dynamoTableProps && propsObject.existingTableInterface) {\n    errorMessages += 'Error - Either provide existingTableInterface or dynamoTableProps, but not both.\\n';\n    errorFound = true;\n  }\n\n  if (propsObject.existingTableObj && propsObject.existingTableInterface) {\n    errorMessages += 'Error - Either provide existingTableInterface or existingTableObj, but not both.\\n';\n    errorFound = true;\n  }\n\n  if (propsObject.pointInTimeRecovery && propsObject.pointInTimeRecoverySpecification) {\n    errorMessages += 'Error - Either provide pointInTimeRecovery or pointInTimeRecoverySpecification, but not both.\\n';\n    errorFound = true;\n  }\n\n  if (errorFound) {\n    throw new Error(errorMessages);\n  }\n}\n"]}
;