@jupiterone/dynamodb-dao
Advanced tools
Comparing version 1.7.6 to 1.8.0
@@ -241,7 +241,2 @@ "use strict"; | ||
async queryUntilLimitReached(params) { | ||
if (!params.filterExpression) { | ||
// Since there are no filter expressions, DynamoDB will automatically | ||
// fulfill the `limit` property. | ||
return this.query(params); | ||
} | ||
// create a shallow copy of params since we mutate the top level properties | ||
@@ -458,2 +453,2 @@ params = { | ||
exports.default = DynamoDbDao; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { sleep } from '@lifeomic/attempt';\nimport { DocumentClient } from 'aws-sdk/clients/dynamodb';\nimport chunk from 'lodash.chunk';\nimport pMap from 'p-map';\nimport {\n  DEFAULT_LOCK_INCREMENT,\n  DEFAULT_QUERY_LIMIT,\n  MAX_BATCH_OPERATIONS,\n} from './constants';\nimport { buildOptimisticLockOptions } from './locking/buildOptimisticLockOptions';\nimport {\n  decodeQueryUntilLimitCursor,\n  encodeQueryUntilLimitCursor,\n} from './query/cursor';\nimport {\n  decodeExclusiveStartKey,\n  encodeExclusiveStartKey,\n} from './scan/startKey';\nimport { isBatchPutOperation } from './typeGuards';\nimport {\n  AttributeNames,\n  AttributeValues,\n  BatchDeleteOperation,\n  BatchGetResult,\n  BatchPutOperation,\n  BatchWriteOperation,\n  BatchWriteResult,\n  BatchWriteWithExponentialBackoffParams,\n  CountOutput,\n  GetItemOptions,\n  QueryInput,\n  QueryInputWithLimit,\n  QueryResult,\n  ScanInput,\n} from './types';\nimport {\n  DataModelAsMap,\n  generateUpdateParams,\n} from './update/generateUpdateParams';\n\nexport * from './constants';\nexport * from './types';\n\nexport interface ConditionalOptions {\n  conditionExpression?: string;\n  attributeNames?: AttributeNames;\n  attributeValues?: AttributeValues;\n}\n\nexport interface MutateBehavior {\n  ignoreOptimisticLocking?: boolean;\n}\n\nexport type PutOptions = ConditionalOptions & MutateBehavior;\nexport type UpdateOptions = ConditionalOptions & MutateBehavior;\nexport type DeleteOptions = ConditionalOptions & MutateBehavior;\n\nexport interface DynamoDbDaoInput<T> {\n  tableName: string;\n  documentClient: DocumentClient;\n  optimisticLockingAttribute?: keyof NumberPropertiesInType<T>;\n  autoInitiateLockingAttribute?: boolean;\n}\n\n/**\n * This type is used to force functions like `incr` and `decr` to only take\n * properties from the `DataModel` that are type \"number\".\n *\n * See: https://stackoverflow.com/a/49797062\n */\nexport type NumberPropertiesInType<T> = Pick<\n  T,\n  {\n    [K in keyof T]: T[K] extends number ? K : never;\n  }[keyof T]\n>;\n\ntype IncrMap<DataModel> = Partial<\n  {\n    [key in keyof NumberPropertiesInType<DataModel>]: number;\n  }\n>;\n\n/**\n * A base dynamodb dao class that enforces types\n */\nexport default class DynamoDbDao<DataModel, KeySchema> {\n  public readonly tableName: string;\n  public readonly documentClient: DocumentClient;\n  public readonly optimisticLockingAttribute?: keyof NumberPropertiesInType<DataModel>;\n  public readonly autoInitiateLockingAttribute?: boolean;\n\n  constructor(options: DynamoDbDaoInput<DataModel>) {\n    this.tableName = options.tableName;\n    this.documentClient = options.documentClient;\n    // The prior version implemented auto-initiate, so\n    // we'll default to true to retain backward compatibility\n    this.autoInitiateLockingAttribute =\n      options.autoInitiateLockingAttribute === undefined\n        ? true\n        : options.autoInitiateLockingAttribute;\n    this.optimisticLockingAttribute = options.optimisticLockingAttribute;\n  }\n\n  /**\n   * Fetches an item by it's key schema\n   */\n  async get(\n    key: KeySchema,\n    options: GetItemOptions = { consistentRead: false }\n  ): Promise<DataModel | undefined> {\n    const { consistentRead } = options;\n    const { Item: item } = await this.documentClient\n      .get({\n        TableName: this.tableName,\n        Key: key,\n        ConsistentRead: consistentRead,\n      })\n      .promise();\n\n    return item as DataModel;\n  }\n\n  /**\n   * Deletes the item. Returns the deleted item\n   * if it was deleted\n   */\n  async delete(\n    key: KeySchema,\n    options: DeleteOptions = {},\n    data: Partial<DataModel> = {}\n  ): Promise<DataModel | undefined> {\n    let { attributeNames, attributeValues, conditionExpression } = options;\n\n    if (this.optimisticLockingAttribute && !options.ignoreOptimisticLocking) {\n      const versionAttribute = this.optimisticLockingAttribute.toString();\n      ({ attributeNames, attributeValues, conditionExpression } =\n        buildOptimisticLockOptions({\n          versionAttribute,\n          versionAttributeValue: (data as DataModelAsMap)[versionAttribute],\n          conditionExpression: conditionExpression,\n          attributeNames,\n          attributeValues,\n        }));\n    }\n    const { Attributes: attributes } = await this.documentClient\n      .delete({\n        TableName: this.tableName,\n        Key: key,\n        ReturnValues: 'ALL_OLD',\n        ConditionExpression: conditionExpression,\n        ExpressionAttributeNames: attributeNames,\n        ExpressionAttributeValues: attributeValues,\n      })\n      .promise();\n\n    return attributes as DataModel;\n  }\n\n  /**\n   * Creates/Updates an item in the table\n   */\n  async put(data: DataModel, options: PutOptions = {}): Promise<DataModel> {\n    let { conditionExpression, attributeNames, attributeValues } = options;\n    if (this.optimisticLockingAttribute) {\n      // Must cast data to avoid tripping the linter, otherwise, it'll complain\n      // about expression of type 'string' can't be used to index type 'unknown'\n      const dataAsMap = data as DataModelAsMap;\n      const versionAttribute = this.optimisticLockingAttribute.toString();\n\n      if (!options.ignoreOptimisticLocking) {\n        ({ conditionExpression, attributeNames, attributeValues } =\n          buildOptimisticLockOptions({\n            versionAttribute,\n            versionAttributeValue: dataAsMap[versionAttribute],\n            conditionExpression,\n            attributeNames,\n            attributeValues,\n          }));\n      }\n\n      // If the version attribute is supplied, increment it, otherwise only\n      // set the default if directed to do so\n      if (versionAttribute in data && !isNaN(dataAsMap[versionAttribute])) {\n        dataAsMap[versionAttribute] += DEFAULT_LOCK_INCREMENT;\n      } else if (this.autoInitiateLockingAttribute) {\n        dataAsMap[versionAttribute] = DEFAULT_LOCK_INCREMENT;\n      }\n    }\n\n    await this.documentClient\n      .put({\n        TableName: this.tableName,\n        Item: data,\n        ConditionExpression: conditionExpression,\n        ExpressionAttributeNames: attributeNames,\n        ExpressionAttributeValues: attributeValues,\n      })\n      .promise();\n    return data;\n  }\n\n  /**\n   * Creates/Updates an item in the table\n   */\n  async update(\n    key: KeySchema,\n    data: Partial<DataModel>,\n    updateOptions?: UpdateOptions\n  ): Promise<DataModel> {\n    const optimisticLockVersionAttribute =\n      this.optimisticLockingAttribute?.toString();\n    const params = generateUpdateParams({\n      tableName: this.tableName,\n      key,\n      data,\n      ...updateOptions,\n      optimisticLockVersionAttribute,\n      autoInitiateLockingAttribute: this.autoInitiateLockingAttribute,\n    });\n\n    const { Attributes: attributes } = await this.documentClient\n      .update(params)\n      .promise();\n\n    return attributes as DataModel;\n  }\n\n  async incr(\n    key: KeySchema,\n    attr: keyof NumberPropertiesInType<DataModel>,\n    incrBy = 1,\n    conditionExpression?: string\n  ): Promise<DataModel> {\n    return this.multiIncr(\n      key,\n      { [attr]: incrBy } as IncrMap<DataModel>,\n      conditionExpression\n    );\n  }\n\n  async decr(\n    key: KeySchema,\n    attr: keyof NumberPropertiesInType<DataModel>,\n    decrBy = 1,\n    conditionExpression?: string\n  ): Promise<DataModel> {\n    return this.multiIncr(\n      key,\n      { [attr]: decrBy * -1 } as IncrMap<DataModel>,\n      conditionExpression\n    );\n  }\n\n  async multiIncr(\n    key: KeySchema,\n    incrMap: IncrMap<DataModel>,\n    conditionExpression?: string\n  ): Promise<DataModel> {\n    const incrEntries = Object.entries(incrMap);\n    const errorEntries = incrEntries.filter(\n      ([_key, value]) => !Number.isInteger(value)\n    );\n    if (errorEntries.length) {\n      throw new Error(\n        `Increments must be integers: ${JSON.stringify(errorEntries)}`\n      );\n    }\n\n    const updateParams: DocumentClient.UpdateItemInput = {\n      TableName: this.tableName,\n      Key: key,\n      UpdateExpression: 'SET',\n      ConditionExpression: conditionExpression,\n      ExpressionAttributeNames: {},\n      ExpressionAttributeValues: {\n        ':start': 0,\n      },\n      ReturnValues: 'ALL_NEW',\n    };\n\n    incrEntries.forEach(([key, value], i) => {\n      const includeComma = i !== incrEntries.length - 1;\n      const attrName = `#incrAttr${i}`;\n      const valueName = `:inc${i}`;\n      updateParams.UpdateExpression += ` ${attrName} = if_not_exists(${attrName}, :start) + ${valueName}${\n        includeComma ? ',' : ''\n      }`;\n      updateParams.ExpressionAttributeNames![attrName] = key;\n      updateParams.ExpressionAttributeValues![valueName] = value;\n    });\n\n    const { Attributes: attributes } = await this.documentClient\n      .update(updateParams)\n      .promise();\n\n    return attributes as DataModel;\n  }\n\n  /**\n   * Executes a query to fetch a count\n   */\n  async count(input: QueryInput): Promise<CountOutput> {\n    const {\n      index,\n      attributeValues,\n      attributeNames,\n      keyConditionExpression,\n      filterExpression,\n      startAt,\n      limit,\n    } = input;\n\n    let startKey: KeySchema | undefined;\n\n    if (startAt) {\n      startKey = decodeExclusiveStartKey<KeySchema>(startAt);\n    }\n\n    const result = await this.documentClient\n      .query({\n        TableName: this.tableName,\n        IndexName: index,\n        KeyConditionExpression: keyConditionExpression,\n        FilterExpression: filterExpression,\n        ExpressionAttributeValues: attributeValues,\n        ExpressionAttributeNames: attributeNames,\n        ExclusiveStartKey: startKey,\n        Limit: limit,\n        Select: 'COUNT',\n      })\n      .promise();\n\n    return {\n      count: result.Count,\n      scannedCount: result.ScannedCount,\n      lastKey: result.LastEvaluatedKey\n        ? encodeExclusiveStartKey<KeySchema>(\n            result.LastEvaluatedKey as KeySchema\n          )\n        : undefined,\n    };\n  }\n\n  /**\n   * Executes a query on the table\n   */\n  async query(input: QueryInput): Promise<QueryResult<DataModel>> {\n    const {\n      index,\n      startAt,\n      attributeNames,\n      attributeValues,\n      scanIndexForward,\n      keyConditionExpression,\n      filterExpression,\n      limit = DEFAULT_QUERY_LIMIT,\n      consistentRead,\n    } = input;\n\n    let startKey: KeySchema | undefined;\n\n    if (startAt) {\n      startKey = decodeExclusiveStartKey<KeySchema>(startAt);\n    }\n\n    const result = await this.documentClient\n      .query({\n        TableName: this.tableName,\n        IndexName: index,\n        Limit: limit,\n        ScanIndexForward: scanIndexForward,\n        ExclusiveStartKey: startKey,\n        KeyConditionExpression: keyConditionExpression,\n        FilterExpression: filterExpression,\n        ExpressionAttributeNames: attributeNames,\n        ExpressionAttributeValues: attributeValues,\n        ConsistentRead: consistentRead,\n      })\n      .promise();\n\n    return {\n      items: result.Items as DataModel[],\n      lastKey: result.LastEvaluatedKey\n        ? encodeExclusiveStartKey<KeySchema>(\n            result.LastEvaluatedKey as KeySchema\n          )\n        : undefined,\n    };\n  }\n\n  async queryUntilLimitReached(\n    params: QueryInputWithLimit\n  ): Promise<QueryResult<DataModel>> {\n    if (!params.filterExpression) {\n      // Since there are no filter expressions, DynamoDB will automatically\n      // fulfill the `limit` property.\n      return this.query(params);\n    }\n\n    // create a shallow copy of params since we mutate the top level properties\n    params = {\n      ...params,\n    };\n\n    const cursor = decodeQueryUntilLimitCursor(params.startAt);\n\n    // Use `cursor.lastKey` for the actual params that will\n    // be sent to query(...).\n    //\n    // `cursor.skip` will be used to skip items on our function.\n    params.startAt = cursor.lastKey;\n\n    const items: DataModel[] = [];\n    const limit = params.limit;\n    let lastKey: string | undefined;\n\n    do {\n      const queryResult = await this.query(params);\n      const curItems = queryResult.items;\n      const curLen = curItems.length;\n\n      for (let i = cursor.skip; i < curLen; i++) {\n        const item = curItems[i];\n        items.push(item);\n        if (items.length >= limit) {\n          // we reached our limit so we need to stop iterator\n\n          let newLastKey: string | undefined = undefined;\n          if (i === curLen - 1) {\n            // If i == curLen - 1, that means that we have seen all of the\n            // items on this page, so we only need to return a lastKey if it\n            // is deifned\n            newLastKey = queryResult.lastKey\n              ? encodeQueryUntilLimitCursor(queryResult.lastKey, 0)\n              : undefined;\n          } else {\n            // If `(i < curLen - 1)` then that means that we did not read\n            // one or more records on the current page. That means that\n            // we will need to read this page again but skip the records\n            // that we have already read.\n            newLastKey =\n              i < curLen - 1\n                ? encodeQueryUntilLimitCursor(params.startAt, i + 1)\n                : encodeQueryUntilLimitCursor(queryResult.lastKey, 0);\n          }\n\n          return {\n            items,\n            lastKey: newLastKey,\n          };\n        }\n      }\n\n      // if on the second page,\n      //    i >= curLen - 1\n      //    queryResult.items = 1\n\n      // only apply skip after the first query so we reset it here\n      cursor.skip = 0;\n      lastKey = queryResult.lastKey;\n      params.startAt = lastKey;\n    } while (lastKey);\n\n    // if we got here then we exhausted all of the pages\n    return {\n      items,\n      lastKey: undefined,\n    };\n  }\n\n  /**\n   * Scans the table\n   */\n  async scan(input: ScanInput = {}): Promise<QueryResult<DataModel>> {\n    const {\n      index,\n      startAt,\n      attributeNames,\n      attributeValues,\n      filterExpression,\n      segment,\n      totalSegments,\n      limit = DEFAULT_QUERY_LIMIT,\n      consistentRead,\n    } = input;\n\n    if (segment !== undefined && totalSegments === undefined) {\n      throw new Error(\n        'If segment is defined, totalSegments must also be defined.'\n      );\n    }\n\n    if (segment === undefined && totalSegments !== undefined) {\n      throw new Error(\n        'If totalSegments is defined, segment must also be defined.'\n      );\n    }\n\n    let startKey: KeySchema | undefined;\n\n    if (startAt) {\n      startKey = decodeExclusiveStartKey<KeySchema>(startAt);\n    }\n\n    const result = await this.documentClient\n      .scan({\n        TableName: this.tableName,\n        IndexName: index,\n        Limit: limit,\n        ExclusiveStartKey: startKey,\n        FilterExpression: filterExpression,\n        ExpressionAttributeNames: attributeNames,\n        ExpressionAttributeValues: attributeValues,\n        Segment: segment,\n        TotalSegments: totalSegments,\n        ConsistentRead: consistentRead,\n      })\n      .promise();\n\n    return {\n      items: result.Items as DataModel[],\n      lastKey: result.LastEvaluatedKey\n        ? encodeExclusiveStartKey<KeySchema>(\n            result.LastEvaluatedKey as KeySchema\n          )\n        : undefined,\n    };\n  }\n\n  async batchWrite(\n    operations: BatchWriteOperation<DataModel, KeySchema>[]\n  ): Promise<BatchWriteResult<DataModel, KeySchema>> {\n    if (operations.length > MAX_BATCH_OPERATIONS) {\n      throw new Error(\n        `Cannot send more than ${MAX_BATCH_OPERATIONS} operations in a single call.`\n      );\n    }\n\n    const result = await this.documentClient\n      .batchWrite({\n        RequestItems: {\n          [this.tableName]: operations.map((operation) => {\n            if (isBatchPutOperation(operation)) {\n              return {\n                PutRequest: {\n                  Item: operation.put,\n                },\n              };\n            } else {\n              return {\n                DeleteRequest: {\n                  Key: operation.delete,\n                },\n              };\n            }\n          }),\n        },\n      })\n      .promise();\n\n    const unprocessedItems =\n      result.UnprocessedItems && result.UnprocessedItems[this.tableName];\n\n    return {\n      unprocessedItems: unprocessedItems\n        ? unprocessedItems.map((item) => {\n            if (item.PutRequest) {\n              return {\n                put: item.PutRequest.Item,\n              } as BatchPutOperation<DataModel>;\n            } else {\n              return {\n                delete: item.DeleteRequest?.Key,\n              } as BatchDeleteOperation<KeySchema>;\n            }\n          })\n        : undefined,\n    };\n  }\n\n  async batchGet(\n    keys: KeySchema[]\n  ): Promise<BatchGetResult<DataModel, KeySchema>> {\n    if (keys.length > MAX_BATCH_OPERATIONS) {\n      throw new Error(\n        `Cannot fetch more than ${MAX_BATCH_OPERATIONS} items in a single call.`\n      );\n    }\n\n    const result = await this.documentClient\n      .batchGet({\n        RequestItems: {\n          [this.tableName]: {\n            Keys: keys,\n          },\n        },\n      })\n      .promise();\n\n    const items = result.Responses && result.Responses[this.tableName];\n    const unprocessedKeys =\n      result.UnprocessedKeys && result.UnprocessedKeys[this.tableName];\n\n    return {\n      items: (items || []) as DataModel[],\n      unprocessedKeys: unprocessedKeys\n        ? (unprocessedKeys.Keys as KeySchema[])\n        : undefined,\n    };\n  }\n\n  async batchPutWithExponentialBackoff(\n    params: BatchWriteWithExponentialBackoffParams<DataModel, KeySchema>\n  ): Promise<void> {\n    const {\n      items,\n      delay = 100,\n      attempts = 0,\n      maxRetries = 5,\n      batchWriteLimit = MAX_BATCH_OPERATIONS,\n      logger,\n    } = params;\n\n    logger.info(\n      { attempts },\n      'Attempting to batch put with exponential backoff'\n    );\n\n    if (items.length === 0) {\n      logger.info({ items: items.length }, 'Nothing to batch put.');\n      return;\n    }\n\n    logger.info(\n      { items: items.length, delay, attempts, maxRetries },\n      'Attempting to batch put...'\n    );\n\n    const batches: DataModel[][] = chunk(items, batchWriteLimit);\n\n    logger.info({ batches: batches.length }, 'Number of total batches');\n    const unprocessedItems: BatchPutOperation<DataModel>[] = [];\n\n    await pMap(\n      batches,\n      async (batch) => {\n        const result = await this.batchWrite(\n          batch.map((batchItem) => ({\n            put: batchItem,\n          }))\n        );\n\n        if (result.unprocessedItems) {\n          unprocessedItems.push(\n            ...(result.unprocessedItems as BatchPutOperation<DataModel>[])\n          );\n        }\n      },\n      { concurrency: 2 }\n    );\n\n    if (unprocessedItems.length && attempts > maxRetries) {\n      logger.error(\n        {\n          unprocessedItems: unprocessedItems.length,\n          attempts,\n          maxRetries,\n        },\n        'Found unprocessed items, but reached max attempts.'\n      );\n\n      throw new Error(\n        `Failed to process items after attempts (attempts=${attempts})`\n      );\n    } else if (unprocessedItems.length) {\n      logger.warn(\n        {\n          unprocessedItems: unprocessedItems.length,\n          attempts,\n          maxRetries,\n          delay,\n        },\n        'Found unprocessed items. Retrying after dely...'\n      );\n\n      await sleep(delay);\n\n      await this.batchPutWithExponentialBackoff({\n        logger,\n        items: unprocessedItems.map((item) => item.put),\n        delay: Math.round(Math.pow(delay, 1.2)),\n        attempts: attempts + 1,\n        maxRetries,\n      });\n    }\n\n    logger.info('Successfully wrote all batches!');\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { sleep } from '@lifeomic/attempt';\nimport { DocumentClient } from 'aws-sdk/clients/dynamodb';\nimport chunk from 'lodash.chunk';\nimport pMap from 'p-map';\nimport {\n  DEFAULT_LOCK_INCREMENT,\n  DEFAULT_QUERY_LIMIT,\n  MAX_BATCH_OPERATIONS,\n} from './constants';\nimport { buildOptimisticLockOptions } from './locking/buildOptimisticLockOptions';\nimport {\n  decodeQueryUntilLimitCursor,\n  encodeQueryUntilLimitCursor,\n} from './query/cursor';\nimport {\n  decodeExclusiveStartKey,\n  encodeExclusiveStartKey,\n} from './scan/startKey';\nimport { isBatchPutOperation } from './typeGuards';\nimport {\n  AttributeNames,\n  AttributeValues,\n  BatchDeleteOperation,\n  BatchGetResult,\n  BatchPutOperation,\n  BatchWriteOperation,\n  BatchWriteResult,\n  BatchWriteWithExponentialBackoffParams,\n  CountOutput,\n  GetItemOptions,\n  QueryInput,\n  QueryInputWithLimit,\n  QueryResult,\n  ScanInput,\n} from './types';\nimport {\n  DataModelAsMap,\n  generateUpdateParams,\n} from './update/generateUpdateParams';\n\nexport * from './constants';\nexport * from './types';\n\nexport interface ConditionalOptions {\n  conditionExpression?: string;\n  attributeNames?: AttributeNames;\n  attributeValues?: AttributeValues;\n}\n\nexport interface MutateBehavior {\n  ignoreOptimisticLocking?: boolean;\n}\n\nexport type PutOptions = ConditionalOptions & MutateBehavior;\nexport type UpdateOptions = ConditionalOptions & MutateBehavior;\nexport type DeleteOptions = ConditionalOptions & MutateBehavior;\n\nexport interface DynamoDbDaoInput<T> {\n  tableName: string;\n  documentClient: DocumentClient;\n  optimisticLockingAttribute?: keyof NumberPropertiesInType<T>;\n  autoInitiateLockingAttribute?: boolean;\n}\n\n/**\n * This type is used to force functions like `incr` and `decr` to only take\n * properties from the `DataModel` that are type \"number\".\n *\n * See: https://stackoverflow.com/a/49797062\n */\nexport type NumberPropertiesInType<T> = Pick<\n  T,\n  {\n    [K in keyof T]: T[K] extends number ? K : never;\n  }[keyof T]\n>;\n\ntype IncrMap<DataModel> = Partial<\n  {\n    [key in keyof NumberPropertiesInType<DataModel>]: number;\n  }\n>;\n\n/**\n * A base dynamodb dao class that enforces types\n */\nexport default class DynamoDbDao<DataModel, KeySchema> {\n  public readonly tableName: string;\n  public readonly documentClient: DocumentClient;\n  public readonly optimisticLockingAttribute?: keyof NumberPropertiesInType<DataModel>;\n  public readonly autoInitiateLockingAttribute?: boolean;\n\n  constructor(options: DynamoDbDaoInput<DataModel>) {\n    this.tableName = options.tableName;\n    this.documentClient = options.documentClient;\n    // The prior version implemented auto-initiate, so\n    // we'll default to true to retain backward compatibility\n    this.autoInitiateLockingAttribute =\n      options.autoInitiateLockingAttribute === undefined\n        ? true\n        : options.autoInitiateLockingAttribute;\n    this.optimisticLockingAttribute = options.optimisticLockingAttribute;\n  }\n\n  /**\n   * Fetches an item by it's key schema\n   */\n  async get(\n    key: KeySchema,\n    options: GetItemOptions = { consistentRead: false }\n  ): Promise<DataModel | undefined> {\n    const { consistentRead } = options;\n    const { Item: item } = await this.documentClient\n      .get({\n        TableName: this.tableName,\n        Key: key,\n        ConsistentRead: consistentRead,\n      })\n      .promise();\n\n    return item as DataModel;\n  }\n\n  /**\n   * Deletes the item. Returns the deleted item\n   * if it was deleted\n   */\n  async delete(\n    key: KeySchema,\n    options: DeleteOptions = {},\n    data: Partial<DataModel> = {}\n  ): Promise<DataModel | undefined> {\n    let { attributeNames, attributeValues, conditionExpression } = options;\n\n    if (this.optimisticLockingAttribute && !options.ignoreOptimisticLocking) {\n      const versionAttribute = this.optimisticLockingAttribute.toString();\n      ({ attributeNames, attributeValues, conditionExpression } =\n        buildOptimisticLockOptions({\n          versionAttribute,\n          versionAttributeValue: (data as DataModelAsMap)[versionAttribute],\n          conditionExpression: conditionExpression,\n          attributeNames,\n          attributeValues,\n        }));\n    }\n    const { Attributes: attributes } = await this.documentClient\n      .delete({\n        TableName: this.tableName,\n        Key: key,\n        ReturnValues: 'ALL_OLD',\n        ConditionExpression: conditionExpression,\n        ExpressionAttributeNames: attributeNames,\n        ExpressionAttributeValues: attributeValues,\n      })\n      .promise();\n\n    return attributes as DataModel;\n  }\n\n  /**\n   * Creates/Updates an item in the table\n   */\n  async put(data: DataModel, options: PutOptions = {}): Promise<DataModel> {\n    let { conditionExpression, attributeNames, attributeValues } = options;\n    if (this.optimisticLockingAttribute) {\n      // Must cast data to avoid tripping the linter, otherwise, it'll complain\n      // about expression of type 'string' can't be used to index type 'unknown'\n      const dataAsMap = data as DataModelAsMap;\n      const versionAttribute = this.optimisticLockingAttribute.toString();\n\n      if (!options.ignoreOptimisticLocking) {\n        ({ conditionExpression, attributeNames, attributeValues } =\n          buildOptimisticLockOptions({\n            versionAttribute,\n            versionAttributeValue: dataAsMap[versionAttribute],\n            conditionExpression,\n            attributeNames,\n            attributeValues,\n          }));\n      }\n\n      // If the version attribute is supplied, increment it, otherwise only\n      // set the default if directed to do so\n      if (versionAttribute in data && !isNaN(dataAsMap[versionAttribute])) {\n        dataAsMap[versionAttribute] += DEFAULT_LOCK_INCREMENT;\n      } else if (this.autoInitiateLockingAttribute) {\n        dataAsMap[versionAttribute] = DEFAULT_LOCK_INCREMENT;\n      }\n    }\n\n    await this.documentClient\n      .put({\n        TableName: this.tableName,\n        Item: data,\n        ConditionExpression: conditionExpression,\n        ExpressionAttributeNames: attributeNames,\n        ExpressionAttributeValues: attributeValues,\n      })\n      .promise();\n    return data;\n  }\n\n  /**\n   * Creates/Updates an item in the table\n   */\n  async update(\n    key: KeySchema,\n    data: Partial<DataModel>,\n    updateOptions?: UpdateOptions\n  ): Promise<DataModel> {\n    const optimisticLockVersionAttribute =\n      this.optimisticLockingAttribute?.toString();\n    const params = generateUpdateParams({\n      tableName: this.tableName,\n      key,\n      data,\n      ...updateOptions,\n      optimisticLockVersionAttribute,\n      autoInitiateLockingAttribute: this.autoInitiateLockingAttribute,\n    });\n\n    const { Attributes: attributes } = await this.documentClient\n      .update(params)\n      .promise();\n\n    return attributes as DataModel;\n  }\n\n  async incr(\n    key: KeySchema,\n    attr: keyof NumberPropertiesInType<DataModel>,\n    incrBy = 1,\n    conditionExpression?: string\n  ): Promise<DataModel> {\n    return this.multiIncr(\n      key,\n      { [attr]: incrBy } as IncrMap<DataModel>,\n      conditionExpression\n    );\n  }\n\n  async decr(\n    key: KeySchema,\n    attr: keyof NumberPropertiesInType<DataModel>,\n    decrBy = 1,\n    conditionExpression?: string\n  ): Promise<DataModel> {\n    return this.multiIncr(\n      key,\n      { [attr]: decrBy * -1 } as IncrMap<DataModel>,\n      conditionExpression\n    );\n  }\n\n  async multiIncr(\n    key: KeySchema,\n    incrMap: IncrMap<DataModel>,\n    conditionExpression?: string\n  ): Promise<DataModel> {\n    const incrEntries = Object.entries(incrMap);\n    const errorEntries = incrEntries.filter(\n      ([_key, value]) => !Number.isInteger(value)\n    );\n    if (errorEntries.length) {\n      throw new Error(\n        `Increments must be integers: ${JSON.stringify(errorEntries)}`\n      );\n    }\n\n    const updateParams: DocumentClient.UpdateItemInput = {\n      TableName: this.tableName,\n      Key: key,\n      UpdateExpression: 'SET',\n      ConditionExpression: conditionExpression,\n      ExpressionAttributeNames: {},\n      ExpressionAttributeValues: {\n        ':start': 0,\n      },\n      ReturnValues: 'ALL_NEW',\n    };\n\n    incrEntries.forEach(([key, value], i) => {\n      const includeComma = i !== incrEntries.length - 1;\n      const attrName = `#incrAttr${i}`;\n      const valueName = `:inc${i}`;\n      updateParams.UpdateExpression += ` ${attrName} = if_not_exists(${attrName}, :start) + ${valueName}${\n        includeComma ? ',' : ''\n      }`;\n      updateParams.ExpressionAttributeNames![attrName] = key;\n      updateParams.ExpressionAttributeValues![valueName] = value;\n    });\n\n    const { Attributes: attributes } = await this.documentClient\n      .update(updateParams)\n      .promise();\n\n    return attributes as DataModel;\n  }\n\n  /**\n   * Executes a query to fetch a count\n   */\n  async count(input: QueryInput): Promise<CountOutput> {\n    const {\n      index,\n      attributeValues,\n      attributeNames,\n      keyConditionExpression,\n      filterExpression,\n      startAt,\n      limit,\n    } = input;\n\n    let startKey: KeySchema | undefined;\n\n    if (startAt) {\n      startKey = decodeExclusiveStartKey<KeySchema>(startAt);\n    }\n\n    const result = await this.documentClient\n      .query({\n        TableName: this.tableName,\n        IndexName: index,\n        KeyConditionExpression: keyConditionExpression,\n        FilterExpression: filterExpression,\n        ExpressionAttributeValues: attributeValues,\n        ExpressionAttributeNames: attributeNames,\n        ExclusiveStartKey: startKey,\n        Limit: limit,\n        Select: 'COUNT',\n      })\n      .promise();\n\n    return {\n      count: result.Count,\n      scannedCount: result.ScannedCount,\n      lastKey: result.LastEvaluatedKey\n        ? encodeExclusiveStartKey<KeySchema>(\n            result.LastEvaluatedKey as KeySchema\n          )\n        : undefined,\n    };\n  }\n\n  /**\n   * Executes a query on the table\n   */\n  async query(input: QueryInput): Promise<QueryResult<DataModel>> {\n    const {\n      index,\n      startAt,\n      attributeNames,\n      attributeValues,\n      scanIndexForward,\n      keyConditionExpression,\n      filterExpression,\n      limit = DEFAULT_QUERY_LIMIT,\n      consistentRead,\n    } = input;\n\n    let startKey: KeySchema | undefined;\n\n    if (startAt) {\n      startKey = decodeExclusiveStartKey<KeySchema>(startAt);\n    }\n\n    const result = await this.documentClient\n      .query({\n        TableName: this.tableName,\n        IndexName: index,\n        Limit: limit,\n        ScanIndexForward: scanIndexForward,\n        ExclusiveStartKey: startKey,\n        KeyConditionExpression: keyConditionExpression,\n        FilterExpression: filterExpression,\n        ExpressionAttributeNames: attributeNames,\n        ExpressionAttributeValues: attributeValues,\n        ConsistentRead: consistentRead,\n      })\n      .promise();\n\n    return {\n      items: result.Items as DataModel[],\n      lastKey: result.LastEvaluatedKey\n        ? encodeExclusiveStartKey<KeySchema>(\n            result.LastEvaluatedKey as KeySchema\n          )\n        : undefined,\n    };\n  }\n\n  async queryUntilLimitReached(\n    params: QueryInputWithLimit\n  ): Promise<QueryResult<DataModel>> {\n    // create a shallow copy of params since we mutate the top level properties\n    params = {\n      ...params,\n    };\n\n    const cursor = decodeQueryUntilLimitCursor(params.startAt);\n\n    // Use `cursor.lastKey` for the actual params that will\n    // be sent to query(...).\n    //\n    // `cursor.skip` will be used to skip items on our function.\n    params.startAt = cursor.lastKey;\n\n    const items: DataModel[] = [];\n    const limit = params.limit;\n    let lastKey: string | undefined;\n\n    do {\n      const queryResult = await this.query(params);\n      const curItems = queryResult.items;\n      const curLen = curItems.length;\n\n      for (let i = cursor.skip; i < curLen; i++) {\n        const item = curItems[i];\n        items.push(item);\n        if (items.length >= limit) {\n          // we reached our limit so we need to stop iterator\n\n          let newLastKey: string | undefined = undefined;\n          if (i === curLen - 1) {\n            // If i == curLen - 1, that means that we have seen all of the\n            // items on this page, so we only need to return a lastKey if it\n            // is deifned\n            newLastKey = queryResult.lastKey\n              ? encodeQueryUntilLimitCursor(queryResult.lastKey, 0)\n              : undefined;\n          } else {\n            // If `(i < curLen - 1)` then that means that we did not read\n            // one or more records on the current page. That means that\n            // we will need to read this page again but skip the records\n            // that we have already read.\n            newLastKey =\n              i < curLen - 1\n                ? encodeQueryUntilLimitCursor(params.startAt, i + 1)\n                : encodeQueryUntilLimitCursor(queryResult.lastKey, 0);\n          }\n\n          return {\n            items,\n            lastKey: newLastKey,\n          };\n        }\n      }\n\n      // if on the second page,\n      //    i >= curLen - 1\n      //    queryResult.items = 1\n\n      // only apply skip after the first query so we reset it here\n      cursor.skip = 0;\n      lastKey = queryResult.lastKey;\n      params.startAt = lastKey;\n    } while (lastKey);\n\n    // if we got here then we exhausted all of the pages\n    return {\n      items,\n      lastKey: undefined,\n    };\n  }\n\n  /**\n   * Scans the table\n   */\n  async scan(input: ScanInput = {}): Promise<QueryResult<DataModel>> {\n    const {\n      index,\n      startAt,\n      attributeNames,\n      attributeValues,\n      filterExpression,\n      segment,\n      totalSegments,\n      limit = DEFAULT_QUERY_LIMIT,\n      consistentRead,\n    } = input;\n\n    if (segment !== undefined && totalSegments === undefined) {\n      throw new Error(\n        'If segment is defined, totalSegments must also be defined.'\n      );\n    }\n\n    if (segment === undefined && totalSegments !== undefined) {\n      throw new Error(\n        'If totalSegments is defined, segment must also be defined.'\n      );\n    }\n\n    let startKey: KeySchema | undefined;\n\n    if (startAt) {\n      startKey = decodeExclusiveStartKey<KeySchema>(startAt);\n    }\n\n    const result = await this.documentClient\n      .scan({\n        TableName: this.tableName,\n        IndexName: index,\n        Limit: limit,\n        ExclusiveStartKey: startKey,\n        FilterExpression: filterExpression,\n        ExpressionAttributeNames: attributeNames,\n        ExpressionAttributeValues: attributeValues,\n        Segment: segment,\n        TotalSegments: totalSegments,\n        ConsistentRead: consistentRead,\n      })\n      .promise();\n\n    return {\n      items: result.Items as DataModel[],\n      lastKey: result.LastEvaluatedKey\n        ? encodeExclusiveStartKey<KeySchema>(\n            result.LastEvaluatedKey as KeySchema\n          )\n        : undefined,\n    };\n  }\n\n  async batchWrite(\n    operations: BatchWriteOperation<DataModel, KeySchema>[]\n  ): Promise<BatchWriteResult<DataModel, KeySchema>> {\n    if (operations.length > MAX_BATCH_OPERATIONS) {\n      throw new Error(\n        `Cannot send more than ${MAX_BATCH_OPERATIONS} operations in a single call.`\n      );\n    }\n\n    const result = await this.documentClient\n      .batchWrite({\n        RequestItems: {\n          [this.tableName]: operations.map((operation) => {\n            if (isBatchPutOperation(operation)) {\n              return {\n                PutRequest: {\n                  Item: operation.put,\n                },\n              };\n            } else {\n              return {\n                DeleteRequest: {\n                  Key: operation.delete,\n                },\n              };\n            }\n          }),\n        },\n      })\n      .promise();\n\n    const unprocessedItems =\n      result.UnprocessedItems && result.UnprocessedItems[this.tableName];\n\n    return {\n      unprocessedItems: unprocessedItems\n        ? unprocessedItems.map((item) => {\n            if (item.PutRequest) {\n              return {\n                put: item.PutRequest.Item,\n              } as BatchPutOperation<DataModel>;\n            } else {\n              return {\n                delete: item.DeleteRequest?.Key,\n              } as BatchDeleteOperation<KeySchema>;\n            }\n          })\n        : undefined,\n    };\n  }\n\n  async batchGet(\n    keys: KeySchema[]\n  ): Promise<BatchGetResult<DataModel, KeySchema>> {\n    if (keys.length > MAX_BATCH_OPERATIONS) {\n      throw new Error(\n        `Cannot fetch more than ${MAX_BATCH_OPERATIONS} items in a single call.`\n      );\n    }\n\n    const result = await this.documentClient\n      .batchGet({\n        RequestItems: {\n          [this.tableName]: {\n            Keys: keys,\n          },\n        },\n      })\n      .promise();\n\n    const items = result.Responses && result.Responses[this.tableName];\n    const unprocessedKeys =\n      result.UnprocessedKeys && result.UnprocessedKeys[this.tableName];\n\n    return {\n      items: (items || []) as DataModel[],\n      unprocessedKeys: unprocessedKeys\n        ? (unprocessedKeys.Keys as KeySchema[])\n        : undefined,\n    };\n  }\n\n  async batchPutWithExponentialBackoff(\n    params: BatchWriteWithExponentialBackoffParams<DataModel, KeySchema>\n  ): Promise<void> {\n    const {\n      items,\n      delay = 100,\n      attempts = 0,\n      maxRetries = 5,\n      batchWriteLimit = MAX_BATCH_OPERATIONS,\n      logger,\n    } = params;\n\n    logger.info(\n      { attempts },\n      'Attempting to batch put with exponential backoff'\n    );\n\n    if (items.length === 0) {\n      logger.info({ items: items.length }, 'Nothing to batch put.');\n      return;\n    }\n\n    logger.info(\n      { items: items.length, delay, attempts, maxRetries },\n      'Attempting to batch put...'\n    );\n\n    const batches: DataModel[][] = chunk(items, batchWriteLimit);\n\n    logger.info({ batches: batches.length }, 'Number of total batches');\n    const unprocessedItems: BatchPutOperation<DataModel>[] = [];\n\n    await pMap(\n      batches,\n      async (batch) => {\n        const result = await this.batchWrite(\n          batch.map((batchItem) => ({\n            put: batchItem,\n          }))\n        );\n\n        if (result.unprocessedItems) {\n          unprocessedItems.push(\n            ...(result.unprocessedItems as BatchPutOperation<DataModel>[])\n          );\n        }\n      },\n      { concurrency: 2 }\n    );\n\n    if (unprocessedItems.length && attempts > maxRetries) {\n      logger.error(\n        {\n          unprocessedItems: unprocessedItems.length,\n          attempts,\n          maxRetries,\n        },\n        'Found unprocessed items, but reached max attempts.'\n      );\n\n      throw new Error(\n        `Failed to process items after attempts (attempts=${attempts})`\n      );\n    } else if (unprocessedItems.length) {\n      logger.warn(\n        {\n          unprocessedItems: unprocessedItems.length,\n          attempts,\n          maxRetries,\n          delay,\n        },\n        'Found unprocessed items. Retrying after dely...'\n      );\n\n      await sleep(delay);\n\n      await this.batchPutWithExponentialBackoff({\n        logger,\n        items: unprocessedItems.map((item) => item.put),\n        delay: Math.round(Math.pow(delay, 1.2)),\n        attempts: attempts + 1,\n        maxRetries,\n      });\n    }\n\n    logger.info('Successfully wrote all batches!');\n  }\n}\n"]} |
{ | ||
"name": "@jupiterone/dynamodb-dao", | ||
"version": "1.7.6", | ||
"version": "1.8.0", | ||
"description": "DynamoDB Data Access Object (DAO) helper library", | ||
"repository": { | ||
"type": "git", | ||
"url": "https://github.com/JupiterOne/dynamodb-dao" | ||
}, | ||
"license": "MIT", | ||
"main": "index.js", | ||
"types": "index.d.ts", | ||
"repository": "git@github.com:jupiterone/dynamodb-dao.git", | ||
"author": "JupiterOne <dev@jupiterone.io>", | ||
"license": "MIT", | ||
"publishConfig": { | ||
@@ -11,0 +14,0 @@ "access": "public" |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
No repository
Supply chain riskPackage does not have a linked source code repository. Without this field, a package will have no reference to the location of the source code use to generate the package.
Found 1 instance in 1 package
0
104678
817