ddb-table
Version:
Strongly typed library for querying and modeling DynamoDB documents.
112 lines (111 loc) • 26.1 kB
JavaScript
"use strict";
exports.__esModule = true;
exports.default = void 0;
var _UpdateValueExpression = _interopRequireDefault(require("./UpdateValueExpression"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
// Docs:
// https://docs.aws.amazon.com/amazondynamodb/latest/developerguide/Expressions.UpdateExpressions.html
class UpdateExpression {
constructor(names, values, init) {
this.names = void 0;
this.values = void 0;
this.sets = void 0;
this.removes = void 0;
this.adds = void 0;
this.deletes = void 0;
this.names = names;
this.values = values;
this.sets = {};
this.removes = {};
this.adds = {};
this.deletes = {};
if (!init) return;
const parts = init.trim().split(/(?:^|\s+)(SET|REMOVE|ADD|DELETE)(?:\s+)/gi);
for (let i = 1; i < parts.length; i += 2) {
const action = parts[i];
const terms = parts[i + 1].split(/\s*,\s*/g);
switch (action.toUpperCase()) {
case 'SET':
{
for (const term of terms) {
const [path, value] = term.split(/\s*=\s*/);
this.sets[path] = value;
}
break;
}
case 'REMOVE':
{
for (const term of terms) {
this.removes[term] = 1;
}
break;
}
case 'ADD':
{
for (const term of terms) {
const [path, value] = term.split(/\s+/);
this.adds[path] = value;
}
break;
}
case 'DELETE':
{
for (const term of terms) {
const [path, value] = term.split(/\s+/);
this.deletes[path] = value;
}
break;
}
}
}
}
set(path, value) {
if (!Array.isArray(path)) {
path = [path];
}
const pathName = this.names.add(...path);
const valueKey = String(path[path.length - 1]);
this.sets[pathName] = typeof value === 'function' ? value(new _UpdateValueExpression.default(this.names, this.values, pathName, valueKey)) : this.values.add(valueKey, value);
return this;
}
remove(...path) {
this.removes[this.names.add(...path)] = 1;
return this;
}
add(path, value) {
if (!Array.isArray(path)) {
path = [path];
}
this.adds[this.names.add(...path)] = this.values.add(String(path[path.length - 1]), value);
return this;
}
delete(path, value) {
if (!Array.isArray(path)) {
path = [path];
}
this.deletes[this.names.add(...path)] = this.values.add(String(path[path.length - 1]), value);
return this;
}
serialize() {
const exp = [];
const sets = Object.entries(this.sets).map(([key, value]) => `${key} = ${value}`);
if (sets.length) {
exp.push(`SET ${sets.join(', ')}`);
}
const removes = Object.keys(this.removes);
if (removes.length) {
exp.push(`REMOVE ${removes.join(', ')}`);
}
const adds = Object.entries(this.adds).map(([key, value]) => `${key} ${value}`);
if (adds.length) {
exp.push(`ADD ${adds.join(', ')}`);
}
const deletes = Object.entries(this.deletes).map(([key, value]) => `${key} ${value}`);
if (deletes.length) {
exp.push(`DELETE ${deletes.join(', ')}`);
}
return exp.join(' ') || undefined;
}
}
exports.default = UpdateExpression;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_UpdateValueExpression","_interopRequireDefault","require","obj","__esModule","default","UpdateExpression","constructor","names","values","init","sets","removes","adds","deletes","parts","trim","split","i","length","action","terms","toUpperCase","term","path","value","set","Array","isArray","pathName","add","valueKey","String","UpdateValueExpression","remove","delete","serialize","exp","Object","entries","map","key","push","join","keys","undefined","exports"],"sources":["../../src/expressions/UpdateExpression.ts"],"sourcesContent":["import { UpdateExpression as UpdateExpressionStr } from '../DocumentClient';\nimport ExpressionAttributeNames from './ExpressionAttributeNames';\nimport ExpressionAttributeValues from './ExpressionAttributeValues';\nimport UpdateValueExpression from './UpdateValueExpression';\n\n// Docs:\n// https://docs.aws.amazon.com/amazondynamodb/latest/developerguide/Expressions.UpdateExpressions.html\n\nexport type AddValue<T> = [T] extends [\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  Set<any> | number | undefined,\n]\n  ? T\n  : never;\n\nexport type DeleteValue<T> = [T] extends [\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  Set<any> | undefined,\n]\n  ? T\n  : never;\n\nexport type SetValue<T, V> = V | ((exp: UpdateValueExpression<T, V>) => string);\n\nexport default class UpdateExpression<T> {\n  private names: ExpressionAttributeNames<T>;\n  private values: ExpressionAttributeValues;\n\n  private sets: { [key: string]: string };\n  private removes: { [key: string]: 1 };\n  private adds: { [key: string]: string };\n  private deletes: { [key: string]: string };\n\n  public constructor(\n    names: ExpressionAttributeNames<T>,\n    values: ExpressionAttributeValues,\n    init?: UpdateExpressionStr,\n  ) {\n    this.names = names;\n    this.values = values;\n\n    this.sets = {};\n    this.removes = {};\n    this.adds = {};\n    this.deletes = {};\n\n    if (!init) return;\n\n    const parts = init\n      .trim()\n      .split(/(?:^|\\s+)(SET|REMOVE|ADD|DELETE)(?:\\s+)/gi);\n    for (let i = 1; i < parts.length; i += 2) {\n      const action = parts[i];\n      const terms = parts[i + 1].split(/\\s*,\\s*/g);\n\n      switch (action.toUpperCase()) {\n        case 'SET': {\n          for (const term of terms) {\n            const [path, value] = term.split(/\\s*=\\s*/);\n            this.sets[path] = value;\n          }\n          break;\n        }\n\n        case 'REMOVE': {\n          for (const term of terms) {\n            this.removes[term] = 1;\n          }\n          break;\n        }\n\n        case 'ADD': {\n          for (const term of terms) {\n            const [path, value] = term.split(/\\s+/);\n            this.adds[path] = value;\n          }\n          break;\n        }\n\n        case 'DELETE': {\n          for (const term of terms) {\n            const [path, value] = term.split(/\\s+/);\n            this.deletes[path] = value;\n          }\n          break;\n        }\n      }\n    }\n  }\n\n  public set<K1 extends keyof T>(\n    path: K1 | [K1],\n    value: SetValue<T, T[K1]>,\n  ): this;\n  public set<K1 extends keyof T, K2 extends keyof T[K1]>(\n    path: [K1, K2],\n    value: SetValue<T, T[K1][K2]>,\n  ): this;\n  public set<\n    K1 extends keyof T,\n    K2 extends keyof T[K1],\n    K3 extends keyof T[K1][K2],\n  >(path: [K1, K2, K3], value: SetValue<T, T[K1][K2][K3]>): this;\n  public set<\n    K1 extends keyof T,\n    K2 extends keyof T[K1],\n    K3 extends keyof T[K1][K2],\n    K4 extends keyof T[K1][K2][K3],\n  >(path: [K1, K2, K3, K4], value: SetValue<T, T[K1][K2][K3][K4]>): this;\n  public set<\n    K1 extends keyof T,\n    K2 extends keyof T[K1],\n    K3 extends keyof T[K1][K2],\n    K4 extends keyof T[K1][K2][K3],\n    K5 extends keyof T[K1][K2][K3][K4],\n  >(\n    path: [K1, K2, K3, K4, K5],\n    value: SetValue<T, T[K1][K2][K3][K4][K5]>,\n  ): this;\n  public set<\n    K1 extends keyof T,\n    K2 extends keyof T[K1],\n    K3 extends keyof T[K1][K2],\n    K4 extends keyof T[K1][K2][K3],\n    K5 extends keyof T[K1][K2][K3][K4],\n    K6 extends keyof T[K1][K2][K3][K4][K5],\n  >(\n    path: [K1, K2, K3, K4, K5, K6],\n    value: SetValue<T, T[K1][K2][K3][K4][K5][K6]>,\n  ): this;\n  public set<\n    K1 extends keyof T,\n    K2 extends keyof T[K1],\n    K3 extends keyof T[K1][K2],\n    K4 extends keyof T[K1][K2][K3],\n    K5 extends keyof T[K1][K2][K3][K4],\n    K6 extends keyof T[K1][K2][K3][K4][K5],\n    K7 extends keyof T[K1][K2][K3][K4][K5][K6],\n  >(\n    path: [K1, K2, K3, K4, K5, K6, K7],\n    value: SetValue<T, T[K1][K2][K3][K4][K5][K6][K7]>,\n  ): this;\n  public set<\n    K1 extends keyof T,\n    K2 extends keyof T[K1],\n    K3 extends keyof T[K1][K2],\n    K4 extends keyof T[K1][K2][K3],\n    K5 extends keyof T[K1][K2][K3][K4],\n    K6 extends keyof T[K1][K2][K3][K4][K5],\n    K7 extends keyof T[K1][K2][K3][K4][K5][K6],\n    K8 extends keyof T[K1][K2][K3][K4][K5][K6][K7],\n  >(\n    path: [K1, K2, K3, K4, K5, K6, K7, K8],\n    value: SetValue<T, T[K1][K2][K3][K4][K5][K6][K7][K8]>,\n  ): this;\n  public set<\n    K1 extends keyof T,\n    K2 extends keyof T[K1],\n    K3 extends keyof T[K1][K2],\n    K4 extends keyof T[K1][K2][K3],\n    K5 extends keyof T[K1][K2][K3][K4],\n    K6 extends keyof T[K1][K2][K3][K4][K5],\n    K7 extends keyof T[K1][K2][K3][K4][K5][K6],\n    K8 extends keyof T[K1][K2][K3][K4][K5][K6][K7],\n  >(\n    path: K1 | [K1, K2?, K3?, K4?, K5?, K6?, K7?, K8?, ...(string | number)[]],\n    value: SetValue<T, unknown>,\n  ): this {\n    if (!Array.isArray(path)) {\n      path = [path];\n    }\n\n    const pathName = this.names.add(...path);\n    const valueKey = String(path[path.length - 1]);\n\n    this.sets[pathName] =\n      typeof value === 'function'\n        ? value(\n            new UpdateValueExpression(\n              this.names,\n              this.values,\n              pathName,\n              valueKey,\n            ),\n          )\n        : this.values.add(valueKey, value);\n\n    return this;\n  }\n\n  public remove<\n    K1 extends keyof T,\n    K2 extends keyof T[K1],\n    K3 extends keyof T[K1][K2],\n    K4 extends keyof T[K1][K2][K3],\n    K5 extends keyof T[K1][K2][K3][K4],\n    K6 extends keyof T[K1][K2][K3][K4][K5],\n    K7 extends keyof T[K1][K2][K3][K4][K5][K6],\n    K8 extends keyof T[K1][K2][K3][K4][K5][K6][K7],\n  >(\n    ...path: [K1, K2?, K3?, K4?, K5?, K6?, K7?, K8?, ...(string | number)[]]\n  ): this {\n    this.removes[this.names.add(...path)] = 1;\n\n    return this;\n  }\n\n  public add<K1 extends keyof T>(path: K1 | [K1], value: AddValue<T[K1]>): this;\n  public add<K1 extends keyof T, K2 extends keyof T[K1]>(\n    path: [K1, K2],\n    value: AddValue<T[K1][K2]>,\n  ): this;\n  public add<\n    K1 extends keyof T,\n    K2 extends keyof T[K1],\n    K3 extends keyof T[K1][K2],\n  >(path: [K1, K2, K3], value: AddValue<T[K1][K2][K3]>): this;\n  public add<\n    K1 extends keyof T,\n    K2 extends keyof T[K1],\n    K3 extends keyof T[K1][K2],\n    K4 extends keyof T[K1][K2][K3],\n  >(path: [K1, K2, K3, K4], value: AddValue<T[K1][K2][K3][K4]>): this;\n  public add<\n    K1 extends keyof T,\n    K2 extends keyof T[K1],\n    K3 extends keyof T[K1][K2],\n    K4 extends keyof T[K1][K2][K3],\n    K5 extends keyof T[K1][K2][K3][K4],\n  >(path: [K1, K2, K3, K4, K5], value: AddValue<T[K1][K2][K3][K4][K5]>): this;\n  public add<\n    K1 extends keyof T,\n    K2 extends keyof T[K1],\n    K3 extends keyof T[K1][K2],\n    K4 extends keyof T[K1][K2][K3],\n    K5 extends keyof T[K1][K2][K3][K4],\n    K6 extends keyof T[K1][K2][K3][K4][K5],\n  >(\n    path: [K1, K2, K3, K4, K5, K6],\n    value: AddValue<T[K1][K2][K3][K4][K5][K6]>,\n  ): this;\n  public add<\n    K1 extends keyof T,\n    K2 extends keyof T[K1],\n    K3 extends keyof T[K1][K2],\n    K4 extends keyof T[K1][K2][K3],\n    K5 extends keyof T[K1][K2][K3][K4],\n    K6 extends keyof T[K1][K2][K3][K4][K5],\n    K7 extends keyof T[K1][K2][K3][K4][K5][K6],\n  >(\n    path: [K1, K2, K3, K4, K5, K6, K7],\n    value: AddValue<T[K1][K2][K3][K4][K5][K6][K7]>,\n  ): this;\n  public add<\n    K1 extends keyof T,\n    K2 extends keyof T[K1],\n    K3 extends keyof T[K1][K2],\n    K4 extends keyof T[K1][K2][K3],\n    K5 extends keyof T[K1][K2][K3][K4],\n    K6 extends keyof T[K1][K2][K3][K4][K5],\n    K7 extends keyof T[K1][K2][K3][K4][K5][K6],\n    K8 extends keyof T[K1][K2][K3][K4][K5][K6][K7],\n  >(\n    path: [K1, K2, K3, K4, K5, K6, K7, K8],\n    value: AddValue<T[K1][K2][K3][K4][K5][K6][K7][K8]>,\n  ): this;\n  public add<\n    K1 extends keyof T,\n    K2 extends keyof T[K1],\n    K3 extends keyof T[K1][K2],\n    K4 extends keyof T[K1][K2][K3],\n    K5 extends keyof T[K1][K2][K3][K4],\n    K6 extends keyof T[K1][K2][K3][K4][K5],\n    K7 extends keyof T[K1][K2][K3][K4][K5][K6],\n    K8 extends keyof T[K1][K2][K3][K4][K5][K6][K7],\n  >(\n    path: K1 | [K1, K2?, K3?, K4?, K5?, K6?, K7?, K8?, ...(string | number)[]],\n    value: unknown,\n  ): this {\n    if (!Array.isArray(path)) {\n      path = [path];\n    }\n\n    this.adds[this.names.add(...path)] = this.values.add(\n      String(path[path.length - 1]),\n      value,\n    );\n\n    return this;\n  }\n\n  public delete<K1 extends keyof T>(\n    path: K1 | [K1],\n    value: DeleteValue<T[K1]>,\n  ): this;\n  public delete<K1 extends keyof T, K2 extends keyof T[K1]>(\n    path: [K1, K2],\n    value: DeleteValue<T[K1][K2]>,\n  ): this;\n  public delete<\n    K1 extends keyof T,\n    K2 extends keyof T[K1],\n    K3 extends keyof T[K1][K2],\n  >(path: [K1, K2, K3], value: DeleteValue<T[K1][K2][K3]>): this;\n  public delete<\n    K1 extends keyof T,\n    K2 extends keyof T[K1],\n    K3 extends keyof T[K1][K2],\n    K4 extends keyof T[K1][K2][K3],\n  >(path: [K1, K2, K3, K4], value: DeleteValue<T[K1][K2][K3][K4]>): this;\n  public delete<\n    K1 extends keyof T,\n    K2 extends keyof T[K1],\n    K3 extends keyof T[K1][K2],\n    K4 extends keyof T[K1][K2][K3],\n    K5 extends keyof T[K1][K2][K3][K4],\n  >(\n    path: [K1, K2, K3, K4, K5],\n    value: DeleteValue<T[K1][K2][K3][K4][K5]>,\n  ): this;\n  public delete<\n    K1 extends keyof T,\n    K2 extends keyof T[K1],\n    K3 extends keyof T[K1][K2],\n    K4 extends keyof T[K1][K2][K3],\n    K5 extends keyof T[K1][K2][K3][K4],\n    K6 extends keyof T[K1][K2][K3][K4][K5],\n  >(\n    path: [K1, K2, K3, K4, K5, K6],\n    value: DeleteValue<T[K1][K2][K3][K4][K5][K6]>,\n  ): this;\n  public delete<\n    K1 extends keyof T,\n    K2 extends keyof T[K1],\n    K3 extends keyof T[K1][K2],\n    K4 extends keyof T[K1][K2][K3],\n    K5 extends keyof T[K1][K2][K3][K4],\n    K6 extends keyof T[K1][K2][K3][K4][K5],\n    K7 extends keyof T[K1][K2][K3][K4][K5][K6],\n  >(\n    path: [K1, K2, K3, K4, K5, K6, K7],\n    value: DeleteValue<T[K1][K2][K3][K4][K5][K6][K7]>,\n  ): this;\n  public delete<\n    K1 extends keyof T,\n    K2 extends keyof T[K1],\n    K3 extends keyof T[K1][K2],\n    K4 extends keyof T[K1][K2][K3],\n    K5 extends keyof T[K1][K2][K3][K4],\n    K6 extends keyof T[K1][K2][K3][K4][K5],\n    K7 extends keyof T[K1][K2][K3][K4][K5][K6],\n    K8 extends keyof T[K1][K2][K3][K4][K5][K6][K7],\n  >(\n    path: [K1, K2, K3, K4, K5, K6, K7, K8],\n    value: DeleteValue<T[K1][K2][K3][K4][K5][K6][K7][K8]>,\n  ): this;\n  public delete<\n    K1 extends keyof T,\n    K2 extends keyof T[K1],\n    K3 extends keyof T[K1][K2],\n    K4 extends keyof T[K1][K2][K3],\n    K5 extends keyof T[K1][K2][K3][K4],\n    K6 extends keyof T[K1][K2][K3][K4][K5],\n    K7 extends keyof T[K1][K2][K3][K4][K5][K6],\n    K8 extends keyof T[K1][K2][K3][K4][K5][K6][K7],\n  >(\n    path: K1 | [K1, K2?, K3?, K4?, K5?, K6?, K7?, K8?, ...(string | number)[]],\n    value: DeleteValue<unknown>,\n  ): this {\n    if (!Array.isArray(path)) {\n      path = [path];\n    }\n\n    this.deletes[this.names.add(...path)] = this.values.add(\n      String(path[path.length - 1]),\n      value,\n    );\n\n    return this;\n  }\n\n  public serialize(): UpdateExpressionStr | undefined {\n    const exp: string[] = [];\n\n    const sets = Object.entries(this.sets).map(\n      ([key, value]) => `${key} = ${value}`,\n    );\n    if (sets.length) {\n      exp.push(`SET ${sets.join(', ')}`);\n    }\n\n    const removes = Object.keys(this.removes);\n    if (removes.length) {\n      exp.push(`REMOVE ${removes.join(', ')}`);\n    }\n\n    const adds = Object.entries(this.adds).map(\n      ([key, value]) => `${key} ${value}`,\n    );\n    if (adds.length) {\n      exp.push(`ADD ${adds.join(', ')}`);\n    }\n\n    const deletes = Object.entries(this.deletes).map(\n      ([key, value]) => `${key} ${value}`,\n    );\n    if (deletes.length) {\n      exp.push(`DELETE ${deletes.join(', ')}`);\n    }\n\n    return exp.join(' ') || undefined;\n  }\n}\n"],"mappings":"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"}