@qrvey/data-persistence 0.5.7 → 0.5.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/helpers/crudHelpers.js +3 -4
- package/dist/cjs/helpers/crudHelpers.js.map +1 -1
- package/dist/cjs/helpers/errorHelper.js +1 -2
- package/dist/cjs/helpers/errorHelper.js.map +1 -1
- package/dist/cjs/helpers/queryHelpers.js +2 -2
- package/dist/cjs/helpers/queryHelpers.js.map +1 -1
- package/dist/cjs/helpers/tableHelper.js +4 -5
- package/dist/cjs/helpers/tableHelper.js.map +1 -1
- package/dist/cjs/services/crud.service.js.map +1 -1
- package/dist/cjs/services/crudFactory.service.js +17 -7
- package/dist/cjs/services/crudFactory.service.js.map +1 -1
- package/dist/cjs/services/cruds/dynamodb/dynamoDbCrud.service.js.map +1 -1
- package/dist/cjs/services/cruds/dynamodb/queryBuilder.service.js.map +1 -1
- package/dist/cjs/services/cruds/dynamodb/queryBuilderCondition.service.js.map +1 -1
- package/dist/cjs/services/cruds/postgresql/connection.service.js.map +1 -1
- package/dist/cjs/services/cruds/postgresql/postgreSqlClient.service.js.map +1 -1
- package/dist/cjs/services/cruds/postgresql/postgreSqlCrud.service.js.map +1 -1
- package/dist/cjs/services/cruds/postgresql/query.service.js.map +1 -1
- package/dist/cjs/services/dbPool.service.js +1 -2
- package/dist/cjs/services/dbPool.service.js.map +1 -1
- package/dist/cjs/tsconfig.cjs.tsbuildinfo +1 -0
- package/dist/cjs/utils/constants.js +2 -2
- package/dist/cjs/utils/constants.js.map +1 -1
- package/dist/esm/{chunk-DHIGNHXS.mjs → chunk-2H6RO6ZL.mjs} +4 -6
- package/dist/esm/chunk-2H6RO6ZL.mjs.map +1 -0
- package/dist/esm/{chunk-6MOAJFFY.mjs → chunk-2OYWEFNZ.mjs} +8 -15
- package/dist/esm/chunk-2OYWEFNZ.mjs.map +1 -0
- package/dist/esm/{dynamoDbCrud.service-J7ZOB5QW.mjs → dynamoDbCrud.service-NRSGRPDQ.mjs} +30 -56
- package/dist/esm/dynamoDbCrud.service-NRSGRPDQ.mjs.map +1 -0
- package/dist/esm/index.d.mts +1 -1
- package/dist/esm/index.mjs +6 -7
- package/dist/esm/index.mjs.map +1 -1
- package/dist/esm/{postgreSqlCrud.service-JGJELA6R.mjs → postgreSqlCrud.service-AD2CHR2Z.mjs} +13 -22
- package/dist/esm/postgreSqlCrud.service-AD2CHR2Z.mjs.map +1 -0
- package/dist/types/index.d.ts +1 -1
- package/package.json +8 -8
- package/dist/esm/chunk-6MOAJFFY.mjs.map +0 -1
- package/dist/esm/chunk-DHIGNHXS.mjs.map +0 -1
- package/dist/esm/dynamoDbCrud.service-J7ZOB5QW.mjs.map +0 -1
- package/dist/esm/postgreSqlCrud.service-JGJELA6R.mjs.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/services/cruds/postgresql/connection.service.ts","../../src/services/cruds/postgresql/query.service.ts","../../src/services/cruds/postgresql/postgreSqlClient.service.ts","../../src/services/cruds/postgresql/postgreSqlCrud.service.ts"],"names":[],"mappings":"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","file":"postgreSqlCrud.service-AD2CHR2Z.mjs","sourcesContent":["import { Client } from 'pg';\n\nexport default class ConnectionService {\n get connectionString() {\n const connectionString =\n process.env.MULTIPLATFORM_PG_CONNECTION_STRING || '';\n if (!connectionString) {\n throw new Error(\n 'MULTIPLATFORM_PG_CONNECTION_STRING environment variable must be configured',\n );\n }\n return connectionString;\n }\n\n async getClient(): Promise<Client> {\n const client: Client = new Client({\n connectionString: this.connectionString,\n });\n await client.connect();\n return client;\n }\n\n releaseClient(client: Client): void {\n try {\n client.end();\n } catch {\n // eslint-disable-next-line no-console\n console.log('Error releasing client');\n }\n }\n}\n","/* eslint-disable no-console */\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { Client, PoolClient, QueryResult } from 'pg';\nimport ConnectionService from './connection.service';\nimport { DbPool } from '../../../types';\n\nexport default class QueryService {\n private connectionService: ConnectionService;\n\n constructor(private pool?: DbPool) {\n this.connectionService = new ConnectionService();\n }\n\n async runQuery(\n queryText: string,\n values?: any[],\n ): Promise<QueryResult<any>> {\n const client: PoolClient | Client | any = await (this.pool\n ? this.pool.connect()\n : this.connectionService.getClient());\n\n try {\n if (process.env.NODE_ENV === 'debugging')\n console.log('queryText:::', queryText);\n const result = await client.query(queryText, values);\n return result;\n } finally {\n if (this.pool) {\n await client.release();\n } else {\n this.connectionService.releaseClient(client as Client);\n }\n }\n }\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\n/* eslint-disable no-console */\n\nimport format from 'pg-format';\nimport { QueryResult } from 'pg';\nimport { AggregateFunction, DbPool, FilterLogicOperator } from '../../../types';\nimport {\n ICompositeFilter,\n IFilter,\n IFindOptions,\n IFindPagination,\n ISorting,\n IUpdateExpressions,\n IUpdateExpressionsOptions,\n} from '../../../interfaces';\nimport QueryService from './query.service';\nimport {\n FILTER_LOGIC_OPERATORS,\n SORT_DIRECTIONS,\n POSTGRES_FILTER_OPERATOR_MAP,\n DEFAULT_PG_SCHEMA,\n FilterOperator,\n DYNAMO_DB_UPDATE_ACTIONS,\n} from '../../../utils/constants';\nimport { CrudSchema } from '../../../schemas';\nimport { getTableName } from '../../../helpers/tableHelper';\nimport { buildAggFunctionAlias } from '../../../helpers/queryHelpers';\nimport { IFindRawWith } from '../../../interfaces/findRawWith.interface';\n\nexport default class PostgresqlClientService<T> extends QueryService {\n private crudSchema: typeof CrudSchema;\n constructor(tableSchema: typeof CrudSchema, poolClient?: DbPool) {\n super(poolClient);\n this.crudSchema = tableSchema;\n }\n\n get dbSchema() {\n return this.crudSchema.schema || DEFAULT_PG_SCHEMA;\n }\n\n get tableName() {\n return (\n getTableName(this.crudSchema.table, 'alias') ||\n getTableName(this.crudSchema.table)\n );\n }\n\n get isTemporalTable() {\n return this.crudSchema?.isTemporalTable;\n }\n\n getWildcardValue(operator: FilterOperator, value: string): string {\n if (\n operator === FilterOperator.CONTAINS ||\n operator === FilterOperator.NOT_CONTAINS\n ) {\n return '%' + value + '%';\n } else if (operator === FilterOperator.STARTS_WITH) {\n return value + '%';\n } else {\n return value;\n }\n }\n\n private buildClause(\n operator: FilterOperator,\n attribute: string,\n relativePath: string | undefined,\n value: any,\n ): string {\n const formattedValue = format.literal(value);\n operator = operator\n ? (operator.toUpperCase() as FilterOperator)\n : FilterOperator.EQUAL;\n const postgresOperator = POSTGRES_FILTER_OPERATOR_MAP[operator];\n\n if (!postgresOperator)\n throw new Error(`Unsupported filter operator: ${operator}`);\n\n let property;\n const filterProperty = format.ident(attribute);\n const columnExists = !!this.crudSchema.columns[attribute];\n const columnType =\n columnExists && this.crudSchema.columns[attribute]?.type;\n\n if (relativePath != undefined) {\n const attributePath = relativePath.split('.').join(',');\n\n property = `(\"${attribute}\" #> '{${attributePath}}')`;\n if (value != null) {\n const comparisonValueType =\n this.getValueTypeAsPostgresDefinition(value);\n property += `::${comparisonValueType}`;\n }\n } else {\n property = columnExists\n ? filterProperty\n : `(\"qvAttributes\" ->> '${attribute}')`;\n }\n\n if (operator === FilterOperator.IN) {\n const formattedValues = Array.isArray(value)\n ? value.map(format.literal)\n : [formattedValue];\n return `${property} ${postgresOperator} (${formattedValues.join(\n ', ',\n )})`;\n }\n\n if (operator === FilterOperator.BETWEEN) {\n return `${property} ${postgresOperator} ${value[0]} AND ${value[1]}`;\n }\n\n /**\n * ? Additional filter to avoid error when column accepts null values.\n */\n if (operator === FilterOperator.NOT_EQUAL && value !== null) {\n return `(${property} ${postgresOperator} ${format.literal(\n value,\n )} OR ${property} IS NULL)`;\n }\n\n if (\n operator === FilterOperator.NOT_EXIST ||\n operator === FilterOperator.EXIST\n ) {\n return `${property} ${postgresOperator}`;\n }\n\n if (\n (operator === FilterOperator.CONTAINS ||\n operator === FilterOperator.NOT_CONTAINS) &&\n columnType === 'array'\n ) {\n const filterValue =\n typeof value === 'number' ? value : `'${value}'`;\n let filterString = `${filterValue} = ANY(${property})`;\n\n if (operator === FilterOperator.NOT_CONTAINS) {\n if (value === null) {\n filterString = `(NOT (${filterString}))`;\n } else {\n filterString = `(NOT (${filterString}) or ${property} IS NULL)`;\n }\n }\n return filterString;\n }\n\n const wildcardValue = this.getWildcardValue(operator, value);\n return `${property} ${postgresOperator} ${format.literal(\n wildcardValue,\n )}`;\n }\n\n private buildFilterClause(\n filters: IFilter[] | ICompositeFilter,\n logicOperator?: FilterLogicOperator,\n ): string {\n if (Array.isArray(filters)) {\n const filterClauses = filters.map((filter) => {\n return this.buildClause(\n filter.operator as FilterOperator,\n filter.attribute,\n filter.relativePath,\n filter.value,\n );\n });\n return filterClauses.join(\n ` ${logicOperator ?? FILTER_LOGIC_OPERATORS.AND} `,\n );\n } else {\n return this.buildQueryByClause(filters);\n }\n }\n\n private isCompositeFilter = function (value: any) {\n return 'OR' in value || 'AND' in value;\n };\n\n buildQueryByClause(filters: IFilter[] | ICompositeFilter): string {\n let filterClauses: string = '';\n let isFirstFilter = true;\n\n for (const [key, value] of Object.entries(filters)) {\n if (!isFirstFilter) {\n filterClauses += key === 'AND' ? ' AND ' : ' OR ';\n }\n\n if (this.isCompositeFilter(value)) {\n filterClauses += '(';\n filterClauses += this.buildQueryByClause(\n value as ICompositeFilter,\n );\n filterClauses += ')';\n } else {\n (value as IFilter[]).forEach((filter: IFilter) => {\n let clause = '';\n if (this.isCompositeFilter(filter)) {\n clause = `(${this.buildQueryByClause(\n filter as ICompositeFilter,\n )})`;\n } else {\n clause = this.buildClause(\n filter.operator as FilterOperator,\n filter.attribute,\n filter.relativePath,\n filter.value,\n );\n }\n filterClauses += `${clause} ${key} `;\n });\n }\n\n isFirstFilter = false;\n }\n\n filterClauses = filterClauses.replace(/\\s+(AND|OR)\\s*$/, '');\n return filterClauses;\n }\n\n private formatOrderByItem(sort: ISorting): string {\n return `${format.ident(sort.column)} ${\n sort.direction || SORT_DIRECTIONS.ASC\n }`;\n }\n\n private buildOrderByClause(querySorting: ISorting[]): string {\n try {\n return querySorting.map(this.formatOrderByItem).join(', ');\n } catch (error) {\n return '';\n }\n }\n\n formatArray(array: any[]) {\n const isNumberArray = typeof array[0] === 'number';\n if (isNumberArray) {\n return `{${array.join(',')}}`;\n } else {\n return `{${array.map((val) => `\"${val}\"`).join(',')}}`;\n }\n }\n\n formatValue(value: any) {\n if (Array.isArray(value)) {\n if (!value?.length) return '{}';\n const isNumberArray = typeof value[0] === 'number';\n if (isNumberArray) {\n return `{${value.join(',')}}`;\n } else {\n return `{${value.map((val: any) => `\"${val}\"`).join(',')}}`;\n }\n }\n return value;\n }\n\n async createCommand(data: any[]): Promise<any> {\n const keys = Object.keys(data[0]); // Assuming all objects have the same keys\n const values = data.map((item) =>\n keys.map((key) => this.formatValue(item[key])),\n );\n\n const query = format(\n `INSERT INTO ${format.ident(this.dbSchema)}.${format.ident(\n this.tableName,\n )} (%I) VALUES %L RETURNING *;`,\n keys,\n values,\n );\n\n return this.runQuery(query);\n }\n\n private isValidFiltersInput(\n filters: IFilter[] | ICompositeFilter,\n ): boolean {\n const isValidArrayFilters =\n Array.isArray(filters) && filters?.length > 0;\n const isValidCompositeFilters = this.isCompositeFilter(filters);\n return isValidArrayFilters || isValidCompositeFilters;\n }\n\n private replaceFilterTokensInQuery(\n query: string,\n filters?: IFilter[] | ICompositeFilter,\n ) {\n if (!filters) return query;\n\n if (this.isValidFiltersInput(filters)) {\n const filterClause = this.buildFilterClause(filters);\n return query.replace(/{{filters}}/g, filterClause);\n }\n }\n\n private addFiltersToQuery(\n query: string,\n filters?: IFilter[] | ICompositeFilter,\n ): string {\n if (!filters) return query;\n\n if (this.isValidFiltersInput(filters))\n query += ` WHERE ${this.buildFilterClause(filters)}`;\n return query;\n }\n\n addOrderByToQuery(query: string, orderBy?: ISorting[]): string {\n if (orderBy) query += ` ORDER BY ${this.buildOrderByClause(orderBy)}`;\n return query;\n }\n\n private addPaginationToQuery(\n query: string,\n pagination?: IFindPagination,\n ): string {\n if (pagination) {\n const { limit, from } = pagination;\n if (limit) query += ` LIMIT ${limit}`;\n if (from) query += ` OFFSET ${from}`;\n }\n return query;\n }\n\n private getSelectClause(\n aggregateFunction: AggregateFunction | undefined,\n fields: string[] = [],\n ) {\n if (aggregateFunction)\n return `CAST(${aggregateFunction}(1) AS INTEGER) AS \"${buildAggFunctionAlias(\n aggregateFunction,\n )}\"`;\n if (!fields?.length) return '*';\n\n return this.parseFields(fields).join(', ');\n }\n\n private parseFields(fields: String[]): String[] {\n const columnsFromSchema: String[] = Object.keys(\n this.crudSchema.columns,\n );\n const attributes: String[] = fields\n .filter((field) => columnsFromSchema.indexOf(field) !== -1)\n .map((field) => `\"${field}\"`);\n\n fields\n .filter((field) => columnsFromSchema.indexOf(field) === -1)\n .forEach((field) => {\n attributes.push(`\"qvAttributes\" ->> '${field}' as \"${field}\"`);\n });\n return attributes;\n }\n\n private resolveWithQueries(rawWith: IFindRawWith[]): string[] {\n const withQueries = rawWith.map(({ alias, query, filters }) => {\n const withQuery = this.replaceFilterTokensInQuery(query, filters);\n return `${alias} AS (${withQuery})`;\n });\n return withQueries;\n }\n\n getRawWithClause(rawWith?: IFindRawWith[]): string {\n let rawWithClause = '';\n if (rawWith?.length) {\n const withQueries = this.resolveWithQueries(rawWith);\n rawWithClause = 'WITH ' + withQueries.join(',\\n');\n }\n return rawWithClause;\n }\n\n getQueryFrom() {\n return this.isTemporalTable\n ? format.ident(this.tableName)\n : `${format.ident(this.dbSchema)}.${format.ident(this.tableName)}`;\n }\n\n async findCommand(options: IFindOptions = {}): Promise<T[]> {\n const rawWithClause = this.getRawWithClause(options.rawWith);\n let query = `SELECT ${this.getSelectClause(\n options.aggregateFunction,\n options.fields,\n )} FROM ${this.getQueryFrom()}`;\n query = this.addFiltersToQuery(query, options.filters);\n if (!options.aggregateFunction) {\n query = this.addOrderByToQuery(query, options.sorting);\n query = this.addPaginationToQuery(query, options.pagination);\n }\n if (rawWithClause) {\n query = `${rawWithClause} ${query}`;\n }\n return (await this.runQuery(query)).rows;\n }\n\n sanitizeValue(value: any): string {\n if (Array.isArray(value)) {\n if (value.length === 0) '[]';\n const formattedArray = value\n .map((item) => {\n if (typeof item === 'string') {\n return `'${item}'`;\n } else if (typeof item === 'object') {\n return JSON.stringify(item);\n } else {\n return item;\n }\n })\n .join(',');\n\n return JSON.stringify(formattedArray);\n } else {\n return format.literal(value);\n }\n }\n\n async updateCommand(\n filters: IFilter[] | ICompositeFilter,\n data: Partial<any>,\n ): Promise<QueryResult<any>> {\n let query = `UPDATE ${format.ident(this.dbSchema)}.${format.ident(\n this.tableName,\n )} SET`;\n\n const updateClauses = Object.entries(data).map(([key, value]) => {\n const dbValue = format.literal(this.formatValue(value));\n return `${format.ident(key)} = ${dbValue}`;\n });\n query += ` ${updateClauses.join(', ')}`;\n\n query += ' WHERE ';\n query += this.buildFilterClause(filters);\n\n return this.runQuery(query);\n }\n\n private buildFilterClauseForFilterGroups(\n filterGroups: IFilter[][],\n ): string {\n const filterClauses = filterGroups.map((filterGroup) => {\n return `(${this.buildFilterClause(filterGroup)})`;\n });\n return filterClauses.join(' OR ');\n }\n\n async deleteCommand(\n filters?: ICompositeFilter | IFilter[] | IFilter[][],\n useFilterGroups: boolean = false,\n ): Promise<QueryResult<any>> {\n let query = `DELETE FROM ${format.ident(this.dbSchema)}.${format.ident(\n this.tableName,\n )}`;\n if (filters) {\n query += ' WHERE ';\n\n if (useFilterGroups) {\n query += this.buildFilterClauseForFilterGroups(\n filters as IFilter[][],\n );\n } else {\n query += this.buildFilterClause(\n filters as ICompositeFilter | IFilter[],\n );\n }\n }\n\n return this.runQuery(query);\n }\n\n query(queryText: string, values?: any[]) {\n return this.runQuery(queryText, values);\n }\n\n public async updateExpressionCommand(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n filters: IFilter[] | ICompositeFilter,\n actions: IUpdateExpressions,\n options: Partial<IUpdateExpressionsOptions> = {},\n ) {\n let query = `UPDATE ${format.ident(this.dbSchema)}.${format.ident(\n this.tableName,\n )} SET`;\n\n const set = actions.SET || [];\n const add = actions.ADD || [];\n const columns = this.crudSchema.columns;\n\n const setValues = this.replacePathAndValueByAttributeNames(\n set,\n options,\n columns,\n DYNAMO_DB_UPDATE_ACTIONS.SET,\n );\n const addValues = this.replacePathAndValueByAttributeNames(\n add,\n options,\n columns,\n DYNAMO_DB_UPDATE_ACTIONS.ADD,\n );\n\n const setValuesAndAddValues: any = setValues.concat(addValues);\n\n const updateClauses: any = [];\n const jsonSetExpressionGroup: any = {};\n const queryFunctions: any = [];\n\n setValuesAndAddValues.forEach((expression: any) => {\n const { path, value, createNewColumn, actionName, dynamoFuncName } =\n expression;\n\n //Dynamo functions replacement\n if (dynamoFuncName) {\n queryFunctions.push({ path, value, dynamoFuncName });\n }\n\n if (path.includes('.') && !dynamoFuncName) {\n const jsonExpr = this.getJSONBSetExpressionByAction(\n path,\n value,\n {\n createNewColumn,\n actionName,\n },\n );\n const columnName: string = jsonExpr.columnName;\n if (!jsonSetExpressionGroup[columnName]) {\n jsonSetExpressionGroup[columnName] = [jsonExpr];\n } else {\n jsonSetExpressionGroup[columnName].push(jsonExpr);\n }\n } else if (!dynamoFuncName) {\n let expValue;\n const column = this.crudSchema.columns[path];\n if (column?.type == undefined)\n throw `Column type definition for column: (${path}) must be in the CrudSchema`;\n let formattedValue;\n switch (column.type) {\n case 'object':\n {\n const valueSerialized = `${JSON.stringify(\n value,\n ).replace(/'/g, \"''\")}`;\n expValue = `'${valueSerialized}'::jsonb`;\n }\n break;\n case 'array':\n formattedValue = format.literal(value);\n expValue = `ARRAY[${formattedValue}]`;\n break;\n default:\n formattedValue = format.literal(value);\n expValue = formattedValue;\n break;\n }\n this.crudSchema.columns;\n updateClauses.push(`${format.ident(path)} = ${expValue}`);\n }\n });\n\n this.setCommonColumnsQueryFunctions(\n jsonSetExpressionGroup,\n queryFunctions,\n );\n\n if (Object.keys(jsonSetExpressionGroup).length > 0) {\n Object.keys(jsonSetExpressionGroup).forEach((groupIndex) => {\n const jsonSetExpression = this.buildJSONBExpression(\n jsonSetExpressionGroup[groupIndex],\n 'jsonb_set',\n );\n\n updateClauses.push(`${groupIndex} = ${jsonSetExpression}`);\n });\n }\n\n //This is for dynamo functions transformed to postgresql functions\n this.buildUpdateClausesFormDynamoFunctions(\n queryFunctions,\n updateClauses,\n );\n\n query += ` ${updateClauses.join(', ')}`;\n\n query += ' WHERE ';\n query += this.buildFilterClause(filters);\n\n return this.runQuery(query);\n }\n\n private buildUpdateClausesFormDynamoFunctions(\n queryFunctions: any,\n updateClauses: any,\n ) {\n if (queryFunctions.length > 0) {\n queryFunctions.forEach((queryFunction: any) => {\n if (typeof queryFunction.value == 'object') {\n const jsonExpr = this.buildJSONBExpression(\n queryFunction.value.jsonExpression,\n 'jsonb_insert',\n );\n updateClauses.push(\n `${format.ident(queryFunction.path)} = ${jsonExpr}`,\n );\n } else {\n updateClauses.push(\n `${format.ident(queryFunction.path)} = ${\n queryFunction.value\n }`,\n );\n }\n });\n }\n }\n\n private setCommonColumnsQueryFunctions(\n jsonSetExpressionGroup: any,\n queryFunctions: any,\n ) {\n Object.keys(jsonSetExpressionGroup).forEach((jsonSetExpr: any) => {\n queryFunctions.forEach((queryFunction: any, index: number) => {\n const columnPath = `\"${queryFunction.path}\"`;\n if (columnPath === jsonSetExpr) {\n jsonSetExpressionGroup[jsonSetExpr].push({\n ...queryFunction,\n isCommonColumn: true,\n });\n delete queryFunctions[index];\n }\n });\n });\n }\n\n /**\n * @description Builds a jsonb expression like jsonb_insert, or jsonb_set\n * @param jsonSetExpressions\n * @param functionName\n * @returns\n */\n private buildJSONBExpression(\n jsonSetExpressions: any,\n functionName: string,\n ) {\n let jsonSetStringExpr = '';\n jsonSetExpressions.forEach((expression: any, index: number) => {\n let _tempFunctionName = functionName;\n let { columnName, jsonExpr } = expression;\n //Is a common column for dynamoDBFunctions\n if (expression.isCommonColumn) {\n const jsonExpression = expression.value.jsonExpression[0];\n _tempFunctionName = jsonExpression.functionName;\n jsonExpr = jsonExpression.jsonExpr;\n columnName = jsonExpression.columnName;\n }\n if (index === 0) {\n jsonSetStringExpr = `${_tempFunctionName}(${columnName},${jsonExpr})`;\n } else {\n jsonSetStringExpr = `${_tempFunctionName}(${jsonSetStringExpr},${jsonExpr})`;\n }\n });\n return jsonSetStringExpr;\n }\n\n /**\n * @description Serializes a JSON value\n * @param value\n * @returns\n */\n private serializeJSONValue(value: any) {\n const valueSerialized =\n typeof value == 'object'\n ? `${JSON.stringify(value).replace(/'/g, \"''\")}`\n : value;\n return valueSerialized;\n }\n\n private getJSONBSetExpressionByAction(\n path: string,\n value: any,\n options: any,\n ) {\n path = path.replace(/\\[(\\d+)\\]/g, '.$1');\n const pathSplitted = path.split('.');\n const parentPath = pathSplitted[0];\n const { createNewColumn, actionName } = options;\n\n const pathSerialized = pathSplitted.slice(1).join(',');\n const valueSerialized = `'${JSON.stringify(value).replace(\n /'/g,\n \"''\",\n )}'`;\n\n if (actionName == DYNAMO_DB_UPDATE_ACTIONS.ADD) {\n if (typeof value != 'string' && !isNaN(value)) {\n const resultExpr = {\n jsonExpr: `'{${pathSerialized}}',to_jsonb(COALESCE((\"${parentPath}\"#>'{${pathSerialized}}')::numeric,0) + ${valueSerialized})`,\n columnName: `\"${parentPath}\"`,\n };\n return resultExpr;\n }\n }\n return {\n jsonExpr: `'{${pathSerialized}}',${valueSerialized},${createNewColumn}`,\n columnName: `\"${parentPath}\"`,\n };\n }\n\n private getListAppendDefFromValue(queryValue: string, columnType: string) {\n const regexListAppend = /list_append\\(([^)]+)\\)/gm;\n const listAppendString = 'list_append(';\n\n const matchList = queryValue.match(regexListAppend) || [];\n const groupResult = matchList[0];\n\n if (groupResult) {\n const attributesFromGroup = groupResult\n .slice(listAppendString.length, -1)\n .split(',');\n const attributes = {\n originalString: groupResult,\n path: attributesFromGroup[0].trim(),\n value: attributesFromGroup.slice(1).join(',').trim(),\n isDynamoFunction: true,\n functionExpr: '',\n jsonExpression: [{}],\n };\n if (columnType == 'array') {\n attributes['functionExpr'] =\n this.buildArrayAppendExpr(attributes);\n } else {\n attributes['jsonExpression'] =\n this.buildJsonbInsertExpr(attributes);\n }\n return attributes;\n }\n\n return null;\n }\n\n private buildArrayAppendExpr(params: any) {\n const arrayPath = params.path.split('.');\n const columnName = arrayPath.shift();\n return `ARRAY_APPEND(\"${columnName}\",${params.value})`;\n }\n\n private buildJsonbInsertExpr(params: any) {\n const arrayPath = params.path.split('.');\n const columnName = arrayPath.shift();\n const options = {\n isDynamoFunction: params?.isDynamoFunction,\n relativePath:\n arrayPath.length && Array.isArray(arrayPath) ? arrayPath : [],\n };\n const jsonbInsertExpressions =\n this.getExpressionsByDefinitionForJSONBInsert(\n columnName,\n params.value,\n options,\n );\n\n return jsonbInsertExpressions;\n }\n\n private getExpressionsByDefinitionForJSONBInsert(\n columnName: string,\n value: string,\n options: any,\n ) {\n const jsonbInsertExpressions = [];\n let pathToAffect = '0';\n if (options.isDynamoFunction == true) {\n options.relativePath.push('0');\n pathToAffect = options.relativePath.join(',');\n }\n try {\n const parsedValue = JSON.parse(value);\n\n if (Array.isArray(parsedValue)) {\n parsedValue.forEach((arrayValue) => {\n arrayValue =\n typeof arrayValue == 'string'\n ? `\"${arrayValue}\"`\n : arrayValue;\n jsonbInsertExpressions.push({\n jsonExpr: `'{${pathToAffect}}','${this.serializeJSONValue(\n arrayValue,\n )}'`,\n columnName: `\"${columnName}\"`,\n functionName: 'jsonb_insert',\n });\n });\n } else {\n jsonbInsertExpressions.push({\n jsonExpr: `'{${pathToAffect}}','${this.serializeJSONValue(\n parsedValue,\n )}'`,\n columnName: `\"${columnName}\"`,\n functionName: 'jsonb_insert',\n });\n }\n } catch (error) {\n jsonbInsertExpressions.push({\n jsonExpr: `'{${pathToAffect}}','${value}'`,\n columnName: `\"${columnName}\"`,\n functionName: 'jsonb_insert',\n });\n }\n return jsonbInsertExpressions;\n }\n\n private getInsertExprFromJsonbDef(queryValue: string, columnType: string) {\n const listAppendParams = this.getListAppendDefFromValue(\n queryValue,\n columnType,\n );\n if (\n listAppendParams != null &&\n listAppendParams?.jsonExpression.length === 0\n ) {\n queryValue = queryValue.replace(\n listAppendParams.originalString,\n listAppendParams.functionExpr,\n );\n } else {\n return listAppendParams;\n }\n\n return queryValue;\n }\n\n private replacePathAndValueByAttributeNames(\n actions: any[],\n options: IUpdateExpressionsOptions,\n columns: any,\n actionName: string,\n ) {\n return actions.map((action) => {\n action.path = this.replaceExpressionAttributeNames(\n action.path,\n options,\n );\n if (\n typeof action.value == 'string' &&\n action.value.includes('list_append')\n ) {\n action.path = action.path.split('.')[0];\n const column = columns[action.path];\n action.value =\n this.replaceExpressionAttributeValuesForDynamoFunctions(\n action.value,\n options,\n );\n action.value = this.getInsertExprFromJsonbDef(\n action.value,\n column.type,\n );\n action.dynamoFuncName = 'list_append';\n } else {\n action.value = this.replaceExpressionAttributeValues(\n action.value,\n options,\n );\n }\n\n action.actionName = actionName;\n action.createNewColumn = true;\n return action;\n });\n }\n\n private replaceExpressionAttributeValuesForDynamoFunctions(\n value: string,\n options: any,\n ) {\n const { expressionAttributeNames, expressionAttributeValues } = options;\n const exprAttributeNamesKeys = expressionAttributeNames\n ? Object.keys(expressionAttributeNames)\n : [];\n const exprAttributeValuesKeys = expressionAttributeValues\n ? Object.keys(expressionAttributeValues)\n : [];\n\n //Set for attribute names\n if (exprAttributeNamesKeys.length > 0) {\n exprAttributeNamesKeys.forEach((exprAttribute) => {\n value = value.replace(\n exprAttribute,\n expressionAttributeNames[exprAttribute],\n );\n });\n }\n\n //Set for attribute values\n if (exprAttributeValuesKeys.length > 0) {\n exprAttributeValuesKeys.forEach((exprAttribute) => {\n const valueSerialized = this.serializeJSONValue(\n expressionAttributeValues[exprAttribute],\n );\n value = value.replace(exprAttribute, `${valueSerialized}`);\n });\n }\n return value;\n }\n\n private replaceExpressionAttributeNames(\n path: string,\n options: IUpdateExpressionsOptions,\n ) {\n const { expressionAttributeNames } = options;\n\n if (expressionAttributeNames) {\n Object.keys(expressionAttributeNames).forEach(\n (attributeName: string) => {\n const attributeNameValue: string =\n expressionAttributeNames[attributeName];\n path = path.replace(attributeName, attributeNameValue);\n },\n );\n }\n return path;\n }\n\n private replaceExpressionAttributeValues(\n value: string,\n options: IUpdateExpressionsOptions,\n ) {\n const { expressionAttributeValues } = options;\n if (expressionAttributeValues[value] != undefined) {\n return expressionAttributeValues[value];\n }\n\n return value;\n }\n\n private getValueTypeAsPostgresDefinition(value: any) {\n switch (typeof value) {\n case 'number':\n return 'number';\n case 'boolean':\n return 'boolean';\n case 'string':\n default:\n return 'text';\n }\n }\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport PostgresqlClientService from './postgreSqlClient.service';\nimport {\n ICompositeFilter,\n ICreateMultipleResponse,\n ICrudService,\n IFilter,\n IFindOptions,\n IFindResult,\n IRemoveOptions,\n IUpdateExpressions,\n IUpdateExpressionsOptions,\n} from '../../../interfaces';\nimport { CrudSchema } from '../../../schemas';\nimport { findIdColumnName } from '../../../helpers/tableHelper';\nimport { AGGREGATE_FUNCTIONS } from '../../../utils/constants';\nimport { buildAggFunctionAlias } from '../../../helpers/queryHelpers';\nimport { PersistenceErrorWrapper } from '../../../helpers/errorHelper';\nimport { DbPool } from '../../../types';\nexport class PostgreSqlCrudService<T>\n extends PostgresqlClientService<T>\n implements ICrudService<T>\n{\n constructor(\n private tableSchema: typeof CrudSchema,\n poolClient?: DbPool,\n ) {\n super(tableSchema, poolClient);\n }\n\n private get idColumnName(): string | undefined {\n return findIdColumnName(this.tableSchema.columns);\n }\n\n normalizeInputData(inputData: any) {\n inputData.qvAttributes = {};\n for (const key in inputData) {\n if (!this.tableSchema.columns[key] && key !== 'qvAttributes') {\n inputData.qvAttributes[key] = inputData[key];\n delete inputData[key];\n } else if (\n Array.isArray(inputData[key]) &&\n this.tableSchema.columns[key]?.type !== 'array'\n ) {\n inputData[key] = JSON.stringify(inputData[key]);\n }\n }\n }\n\n getItem(data: { [key: string]: any }): any {\n const schemaColumns = Object.entries(this.tableSchema.columns);\n schemaColumns.forEach(([key, value]) => {\n if (value.type === 'big_number') {\n if (data[key]) data[key] = Number(data[key]);\n }\n });\n const resultItem = { ...data, ...data.qvAttributes };\n delete resultItem['qvAttributes'];\n return resultItem;\n }\n\n prepareData(data: T): any {\n const inputData = { ...data } as { [key: string]: any };\n this.normalizeInputData(inputData);\n return inputData;\n }\n\n buildCreateResponseBatch(result: any): ICreateMultipleResponse {\n const rows = Array.isArray(result?.rows) ? result.rows : [];\n return {\n items: rows.map((r: any) => this.getItem(r)),\n unprocessedItems: [],\n };\n }\n\n create(data: T | T[]): Promise<T | ICreateMultipleResponse> {\n if (Array.isArray(data)) {\n const inputDataArray = data.map((item) => this.prepareData(item));\n return this.createCommand(inputDataArray).then((result) => {\n return this.buildCreateResponseBatch(result);\n });\n } else {\n const inputData = this.prepareData(data);\n return this.createCommand([inputData]).then((result) =>\n result.rowCount ? this.getItem(result.rows[0]) : null,\n );\n }\n }\n\n findItem(findOptions: IFindOptions): Promise<T | null> {\n return this.findCommand(findOptions).then((data) => {\n return data?.length\n ? this.getItem(data[0] as { [key: string]: any })\n : null;\n });\n }\n\n private async processQueryResult(\n findOptions: IFindOptions,\n omitPagination: boolean = false,\n ): Promise<IFindResult<T>> {\n const rows = await this.findCommand(findOptions);\n const items = rows.map((row) =>\n this.getItem(row as { [key: string]: any }),\n );\n\n const { limit, from } = findOptions?.pagination || {};\n const hasMoreRecords = items.length && items.length === limit;\n const newFrom = limit && hasMoreRecords ? limit + (from || 0) : null;\n\n const result: IFindResult<T> = {\n items,\n pagination: omitPagination ? null : { limit: limit, from: newFrom },\n count: items.length,\n };\n return result;\n }\n\n async find(findOptions: IFindOptions): Promise<IFindResult<T>> {\n return this.processQueryResult(findOptions);\n }\n\n async findAll(findOptions: IFindOptions): Promise<IFindResult<T>> {\n return this.processQueryResult(findOptions, true);\n }\n\n async findCount(findOptions: IFindOptions): Promise<number> {\n const items = await this.findCommand({\n ...findOptions,\n aggregateFunction: AGGREGATE_FUNCTIONS.COUNT,\n });\n\n const aggFunctionProperty = buildAggFunctionAlias(\n AGGREGATE_FUNCTIONS.COUNT,\n );\n const item: any = items.length ? items[0] : {};\n return item[aggFunctionProperty] || 0;\n }\n\n async update(\n filters: IFilter[] | ICompositeFilter,\n data: Partial<T>,\n ): Promise<any> {\n const savedRecord = await this.findItem({ filters });\n\n const inputData: any = {\n ...savedRecord,\n ...data,\n } as {\n [key: string]: any;\n };\n\n await this.updateCommand(filters, this.prepareData(inputData));\n return this.getItem(inputData);\n }\n\n async remove(\n filters: IFilter[] | ICompositeFilter | IFilter[][],\n options: IRemoveOptions,\n ): Promise<void> {\n await this.deleteCommand(filters, options?.filterGroups);\n }\n\n runQuery(querySentence: string, values?: any[]) {\n return super.runQuery(querySentence, values);\n }\n\n async updateExpressions(\n filters: IFilter[] | ICompositeFilter,\n actions: IUpdateExpressions,\n options: IUpdateExpressionsOptions,\n ): Promise<any> {\n const result = await this.updateExpressionCommand(\n filters,\n actions,\n options,\n );\n return PersistenceErrorWrapper(result);\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n runRawQuery(query: string, params: any[]): Promise<any> {\n throw super.runQuery(query, params);\n }\n}\n"]}
|
package/dist/types/index.d.ts
CHANGED
|
@@ -178,4 +178,4 @@ declare function buildSort(column: string, direction?: string): ISorting;
|
|
|
178
178
|
|
|
179
179
|
declare function getDbPool(poolConfig?: PoolConfig): Pool | undefined;
|
|
180
180
|
|
|
181
|
-
export { AggregateFunction, CrudSchema, CrudService, FilterInput, ICrudService, IFilter, IFindOptions, IFindPagination, ISorting, SortDirection, buildFilter, buildQueryIndex, buildSort, getDbPool };
|
|
181
|
+
export { type AggregateFunction, CrudSchema, CrudService, type FilterInput, type ICrudService, type IFilter, type IFindOptions, type IFindPagination, type ISorting, type SortDirection, buildFilter, buildQueryIndex, buildSort, getDbPool };
|
package/package.json
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
"name": "@qrvey/data-persistence",
|
|
3
3
|
"types": "dist/types/index.d.ts",
|
|
4
4
|
"main": "dist/cjs/index.js",
|
|
5
|
-
"version": "0.5.
|
|
5
|
+
"version": "0.5.8",
|
|
6
6
|
"license": "MIT",
|
|
7
7
|
"exports": {
|
|
8
8
|
".": {
|
|
@@ -32,7 +32,7 @@
|
|
|
32
32
|
"peerDependencies": {
|
|
33
33
|
"@aws-sdk/client-dynamodb": "3.x",
|
|
34
34
|
"@aws-sdk/lib-dynamodb": "3.x",
|
|
35
|
-
"pg": "8.
|
|
35
|
+
"pg": "8.x",
|
|
36
36
|
"pg-format": "1.0.4"
|
|
37
37
|
},
|
|
38
38
|
"peerDependenciesMeta": {
|
|
@@ -50,16 +50,16 @@
|
|
|
50
50
|
}
|
|
51
51
|
},
|
|
52
52
|
"devDependencies": {
|
|
53
|
-
"@types/jest": "
|
|
54
|
-
"@types/pg": "8.
|
|
53
|
+
"@types/jest": "30.0.0",
|
|
54
|
+
"@types/pg": "8.15.4",
|
|
55
55
|
"@types/pg-format": "1.0.5",
|
|
56
56
|
"auto-version-js": "0.3.10",
|
|
57
57
|
"eslint-config-custom": "*",
|
|
58
|
-
"jest": "
|
|
59
|
-
"ts-jest": "29.
|
|
58
|
+
"jest": "30.0.2",
|
|
59
|
+
"ts-jest": "29.4.0",
|
|
60
60
|
"tsconfig": "*",
|
|
61
|
-
"tsup": "
|
|
62
|
-
"typescript": "5.
|
|
61
|
+
"tsup": "8.5.0",
|
|
62
|
+
"typescript": "5.8.3"
|
|
63
63
|
},
|
|
64
64
|
"publishConfig": {
|
|
65
65
|
"access": "public"
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/utils/constants.ts"],"names":["CONNECTION_CLOSING_MODES","FILTER_LOGIC_OPERATORS"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAO,IAAM,sBAAiD;AAAA,EAC1D,UAAU;AAAA,EACV,cAAc;AAAA,EACd,OAAO;AAAA,EACP,aAAa;AAAA,EACb,WAAW;AAAA,EACX,IAAI;AAAA,EACJ,cAAc;AAAA,EACd,IAAI;AAAA,EACJ,oBAAoB;AAAA,EACpB,KAAK;AAAA,EACL,WAAW;AAAA,EACX,IAAI;AAAA,EACJ,iBAAiB;AAAA,EACjB,KAAK;AAAA,EACL,OAAO;AAAA,EACP,WAAW;AAAA,EACX,SAAS;AACb;AAEO,IAAM,qBAAgD;AAAA,EACzD,OAAO;AACX;AAOO,IAAK,2BAAL,kBAAKA,8BAAL;AACH,EAAAA,0BAAA,UAAO;AACP,EAAAA,0BAAA,YAAS;AAFD,SAAAA;AAAA,GAAA;AAKL,IAAK,yBAAL,kBAAKC,4BAAL;AACH,EAAAA,wBAAA,SAAM;AACN,EAAAA,wBAAA,QAAK;AAFG,SAAAA;AAAA,GAAA;AAqBL,IAAM,+BAA+B;AAAA,EACxC,OAAO;AAAA,EACP,WAAW;AAAA,EACX,cAAc;AAAA,EACd,IAAI;AAAA,EACJ,KAAK;AAAA,EACL,oBAAoB;AAAA,EACpB,KAAK;AAAA,EACL,iBAAiB;AAAA,EACjB,WAAW;AAAA,EACX,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,aAAa;AAAA,EACb,UAAU;AAAA,EACV,cAAc;AAAA,EACd,SAAS;AAAA,EACT,OAAO;AAAA,EACP,WAAW;AACf;AAEO,IAAM,oBAAoB;AAM1B,IAAM,2BAAsD;AAAA,EAC/D,KAAK;AAAA,EACL,KAAK;AAAA,EACL,QAAQ;AAAA,EACR,QAAQ;AACZ;AAEO,SAAS,sBAAsB;AAxFtC;AAyFI,WAAO,aAAQ,IAAI,kBAAZ,mBAA2B,mBAAkB;AACxD","sourcesContent":["export const FILTER_OPERATOR_MAP: { [key: string]: string } = {\n CONTAINS: 'contains',\n NOT_CONTAINS: 'notContains',\n EQUAL: 'eq',\n STARTS_WITH: 'beginsWith',\n NOT_EQUAL: 'notEq',\n IN: 'in',\n GREATER_THAN: 'gt',\n GT: 'gt',\n GREATER_THAN_EQUAL: 'gte',\n GTE: 'gte',\n LESS_THAN: 'lt',\n LT: 'lt',\n LESS_THAN_EQUAL: 'lte',\n LTE: 'lte',\n EXIST: 'attribute_exists',\n NOT_EXIST: 'attribute_not_exists',\n BETWEEN: 'between',\n};\n\nexport const DYNAMODB_OPERATORS: { [key: string]: string } = {\n EQUAL: 'EQUAL',\n};\n\nexport enum SORT_DIRECTIONS {\n ASC = 'ASC',\n DESC = 'DESC',\n}\n\nexport enum CONNECTION_CLOSING_MODES {\n AUTO = 'AUTO',\n MANUAL = 'MANUAL',\n}\n\nexport enum FILTER_LOGIC_OPERATORS {\n AND = 'AND',\n OR = 'OR',\n}\n\nexport enum FilterOperator {\n EQUAL = 'EQUAL',\n NOT_EQUAL = 'NOT_EQUAL',\n CONTAINS = 'CONTAINS',\n GREATER_THAN = 'GREATER_THAN',\n GREATER_THAN_EQUAL = 'GREATER_THAN_EQUAL',\n LESS_THAN = 'LESS_THAN',\n LESS_THAN_EQUAL = 'LESS_THAN_EQUAL',\n IN = 'IN',\n STARTS_WITH = 'STARTS_WITH',\n NOT_CONTAINS = 'NOT_CONTAINS',\n BETWEEN = 'BETWEEN',\n EXIST = 'EXIST',\n NOT_EXIST = 'NOT_EXIST',\n}\n\nexport const POSTGRES_FILTER_OPERATOR_MAP = {\n EQUAL: '=',\n NOT_EQUAL: '<>',\n GREATER_THAN: '>',\n GT: '>',\n GTE: '>=',\n GREATER_THAN_EQUAL: '>=',\n LTE: '<=',\n LESS_THAN_EQUAL: '<=',\n LESS_THAN: '<',\n LT: '<',\n IN: 'IN',\n STARTS_WITH: 'LIKE',\n CONTAINS: 'LIKE',\n NOT_CONTAINS: 'NOT LIKE',\n BETWEEN: 'BETWEEN',\n EXIST: 'IS NOT NULL',\n NOT_EXIST: 'IS NULL',\n};\n\nexport const DEFAULT_PG_SCHEMA = 'public';\n\nexport enum AGGREGATE_FUNCTIONS {\n COUNT = 'COUNT',\n}\n\nexport const DYNAMO_DB_UPDATE_ACTIONS: { [key: string]: string } = {\n SET: 'SET',\n ADD: 'ADD',\n DELETE: 'DELETE',\n REMOVE: 'REMOVE',\n};\n\nexport function isMultiPlatformMode() {\n return process.env.PLATFORM_TYPE?.toLowerCase() === 'container';\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/helpers/tableHelper.ts","../../src/helpers/queryHelpers.ts","../../src/error/NoRecordsAffectedException.ts","../../src/helpers/errorHelper.ts"],"names":[],"mappings":";AAEO,SAAS,oBAAoB,SAAkC;AAClE,SAAO,OAAO,KAAK,OAAO;AAC9B;AAEO,SAAS,iBAAiB,SAA4C;AACzE,SAAO,oBAAoB,OAAO,EAAE;AAAA,IAChC,CAAC,eAAe,QAAQ,UAAU,EAAE,aAAa;AAAA,EACrD;AACJ;AAEO,SAAS,aACZ,OACA,WAAW,QACL;AACN,MAAI,CAAC;AAAO,UAAM,IAAI,MAAM,wBAAwB;AAEpD,MAAI,OAAO,UAAU;AAAU,WAAO;AAEtC,QAAM,EAAE,MAAM,MAAM,IAAI;AACxB,SAAO,aAAa,WAAW,QAAQ,QAAQ;AACnD;AAEO,SAAS,qBAAqB,SAAkC;AACnE,SAAO,oBAAoB,OAAO,EAAE;AAAA,IAChC,CAAC,eAAe,QAAQ,UAAU,EAAE,YAAY;AAAA,EACpD;AACJ;;;ACpBO,SAAS,sBACZ,mBACM;AACN,SAAO,UAAU,iBAAiB;AACtC;;;ACZO,IAAM,6BAAN,cAAyC,MAAM;AAAA,EAClD,cAAc;AACV,UAAM,+BAA+B;AACrC,SAAK,OAAO;AAAA,EAChB;AACJ;;;ACHO,SAAS,wBAAwB,aAAkB;AACtD,QAAM,oCAAoC;AAAA,IACtC;AAAA,EACJ;AAEA,MAAI,uBAAuB,OAAO;AAE9B,QACI,YAAY,QACZ,kCAAkC,SAAS,YAAY,IAAI,GAC7D;AACE,YAAM,IAAI,2BAA2B;AAAA,IACzC,OAAO;AACH,YAAM;AAAA,IACV;AAAA,EACJ,OAAO;AAEH,QAAI,YAAY,aAAa,GAAG;AAC5B,YAAM,IAAI,2BAA2B;AAAA,IACzC;AAAA,EACJ;AAEA,SAAO;AACX","sourcesContent":["import { ITableColumns, ITableName } from '../interfaces';\n\nexport function getTableColumnNames(columns: ITableColumns): string[] {\n return Object.keys(columns);\n}\n\nexport function findIdColumnName(columns: ITableColumns): string | undefined {\n return getTableColumnNames(columns).find(\n (columnName) => columns[columnName].columnId === true,\n );\n}\n\nexport function getTableName(\n table: string | ITableName,\n property = 'name',\n): string {\n if (!table) throw new Error('missing table property');\n\n if (typeof table === 'string') return table;\n\n const { name, alias } = table;\n return property === 'alias' && alias ? alias : name;\n}\n\nexport function getPrimaryKeyColumns(columns: ITableColumns): string[] {\n return getTableColumnNames(columns).filter(\n (columnName) => columns[columnName].primary === true,\n );\n}\n","import { AggregateFunction } from '../types';\n\nexport enum METHOD_TO_QUERY {\n where = 'where',\n filter = 'filter',\n update = 'update',\n}\n\nexport function buildAggFunctionAlias(\n aggregateFunction: AggregateFunction,\n): string {\n return `AGG_FN_${aggregateFunction}`;\n}\n","export class NoRecordsAffectedException extends Error {\n constructor() {\n super('No records affected by update');\n this.name = 'NoRecordsAffectedException';\n }\n}\n","import { NoRecordsAffectedException } from '../error/NoRecordsAffectedException';\n\nexport function PersistenceErrorWrapper(queryResult: any) {\n const dynamoNoRecordsAffectedExceptions = [\n 'ConditionalCheckFailedException',\n ];\n\n if (queryResult instanceof Error) {\n //Checks for dynamodb errors also the ones that is included in NoRecordsAffectedExceptions list\n if (\n queryResult.name &&\n dynamoNoRecordsAffectedExceptions.includes(queryResult.name)\n ) {\n throw new NoRecordsAffectedException();\n } else {\n throw queryResult;\n }\n } else {\n //This is for Postgres scenario, where there is not error launched by updates\n if (queryResult.rowCount === 0) {\n throw new NoRecordsAffectedException();\n }\n }\n\n return queryResult;\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/services/cruds/dynamodb/dynamoDbClient.service.ts","../../src/services/cruds/dynamodb/queryBuilderCondition.service.ts","../../src/services/cruds/dynamodb/queryBuilder.service.ts","../../src/services/cruds/dynamodb/dynamoDbCrud.service.ts"],"names":["_a","_b"],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { DynamoDBClient } from '@aws-sdk/client-dynamodb';\nimport {\n DynamoDBDocumentClient,\n GetCommand,\n QueryCommand,\n PutCommand,\n UpdateCommand,\n DeleteCommand,\n GetCommandInput,\n QueryCommandInput,\n PutCommandInput,\n UpdateCommandInput,\n DeleteCommandInput,\n QueryCommandOutput,\n ScanCommandInput,\n ScanCommand,\n BatchWriteCommandInput,\n BatchWriteCommand,\n} from '@aws-sdk/lib-dynamodb';\nimport { IFilter } from '../../../interfaces';\n\nconst AWS_REGION = process.env.AWS_DEFAULT_REGION;\n\n/**\n * Ref:\n * - https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/DynamoDB/DocumentClient.html\n * - https://www.fernandomc.com/posts/eight-examples-of-fetching-data-from-dynamodb-with-node/\n */\nexport default class DynamoDbClientService {\n private tableName: string;\n protected dynamoDBClient: DynamoDBDocumentClient;\n\n constructor(tableName: string) {\n if (!tableName)\n throw new Error(\n 'The \"tableName\" is required to use a DynamoDbClientService.',\n );\n this.tableName = tableName;\n const client = new DynamoDBClient({ region: AWS_REGION });\n this.dynamoDBClient = DynamoDBDocumentClient.from(client, {\n marshallOptions: {\n removeUndefinedValues: true,\n },\n });\n }\n\n /**\n * Get an item by key\n * @param {Object} keyObject - Ex: { jobId: 1234 }\n * @param {GetCommandInput} options\n */\n public async getByKey(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n keyObject: Record<string, any>,\n options: Partial<GetCommandInput> = {},\n ) {\n const params: GetCommandInput = {\n TableName: this.tableName,\n Key: keyObject,\n ...options,\n };\n const result = await this.dynamoDBClient.send(new GetCommand(params));\n return result.Item;\n }\n\n /**\n * Query a table\n * @param {QueryCommandInput} options\n */\n public async query(\n options: Omit<QueryCommandInput, 'TableName'> = {},\n ): Promise<Omit<QueryCommandOutput, '$metadata'>> {\n const params: QueryCommandInput = {\n TableName: this.tableName,\n ...options,\n };\n const result: Partial<QueryCommandOutput> =\n await this.dynamoDBClient.send(new QueryCommand(params));\n\n if (result.$metadata) delete result.$metadata;\n return result;\n }\n\n /**\n * Scan a table\n * @param {ScanInput} options\n */\n public async scan(\n input: ScanCommandInput,\n ): Promise<Omit<QueryCommandOutput, '$metadata'>> {\n const params: ScanCommandInput = {\n ...input,\n TableName: this.tableName,\n };\n\n const command = new ScanCommand(params);\n const response: Partial<QueryCommandOutput> =\n await this.dynamoDBClient.send(command);\n if (response.$metadata) delete response.$metadata;\n return response;\n }\n\n /**\n * Create/Replace a item object\n * To take care:\n * - https://stackoverflow.com/questions/43667229/difference-between-dynamodb-putitem-vs-updateitem\n * @param {Object} input\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n public async put(input: Record<string, any>) {\n const params: PutCommandInput = {\n TableName: this.tableName,\n Item: input,\n ReturnValues: 'NONE',\n };\n return await this.dynamoDBClient.send(new PutCommand(params));\n }\n\n /**\n * Update a item object\n * To take care:\n * - https://stackoverflow.com/questions/43667229/difference-between-dynamodb-putitem-vs-updateitem\n * @param {Object} keyObject - Ex: { jobId: 1234 }\n * @param {UpdateCommandInput} updateObject\n */\n public async update(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n keyObject: Record<string, any>,\n options: Partial<UpdateCommandInput> = {},\n ) {\n const params: UpdateCommandInput = {\n TableName: this.tableName,\n Key: keyObject,\n ReturnValues: 'NONE',\n ...options,\n };\n return await this.dynamoDBClient.send(new UpdateCommand(params));\n }\n\n /**\n * Delete/Remove an item object\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n public async remove(keyObject: Record<string, any>) {\n const params: DeleteCommandInput = {\n TableName: this.tableName,\n Key: keyObject,\n ReturnValues: 'NONE',\n };\n return await this.dynamoDBClient.send(new DeleteCommand(params));\n }\n\n public batchWrittenPut(data: Record<string, any>) {\n const putRequests = data.map((item: any) => ({\n PutRequest: {\n Item: item,\n },\n }));\n const params = {\n RequestItems: {\n [this.tableName]: putRequests,\n },\n } as BatchWriteCommandInput;\n const insertCommand = new BatchWriteCommand(params);\n return this.dynamoDBClient.send(insertCommand);\n }\n\n private buildDeleteRequestKeys(filters: IFilter[]) {\n const deleteRequestKeys: any = {};\n filters.forEach((filter) => {\n deleteRequestKeys[filter.attribute] = filter.value;\n });\n return deleteRequestKeys;\n }\n\n async batchRemove(filterGroups: IFilter[][]): Promise<void> {\n if (!filterGroups?.length) return;\n\n const deleteRequests = filterGroups.map((filterGroup: IFilter[]) => ({\n DeleteRequest: {\n Key: this.buildDeleteRequestKeys(filterGroup),\n },\n }));\n\n const params = {\n RequestItems: {\n [this.tableName]: deleteRequests,\n },\n } as BatchWriteCommandInput;\n\n await this.dynamoDBClient.send(new BatchWriteCommand(params));\n }\n\n public async updateExpressions(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n keyObject: Record<string, any>,\n options: Partial<UpdateCommandInput> = {},\n ) {\n const params: UpdateCommandInput = {\n TableName: this.tableName,\n Key: keyObject,\n ...options,\n };\n\n return await this.dynamoDBClient.send(new UpdateCommand(params));\n }\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { QueryCommandInput } from '@aws-sdk/client-dynamodb';\nimport { UpdateCommandInput } from '@aws-sdk/lib-dynamodb';\nimport { IQueryBuilder } from '../../../interfaces/queryBuilder.interface';\nimport { METHOD_TO_QUERY } from '../../../helpers/queryHelpers';\nimport { IQueryBuilderCondition } from '../../../interfaces/queryBuilderCondition.interface';\n\nexport default class QueryBuilderConditionService\n implements IQueryBuilderCondition\n{\n private query;\n private command: Pick<\n QueryCommandInput,\n | 'FilterExpression'\n | 'KeyConditionExpression'\n | 'ExpressionAttributeNames'\n | 'ExpressionAttributeValues'\n > &\n Pick<UpdateCommandInput, 'UpdateExpression'>;\n private queryFrom: METHOD_TO_QUERY | undefined;\n private tempKey: string = '';\n private tempLogicOperator: string | null = null;\n private config: any;\n private wheres: string[] = [];\n private filters: string[] = [];\n private updates: string[] = [];\n private attributeNames: Record<string, string> = {};\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n private attributeValues: Record<string, any> = {};\n\n constructor(query: IQueryBuilder) {\n this.query = query;\n this.command = {};\n }\n\n public get() {\n this.build();\n return this.command;\n }\n\n public setKey(key: string) {\n this.tempKey = key;\n return this;\n }\n setTmpLogicOp(logicOp: string) {\n this.tempLogicOperator = logicOp;\n return this;\n }\n\n setConfig(config: any) {\n this.config = config;\n return this;\n }\n\n public from(methodName: METHOD_TO_QUERY) {\n this.queryFrom = methodName;\n return this;\n }\n\n eq(keyValue: string) {\n const { key, value } = this.generateKeyValue(keyValue);\n let expression: any = `${key} = ${value}`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n notEq(keyValue: string) {\n const { key, value } = this.generateKeyValue(keyValue);\n let expression: any = `${key} <> ${value}`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n contains(keyValue: string) {\n const { key, value } = this.generateKeyValue(keyValue);\n let expression: any = `contains(${key}, ${value})`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n notContains(keyValue: string) {\n const { key, value } = this.generateKeyValue(keyValue);\n let expression: any = `NOT contains(${key}, ${value})`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n in(keyValue: any) {\n const keyValues = Array.isArray(keyValue) ? keyValue : [keyValue];\n const { key, value } = this.generateKeyValue(keyValues);\n let expression: any = `${key} IN (${value})`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n beginsWith(keyValue: string) {\n const { key, value } = this.generateKeyValue(keyValue);\n let expression: any = `begins_with(${key}, ${value})`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n project(keyValue: string): string {\n const key = `#${keyValue}`;\n this.attributeNames[key] = keyValue;\n return key;\n }\n\n gt(keyValue: any) {\n const { key, value } = this.generateKeyValue(keyValue);\n let expression: any = `${key} > ${value}`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n gte(keyValue: any) {\n const { key, value } = this.generateKeyValue(keyValue);\n let expression: any = `${key} >= ${value}`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n lte(keyValue: any) {\n const { key, value } = this.generateKeyValue(keyValue);\n let expression: any = `${key} <= ${value}`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n lt(keyValue: any) {\n const { key, value } = this.generateKeyValue(keyValue);\n let expression: any = `${key} < ${value}`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n attribute_exists(keyValue: string) {\n const { key } = this.generateKeyValue(keyValue, null, true);\n let expression: any = `attribute_exists(${key})`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n attribute_not_exists(keyValue: string) {\n const { key } = this.generateKeyValue(keyValue, null, true);\n let expression: any = `attribute_not_exists(${key})`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n between(keyValues: any) {\n const isValidValues =\n Array.isArray(keyValues) && keyValues?.length === 2;\n if (!isValidValues)\n throw new Error(\n 'The value for between filter operator should be an Array with 2 values.',\n );\n\n const { key, value } = this.generateKeyValue(keyValues, ' AND');\n let expression: any = `${key} between ${value}`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n private setExpression(expression: string): void {\n switch (this.queryFrom) {\n case METHOD_TO_QUERY.filter:\n this.filters.push(expression);\n break;\n case METHOD_TO_QUERY.update:\n this.updates.push(expression);\n break;\n default:\n this.wheres.push(expression);\n break;\n }\n }\n\n private generateKeyValue(\n value: string[] | string,\n separatorCharacter: string | null = ',',\n omitAttributeValues: boolean = false,\n ): {\n key: string;\n value: string;\n } {\n const keyExpression = `#${this.tempKey}1`;\n\n this.attributeNames[keyExpression] = this.tempKey;\n\n if (Array.isArray(value)) {\n const valueExpressions = value.map((val, index) => {\n let valueExpression = `:${this.tempKey}${index + 1}1`;\n for (const [i] of Object.entries(this.attributeValues)) {\n if (i === valueExpression) valueExpression += '1';\n }\n this.attributeValues[valueExpression] = val;\n return valueExpression;\n });\n return {\n key: keyExpression,\n value: valueExpressions.join(`${separatorCharacter} `),\n };\n } else {\n let valueExpression = `:${this.tempKey}1`;\n if (valueExpression in this.attributeValues) {\n for (const [index] of Object.entries(this.attributeValues)) {\n if (index === valueExpression) valueExpression += '1';\n }\n }\n if (!omitAttributeValues)\n this.attributeValues[valueExpression] = value;\n return { key: keyExpression, value: valueExpression };\n }\n }\n\n private build(): void {\n if (this.wheres.length > 0) {\n const keyConditionExpression = this.wheres.join(' AND ');\n this.command['KeyConditionExpression'] = keyConditionExpression;\n }\n if (this.filters.length > 0) {\n let filterExpression = '';\n\n this.filters?.forEach((filter: any, index) => {\n if (filter?.logicOperator) {\n if (filter?.config?.openExpression) {\n filterExpression = filterExpression.replace(/\\s+(AND|OR)\\s*$/, ` ${filter.config.parentKey} (`);\n if (filterExpression === '') filterExpression += '('\n filterExpression += `${filter.expression} ${filter.logicOperator} `;\n } else if (filter?.config?.closeExpression) {\n filterExpression += `${filter.expression}) ${filter.config.parentKey} `; \n } else {\n filterExpression += `${filter.expression} ${filter.logicOperator} `;\n }\n }\n });\n filterExpression = filterExpression.replace(/\\s+(AND|OR)\\s*$/, '');\n this.command['FilterExpression'] = filterExpression;\n }\n if (this.updates.length > 0) {\n const filterExpression = this.updates.join(', ');\n this.command['UpdateExpression'] = `SET ${filterExpression}`;\n }\n if (Object.values(this.attributeNames).length > 0)\n this.command['ExpressionAttributeNames'] = this.attributeNames;\n\n if (Object.values(this.attributeValues).length > 0)\n this.command['ExpressionAttributeValues'] = this.attributeValues;\n }\n}\n","import { QueryCommandInput, ScanCommandInput } from '@aws-sdk/client-dynamodb';\nimport { IQueryBuilderCondition } from '../../../interfaces/queryBuilderCondition.interface';\nimport QueryBuilderConditionService from './queryBuilderCondition.service';\nimport { METHOD_TO_QUERY } from '../../../helpers/queryHelpers';\nimport { IQueryBuilder } from '../../../interfaces/queryBuilder.interface';\nimport { AGGREGATE_FUNCTIONS } from '../../../utils/constants';\n\nexport default class QueryBuilderService implements IQueryBuilder {\n private command: Omit<QueryCommandInput & ScanCommandInput, 'TableName'>;\n private condition: IQueryBuilderCondition;\n\n constructor(private useScan = false) {\n this.command = {};\n\n this.condition = new QueryBuilderConditionService(this);\n }\n\n get() {\n const condition = this.condition.get();\n return { ...this.command, ...condition };\n }\n\n limit(num: number): IQueryBuilder {\n this.command.Limit = num;\n return this;\n }\n\n usingIndex(indexName: string): IQueryBuilder {\n this.command.IndexName = indexName;\n return this;\n }\n\n ascending(): IQueryBuilder {\n if (!this.useScan) this.command.ScanIndexForward = true;\n return this;\n }\n\n descending(): IQueryBuilder {\n if (!this.useScan) this.command.ScanIndexForward = false;\n return this;\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n startKey(lastEvaluatedKey: Record<string, any>): IQueryBuilder {\n this.command.ExclusiveStartKey = lastEvaluatedKey;\n return this;\n }\n\n projection(fields: string[] = []) {\n if (!fields.length) return this;\n\n const expression: string[] = [];\n fields.forEach((field) => {\n const key = this.condition.project(field);\n expression.push(key);\n });\n this.command.ProjectionExpression = expression.join(',');\n return this;\n }\n\n where(keyName: string): IQueryBuilderCondition {\n this.condition\n .setKey(keyName)\n .setTmpLogicOp(null)\n .from(METHOD_TO_QUERY.where);\n return this.condition;\n }\n\n filter(\n keyName: string,\n logicOperator: string = 'AND',\n config?: any\n ): IQueryBuilderCondition {\n this.condition\n .setKey(keyName)\n .setTmpLogicOp(logicOperator)\n .setConfig(config)\n .from(METHOD_TO_QUERY.filter);\n return this.condition;\n }\n\n update(attribute: Record<string, string>): IQueryBuilder {\n for (const [key, value] of Object.entries(attribute)) {\n this.condition.setKey(key).from(METHOD_TO_QUERY.update);\n this.condition.eq(value);\n }\n return this;\n }\n\n consistentRead(consistentRead: boolean): IQueryBuilder {\n this.command.ConsistentRead = consistentRead;\n return this;\n }\n\n count(): IQueryBuilder {\n this.command.Select = AGGREGATE_FUNCTIONS.COUNT;\n return this;\n }\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport DynamoDbClientService from './dynamoDbClient.service';\nimport QueryBuilderService from './queryBuilder.service';\n\nimport {\n AGGREGATE_FUNCTIONS,\n DYNAMODB_OPERATORS,\n FILTER_OPERATOR_MAP,\n DYNAMO_DB_UPDATE_ACTIONS,\n} from '../../../utils/constants';\nimport {\n ICompositeFilter,\n ICreateMultipleResponse,\n ICrudService,\n IFilter,\n IFindOptions,\n IFindPagination,\n IRemoveOptions,\n IUpdateExpressions,\n IUpdateExpressionsOptions,\n} from '../../../interfaces';\nimport { CrudSchema } from '../../../schemas/crudSchema';\nimport {\n findIdColumnName,\n getPrimaryKeyColumns,\n getTableName,\n} from '../../../helpers/tableHelper';\nimport { PersistenceErrorWrapper } from '../../../helpers/errorHelper';\nimport {\n QueryCommandInput,\n QueryCommandOutput,\n ScanCommandInput,\n} from '@aws-sdk/lib-dynamodb';\n\nexport class DynamoDbCrudService<T> implements ICrudService<T> {\n private dynamoDbClientService: DynamoDbClientService;\n\n constructor(private tableSchema: typeof CrudSchema) {\n this.dynamoDbClientService = new DynamoDbClientService(this.tableName);\n }\n\n private get tableName(): string {\n return getTableName(this.tableSchema.table);\n }\n\n private get idColumnName(): string | undefined {\n return findIdColumnName(this.tableSchema.columns);\n }\n\n private get defaultPrimaryKeys(): string[] {\n return getPrimaryKeyColumns(this.tableSchema.columns);\n }\n\n async create(data: T | T[]): Promise<T | ICreateMultipleResponse> {\n if (Array.isArray(data)) {\n const response =\n await this.dynamoDbClientService.batchWrittenPut(data);\n return {\n unprocessedItems: response.UnprocessedItems ?? [],\n };\n } else {\n await this.dynamoDbClientService.put(data as Record<string, any>);\n return data as T;\n }\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars, no-unused-vars\n runQuery(queryCommand: any): Promise<any> {\n throw new Error('Method not implemented.');\n }\n\n find(options: IFindOptions = {}): Promise<any> {\n const query = new QueryBuilderService(options.useScan);\n\n if (options.index?.indexName)\n query.usingIndex(options.index?.indexName);\n\n this.applySorting(query, options.sorting, options.index?.indexName);\n this.applyPagination(query, options.pagination);\n\n if (options.consistentRead)\n query.consistentRead(options.consistentRead);\n\n if (options.fields) query.projection(options.fields);\n\n this.applyFilters(query, options);\n\n if (options.aggregateFunction === AGGREGATE_FUNCTIONS.COUNT)\n query.count();\n\n return this.fetchResults(\n query.get(),\n options.pagination?.limit,\n options.useScan,\n ).then((res: any) => {\n const pagination: IFindPagination = {};\n if (res.lastEvaluatedKey) pagination.from = res.lastEvaluatedKey;\n if (options.pagination?.limit)\n pagination.limit = options.pagination?.limit;\n return {\n items: res.items,\n pagination,\n count: res.count,\n };\n });\n }\n\n async fetchResults(\n command: ScanCommandInput | QueryCommandInput,\n limit: number = 100,\n useScan: boolean = false,\n ): Promise<unknown> {\n let results: unknown[] = [];\n let lastEvaluatedKey: Record<string, unknown> = {};\n let rowsCount = 0;\n\n do {\n const result = await this.fetchBatch(\n command,\n useScan,\n lastEvaluatedKey,\n );\n const rows = result.Items ?? [];\n results = results.concat(rows);\n lastEvaluatedKey = result.LastEvaluatedKey ?? {};\n rowsCount += result.Count || rows.length;\n } while (rowsCount < limit && this.isNotEmptyObject(lastEvaluatedKey));\n\n const encryptedLastEvaluatedKey = this.isNotEmptyObject(\n lastEvaluatedKey,\n )\n ? this.encryptPaginationKey(lastEvaluatedKey)\n : null;\n return {\n items: results,\n lastEvaluatedKey: encryptedLastEvaluatedKey,\n count: rowsCount,\n };\n }\n\n async fetchBatch(\n command: ScanCommandInput | QueryCommandInput,\n useScan: boolean,\n lastEvaluatedKey: Record<string, unknown>,\n ): Promise<Partial<QueryCommandOutput>> {\n if (this.isNotEmptyObject(lastEvaluatedKey))\n command.ExclusiveStartKey = lastEvaluatedKey;\n\n const result = await (useScan\n ? this.dynamoDbClientService.scan(command)\n : this.dynamoDbClientService.query(command));\n\n if (command.Select !== AGGREGATE_FUNCTIONS.COUNT) {\n command.Limit = (command.Limit ?? 0) - (result.Items?.length ?? 0);\n }\n\n return result;\n }\n\n applyPagination(\n query: QueryBuilderService,\n pagination: IFindPagination | undefined,\n ) {\n if (pagination?.limit) query.limit(pagination.limit);\n if (pagination?.from)\n query.startKey(this.decryptPaginationKey(pagination.from));\n }\n\n async findAll(\n options: IFindOptions = {},\n allResults: any[] = [],\n rowsCount: number = 0,\n ): Promise<any> {\n const { items, pagination, count } = await this.find(options);\n allResults.push(...items);\n rowsCount += count;\n\n if (pagination?.from)\n await this.findAll({ ...options, pagination }, allResults);\n\n return {\n items: allResults,\n pagination: null,\n count: rowsCount,\n };\n }\n\n async findCount(options: IFindOptions = {}): Promise<number> {\n const findOptions = {\n ...options,\n aggregateFunction: AGGREGATE_FUNCTIONS.COUNT,\n };\n if (options.pagination?.from) {\n return this.find(findOptions).then((res) => res.count);\n } else {\n return this.findAll(findOptions).then((res) => res.count);\n }\n }\n\n buildFindItemQuery(options: IFindOptions): QueryBuilderService {\n const query = new QueryBuilderService();\n\n if (options.index?.indexName) query.usingIndex(options.index.indexName);\n\n this.applyFilters(query, options);\n query.projection(options.fields);\n query.limit(1);\n\n return query;\n }\n\n findItem(options: IFindOptions): Promise<T | null> {\n const query = this.buildFindItemQuery(options);\n return this.dynamoDbClientService.query(query.get()).then((result) => {\n if (result.Items?.length) return result.Items[0] as T;\n if (options.throwErrorIfNull) throw new Error('NOT_FOUND');\n return null;\n });\n }\n\n applyWhereFilter(query: QueryBuilderService, filter: IFilter) {\n const operator =\n FILTER_OPERATOR_MAP[\n filter.operator?.toUpperCase() ?? DYNAMODB_OPERATORS.EQUAL\n ];\n (query.where(filter.attribute) as any)[operator](filter.value);\n }\n\n applyFilterFilter(\n query: QueryBuilderService,\n filter: IFilter,\n logicOperator: string = 'AND',\n config?: any,\n ) {\n const operator =\n FILTER_OPERATOR_MAP[\n filter.operator?.toUpperCase() ?? DYNAMODB_OPERATORS.EQUAL\n ];\n (query.filter(filter.attribute, logicOperator, config) as any)[\n operator\n ](filter.value);\n }\n\n applyFilters(query: QueryBuilderService, options: IFindOptions) {\n if (Array.isArray(options.filters)) {\n this.applySimpleFilters(query, options);\n } else {\n this.applyCompoundFilters(query, options);\n }\n }\n\n applySimpleFilters(query: QueryBuilderService, options: IFindOptions) {\n const queryIndexColumns = options.index?.columns ?? [];\n const defaultWhereProperties = this.defaultPrimaryKeys;\n\n const whereProperties: string[] = queryIndexColumns?.length\n ? queryIndexColumns\n : defaultWhereProperties;\n const filters = options.filters as IFilter[];\n filters.forEach((filter: IFilter) => {\n const isWhereProperty = whereProperties.includes(filter.attribute);\n isWhereProperty && !options.useScan\n ? this.applyWhereFilter(query, filter)\n : this.applyFilterFilter(query, filter);\n });\n }\n\n applyCompoundFilters(query: QueryBuilderService, options: IFindOptions) {\n if (!options.filters) return;\n this.buildFilterExpression(query, options);\n }\n\n buildFilterExpression(\n query: QueryBuilderService,\n options: IFindOptions,\n parentKey?: string,\n ) {\n const compositeFilters = options.filters as ICompositeFilter;\n const queryIndexColumns = options.index?.columns || [];\n const defaultWhereProperties = this.defaultPrimaryKeys;\n\n const whereProperties = queryIndexColumns?.length\n ? queryIndexColumns\n : defaultWhereProperties;\n\n for (const [key, value] of Object.entries(compositeFilters)) {\n value.forEach(\n (filter: IFilter | ICompositeFilter, index: number) => {\n const isCompositeFilter = 'OR' in filter || 'AND' in filter;\n if (isCompositeFilter) {\n const newOptions = {\n ...options,\n filters: filter,\n };\n this.buildFilterExpression(query, newOptions, key);\n } else {\n const simpleFilter = filter as IFilter;\n const isWhereProperty = whereProperties.includes(\n simpleFilter.attribute,\n );\n let config;\n if (parentKey) {\n config = {\n parentKey,\n openExpression: index === 0,\n closeExpression: index === value.length - 1,\n };\n }\n\n isWhereProperty && !options.useScan\n ? this.applyWhereFilter(query, simpleFilter)\n : this.applyFilterFilter(\n query,\n simpleFilter,\n key,\n config,\n );\n }\n },\n );\n }\n }\n\n applySorting(query: QueryBuilderService, sorting: any, sortIndex?: string) {\n if (sorting?.length) {\n if (sortIndex) query.usingIndex(sortIndex);\n if (sorting[0].direction === 'DESC') {\n query.descending();\n } else {\n query.ascending();\n }\n }\n }\n\n isNotEmptyObject(obj: unknown) {\n return (\n obj !== null &&\n typeof obj === 'object' &&\n Object.keys(obj).length > 0\n );\n }\n\n encryptPaginationKey(key: Record<string, any>): string {\n const jsonKey = JSON.stringify(key);\n return Buffer.from(jsonKey).toString('base64');\n }\n\n decryptPaginationKey(encodedKey: string): Record<string, any> {\n const decodedKey = Buffer.from(encodedKey, 'base64').toString('utf-8');\n return JSON.parse(decodedKey);\n }\n\n async update(\n filters: IFilter[] | ICompositeFilter,\n data: Partial<T>,\n { replace = false },\n ): Promise<any> {\n const savedRecord = await this.findItem({\n filters: filters as IFilter[],\n });\n\n if (replace) {\n //delete all attributes of savedRecord except those that as marked as primary columns in the schema\n }\n\n const newData: any = {\n ...savedRecord,\n ...data,\n };\n\n await this.dynamoDbClientService.put(newData);\n return newData;\n }\n\n async remove(\n filters: IFilter[] | ICompositeFilter | IFilter[][],\n options: IRemoveOptions,\n ) {\n if (options?.filterGroups) {\n await this.dynamoDbClientService.batchRemove(\n filters as IFilter[][],\n );\n } else {\n const key = (filters as IFilter[]).reduce((obj: any, item: any) => {\n const property = item.attribute;\n obj[property] = item.value;\n return obj;\n }, {});\n await this.dynamoDbClientService.remove(key);\n }\n }\n\n async updateExpressions(\n filters: IFilter[] | ICompositeFilter,\n actions: IUpdateExpressions,\n options: IUpdateExpressionsOptions,\n ): Promise<any> {\n try {\n return await this.#prepareAndExecuteUpdateExpression(\n filters,\n actions,\n options,\n );\n } catch (error: any) {\n PersistenceErrorWrapper(error);\n }\n }\n\n async #prepareAndExecuteUpdateExpression(\n filters: IFilter[] | ICompositeFilter,\n actions: IUpdateExpressions,\n options: IUpdateExpressionsOptions,\n ) {\n const queryObject = this.#buildUpdateExpressionQuery({ filters }).get();\n const primaryKeys = this.defaultPrimaryKeys;\n\n const keyObject: any = this.#getKeyObjectForUpdateExpression(\n queryObject,\n primaryKeys,\n );\n\n const updateExpressions: any = [];\n\n Object.keys(actions).forEach((action: string) => {\n const actionUpdateExpression =\n this.#extractUpdateExpressionAttributesAndNames(\n actions,\n action,\n );\n updateExpressions.push(actionUpdateExpression);\n });\n\n const dbParams = {\n UpdateExpression: updateExpressions.join(' '),\n ...this.#getUpdateExpressionOptions(options),\n };\n\n const { ExpressionAttributeValues, ExpressionAttributeNames } =\n queryObject;\n if (Object.keys(ExpressionAttributeValues).length > 0) {\n dbParams['ExpressionAttributeValues'] = {\n ...ExpressionAttributeValues,\n ...dbParams.ExpressionAttributeValues,\n };\n }\n\n if (Object.keys(ExpressionAttributeNames).length > 0) {\n dbParams['ExpressionAttributeNames'] = {\n ...ExpressionAttributeNames,\n ...dbParams.ExpressionAttributeNames,\n };\n }\n if (queryObject.FilterExpression)\n dbParams['ConditionExpression'] = queryObject.FilterExpression;\n\n return this.dynamoDbClientService.updateExpressions(\n keyObject,\n dbParams,\n );\n }\n\n #buildUpdateExpressionQuery(options: IFindOptions): QueryBuilderService {\n const query = new QueryBuilderService();\n\n if (options.index?.indexName) query.usingIndex(options.index.indexName);\n this.applyFilters(query, options);\n\n return query;\n }\n\n #getKeyObjectForUpdateExpression(queryObject: any, primaryKeys: any) {\n const keyObject: any = {};\n\n Object.keys(queryObject.ExpressionAttributeNames).forEach(\n (attribute) => {\n const sanitizedAttribute = attribute\n .replace('#', '')\n .replace('1', '');\n if (primaryKeys.includes(sanitizedAttribute)) {\n const valueName = `:${sanitizedAttribute}1`;\n keyObject[sanitizedAttribute] =\n queryObject.ExpressionAttributeValues[valueName];\n delete queryObject.ExpressionAttributeValues[valueName];\n delete queryObject.ExpressionAttributeNames[attribute];\n }\n },\n );\n\n return keyObject;\n }\n\n #getUpdateExpressionOptions(options: IUpdateExpressionsOptions) {\n const updateExprOptions: any = {\n ReturnValues: options.returnValues,\n };\n\n if (options.expressionAttributeNames)\n updateExprOptions.ExpressionAttributeNames =\n options.expressionAttributeNames;\n if (options.expressionAttributeValues)\n updateExprOptions.ExpressionAttributeValues =\n options.expressionAttributeValues;\n\n return updateExprOptions;\n }\n\n #extractUpdateExpressionAttributesAndNames(\n actions: any,\n actionType: string,\n ) {\n const actionUpdateExpressions: any = [];\n\n actions[actionType].forEach((action: any) => {\n switch (actionType) {\n case DYNAMO_DB_UPDATE_ACTIONS.DELETE:\n case DYNAMO_DB_UPDATE_ACTIONS.REMOVE:\n actionUpdateExpressions.push(`${action.path}`);\n break;\n\n case DYNAMO_DB_UPDATE_ACTIONS.ADD:\n case DYNAMO_DB_UPDATE_ACTIONS.SET:\n {\n let operator = '';\n if (actionType == DYNAMO_DB_UPDATE_ACTIONS.SET)\n operator = '=';\n actionUpdateExpressions.push(\n `${action.path} ${operator}${action.value}`,\n );\n }\n break;\n }\n });\n\n const actionUpdateExpression = `${actionType} ${actionUpdateExpressions.join(\n ', ',\n )}`;\n\n return actionUpdateExpression;\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n runRawQuery(query: string, params: any[]): Promise<any> {\n throw new Error('Method not implemented.');\n }\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/services/cruds/postgresql/postgreSqlClient.service.ts","../../src/services/cruds/postgresql/connection.service.ts","../../src/services/cruds/postgresql/query.service.ts","../../src/services/cruds/postgresql/postgreSqlCrud.service.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\n/* eslint-disable no-console */\n\nimport format from 'pg-format';\nimport { QueryResult } from 'pg';\nimport { AggregateFunction, DbPool, FilterLogicOperator } from '../../../types';\nimport {\n ICompositeFilter,\n IFilter,\n IFindOptions,\n IFindPagination,\n ISorting,\n IUpdateExpressions,\n IUpdateExpressionsOptions,\n} from '../../../interfaces';\nimport QueryService from './query.service';\nimport {\n FILTER_LOGIC_OPERATORS,\n SORT_DIRECTIONS,\n POSTGRES_FILTER_OPERATOR_MAP,\n DEFAULT_PG_SCHEMA,\n FilterOperator,\n DYNAMO_DB_UPDATE_ACTIONS,\n} from '../../../utils/constants';\nimport { CrudSchema } from '../../../schemas';\nimport { getTableName } from '../../../helpers/tableHelper';\nimport { buildAggFunctionAlias } from '../../../helpers/queryHelpers';\nimport { IFindRawWith } from '../../../interfaces/findRawWith.interface';\n\nexport default class PostgresqlClientService<T> extends QueryService {\n private crudSchema: typeof CrudSchema;\n constructor(tableSchema: typeof CrudSchema, poolClient?: DbPool) {\n super(poolClient);\n this.crudSchema = tableSchema;\n }\n\n get dbSchema() {\n return this.crudSchema.schema || DEFAULT_PG_SCHEMA;\n }\n\n get tableName() {\n return (\n getTableName(this.crudSchema.table, 'alias') ||\n getTableName(this.crudSchema.table)\n );\n }\n\n get isTemporalTable() {\n return this.crudSchema?.isTemporalTable;\n }\n\n getWildcardValue(operator: FilterOperator, value: string): string {\n if (\n operator === FilterOperator.CONTAINS ||\n operator === FilterOperator.NOT_CONTAINS\n ) {\n return '%' + value + '%';\n } else if (operator === FilterOperator.STARTS_WITH) {\n return value + '%';\n } else {\n return value;\n }\n }\n\n private buildClause(\n operator: FilterOperator,\n attribute: string,\n relativePath: string | undefined,\n value: any,\n ): string {\n const formattedValue = format.literal(value);\n operator = operator\n ? (operator.toUpperCase() as FilterOperator)\n : FilterOperator.EQUAL;\n const postgresOperator = POSTGRES_FILTER_OPERATOR_MAP[operator];\n\n if (!postgresOperator)\n throw new Error(`Unsupported filter operator: ${operator}`);\n\n let property;\n const filterProperty = format.ident(attribute);\n const columnExists = !!this.crudSchema.columns[attribute];\n const columnType =\n columnExists && this.crudSchema.columns[attribute]?.type;\n\n if (relativePath != undefined) {\n const attributePath = relativePath.split('.').join(',');\n\n property = `(\"${attribute}\" #> '{${attributePath}}')`;\n if (value != null) {\n const comparisonValueType =\n this.getValueTypeAsPostgresDefinition(value);\n property += `::${comparisonValueType}`;\n }\n } else {\n property = columnExists\n ? filterProperty\n : `(\"qvAttributes\" ->> '${attribute}')`;\n }\n\n if (operator === FilterOperator.IN) {\n const formattedValues = Array.isArray(value)\n ? value.map(format.literal)\n : [formattedValue];\n return `${property} ${postgresOperator} (${formattedValues.join(\n ', ',\n )})`;\n }\n\n if (operator === FilterOperator.BETWEEN) {\n return `${property} ${postgresOperator} ${value[0]} AND ${value[1]}`;\n }\n\n /**\n * ? Additional filter to avoid error when column accepts null values.\n */\n if (operator === FilterOperator.NOT_EQUAL && value !== null) {\n return `(${property} ${postgresOperator} ${format.literal(\n value,\n )} OR ${property} IS NULL)`;\n }\n\n if (\n operator === FilterOperator.NOT_EXIST ||\n operator === FilterOperator.EXIST\n ) {\n return `${property} ${postgresOperator}`;\n }\n\n if (\n (operator === FilterOperator.CONTAINS ||\n operator === FilterOperator.NOT_CONTAINS) &&\n columnType === 'array'\n ) {\n const filterValue =\n typeof value === 'number' ? value : `'${value}'`;\n let filterString = `${filterValue} = ANY(${property})`;\n\n if (operator === FilterOperator.NOT_CONTAINS) {\n if (value === null) {\n filterString = `(NOT (${filterString}))`;\n } else {\n filterString = `(NOT (${filterString}) or ${property} IS NULL)`;\n }\n }\n return filterString;\n }\n\n const wildcardValue = this.getWildcardValue(operator, value);\n return `${property} ${postgresOperator} ${format.literal(\n wildcardValue,\n )}`;\n }\n\n private buildFilterClause(\n filters: IFilter[] | ICompositeFilter,\n logicOperator?: FilterLogicOperator,\n ): string {\n if (Array.isArray(filters)) {\n const filterClauses = filters.map((filter) => {\n return this.buildClause(\n filter.operator as FilterOperator,\n filter.attribute,\n filter.relativePath,\n filter.value,\n );\n });\n return filterClauses.join(\n ` ${logicOperator ?? FILTER_LOGIC_OPERATORS.AND} `,\n );\n } else {\n return this.buildQueryByClause(filters);\n }\n }\n\n private isCompositeFilter = function (value: any) {\n return 'OR' in value || 'AND' in value;\n };\n\n buildQueryByClause(filters: IFilter[] | ICompositeFilter): string {\n let filterClauses: string = '';\n let isFirstFilter = true;\n\n for (const [key, value] of Object.entries(filters)) {\n if (!isFirstFilter) {\n filterClauses += key === 'AND' ? ' AND ' : ' OR ';\n }\n\n if (this.isCompositeFilter(value)) {\n filterClauses += '(';\n filterClauses += this.buildQueryByClause(\n value as ICompositeFilter,\n );\n filterClauses += ')';\n } else {\n (value as IFilter[]).forEach((filter: IFilter) => {\n let clause = '';\n if (this.isCompositeFilter(filter)) {\n clause = `(${this.buildQueryByClause(\n filter as ICompositeFilter,\n )})`;\n } else {\n clause = this.buildClause(\n filter.operator as FilterOperator,\n filter.attribute,\n filter.relativePath,\n filter.value,\n );\n }\n filterClauses += `${clause} ${key} `;\n });\n }\n\n isFirstFilter = false;\n }\n\n filterClauses = filterClauses.replace(/\\s+(AND|OR)\\s*$/, '');\n return filterClauses;\n }\n\n private formatOrderByItem(sort: ISorting): string {\n return `${format.ident(sort.column)} ${\n sort.direction || SORT_DIRECTIONS.ASC\n }`;\n }\n\n private buildOrderByClause(querySorting: ISorting[]): string {\n try {\n return querySorting.map(this.formatOrderByItem).join(', ');\n } catch (error) {\n return '';\n }\n }\n\n formatArray(array: any[]) {\n const isNumberArray = typeof array[0] === 'number';\n if (isNumberArray) {\n return `{${array.join(',')}}`;\n } else {\n return `{${array.map((val) => `\"${val}\"`).join(',')}}`;\n }\n }\n\n formatValue(value: any) {\n if (Array.isArray(value)) {\n if (!value?.length) return '{}';\n const isNumberArray = typeof value[0] === 'number';\n if (isNumberArray) {\n return `{${value.join(',')}}`;\n } else {\n return `{${value.map((val: any) => `\"${val}\"`).join(',')}}`;\n }\n }\n return value;\n }\n\n async createCommand(data: any[]): Promise<any> {\n const keys = Object.keys(data[0]); // Assuming all objects have the same keys\n const values = data.map((item) =>\n keys.map((key) => this.formatValue(item[key])),\n );\n\n const query = format(\n `INSERT INTO ${format.ident(this.dbSchema)}.${format.ident(\n this.tableName,\n )} (%I) VALUES %L RETURNING *;`,\n keys,\n values,\n );\n\n return this.runQuery(query);\n }\n\n private isValidFiltersInput(\n filters: IFilter[] | ICompositeFilter,\n ): boolean {\n const isValidArrayFilters =\n Array.isArray(filters) && filters?.length > 0;\n const isValidCompositeFilters = this.isCompositeFilter(filters);\n return isValidArrayFilters || isValidCompositeFilters;\n }\n\n private replaceFilterTokensInQuery(\n query: string,\n filters?: IFilter[] | ICompositeFilter,\n ) {\n if (!filters) return query;\n\n if (this.isValidFiltersInput(filters)) {\n const filterClause = this.buildFilterClause(filters);\n return query.replace(/{{filters}}/g, filterClause);\n }\n }\n\n private addFiltersToQuery(\n query: string,\n filters?: IFilter[] | ICompositeFilter,\n ): string {\n if (!filters) return query;\n\n if (this.isValidFiltersInput(filters))\n query += ` WHERE ${this.buildFilterClause(filters)}`;\n return query;\n }\n\n addOrderByToQuery(query: string, orderBy?: ISorting[]): string {\n if (orderBy) query += ` ORDER BY ${this.buildOrderByClause(orderBy)}`;\n return query;\n }\n\n private addPaginationToQuery(\n query: string,\n pagination?: IFindPagination,\n ): string {\n if (pagination) {\n const { limit, from } = pagination;\n if (limit) query += ` LIMIT ${limit}`;\n if (from) query += ` OFFSET ${from}`;\n }\n return query;\n }\n\n private getSelectClause(\n aggregateFunction: AggregateFunction | undefined,\n fields: string[] = [],\n ) {\n if (aggregateFunction)\n return `CAST(${aggregateFunction}(1) AS INTEGER) AS \"${buildAggFunctionAlias(\n aggregateFunction,\n )}\"`;\n if (!fields?.length) return '*';\n\n return this.parseFields(fields).join(', ');\n }\n\n private parseFields(fields: String[]): String[] {\n const columnsFromSchema: String[] = Object.keys(\n this.crudSchema.columns,\n );\n const attributes: String[] = fields\n .filter((field) => columnsFromSchema.indexOf(field) !== -1)\n .map((field) => `\"${field}\"`);\n\n fields\n .filter((field) => columnsFromSchema.indexOf(field) === -1)\n .forEach((field) => {\n attributes.push(`\"qvAttributes\" ->> '${field}' as \"${field}\"`);\n });\n return attributes;\n }\n\n private resolveWithQueries(rawWith: IFindRawWith[]): string[] {\n const withQueries = rawWith.map(({ alias, query, filters }) => {\n const withQuery = this.replaceFilterTokensInQuery(query, filters);\n return `${alias} AS (${withQuery})`;\n });\n return withQueries;\n }\n\n getRawWithClause(rawWith?: IFindRawWith[]): string {\n let rawWithClause = '';\n if (rawWith?.length) {\n const withQueries = this.resolveWithQueries(rawWith);\n rawWithClause = 'WITH ' + withQueries.join(',\\n');\n }\n return rawWithClause;\n }\n\n getQueryFrom() {\n return this.isTemporalTable\n ? format.ident(this.tableName)\n : `${format.ident(this.dbSchema)}.${format.ident(this.tableName)}`;\n }\n\n async findCommand(options: IFindOptions = {}): Promise<T[]> {\n const rawWithClause = this.getRawWithClause(options.rawWith);\n let query = `SELECT ${this.getSelectClause(\n options.aggregateFunction,\n options.fields,\n )} FROM ${this.getQueryFrom()}`;\n query = this.addFiltersToQuery(query, options.filters);\n if (!options.aggregateFunction) {\n query = this.addOrderByToQuery(query, options.sorting);\n query = this.addPaginationToQuery(query, options.pagination);\n }\n if (rawWithClause) {\n query = `${rawWithClause} ${query}`;\n }\n return (await this.runQuery(query)).rows;\n }\n\n sanitizeValue(value: any): string {\n if (Array.isArray(value)) {\n if (value.length === 0) '[]';\n const formattedArray = value\n .map((item) => {\n if (typeof item === 'string') {\n return `'${item}'`;\n } else if (typeof item === 'object') {\n return JSON.stringify(item);\n } else {\n return item;\n }\n })\n .join(',');\n\n return JSON.stringify(formattedArray);\n } else {\n return format.literal(value);\n }\n }\n\n async updateCommand(\n filters: IFilter[] | ICompositeFilter,\n data: Partial<any>,\n ): Promise<QueryResult<any>> {\n let query = `UPDATE ${format.ident(this.dbSchema)}.${format.ident(\n this.tableName,\n )} SET`;\n\n const updateClauses = Object.entries(data).map(([key, value]) => {\n const dbValue = format.literal(this.formatValue(value));\n return `${format.ident(key)} = ${dbValue}`;\n });\n query += ` ${updateClauses.join(', ')}`;\n\n query += ' WHERE ';\n query += this.buildFilterClause(filters);\n\n return this.runQuery(query);\n }\n\n private buildFilterClauseForFilterGroups(\n filterGroups: IFilter[][],\n ): string {\n const filterClauses = filterGroups.map((filterGroup) => {\n return `(${this.buildFilterClause(filterGroup)})`;\n });\n return filterClauses.join(' OR ');\n }\n\n async deleteCommand(\n filters?: ICompositeFilter | IFilter[] | IFilter[][],\n useFilterGroups: boolean = false,\n ): Promise<QueryResult<any>> {\n let query = `DELETE FROM ${format.ident(this.dbSchema)}.${format.ident(\n this.tableName,\n )}`;\n if (filters) {\n query += ' WHERE ';\n\n if (useFilterGroups) {\n query += this.buildFilterClauseForFilterGroups(\n filters as IFilter[][],\n );\n } else {\n query += this.buildFilterClause(\n filters as ICompositeFilter | IFilter[],\n );\n }\n }\n\n return this.runQuery(query);\n }\n\n query(queryText: string, values?: any[]) {\n return this.runQuery(queryText, values);\n }\n\n public async updateExpressionCommand(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n filters: IFilter[] | ICompositeFilter,\n actions: IUpdateExpressions,\n options: Partial<IUpdateExpressionsOptions> = {},\n ) {\n let query = `UPDATE ${format.ident(this.dbSchema)}.${format.ident(\n this.tableName,\n )} SET`;\n\n const set = actions.SET || [];\n const add = actions.ADD || [];\n const columns = this.crudSchema.columns;\n\n const setValues = this.replacePathAndValueByAttributeNames(\n set,\n options,\n columns,\n DYNAMO_DB_UPDATE_ACTIONS.SET,\n );\n const addValues = this.replacePathAndValueByAttributeNames(\n add,\n options,\n columns,\n DYNAMO_DB_UPDATE_ACTIONS.ADD,\n );\n\n const setValuesAndAddValues: any = setValues.concat(addValues);\n\n const updateClauses: any = [];\n const jsonSetExpressionGroup: any = {};\n const queryFunctions: any = [];\n\n setValuesAndAddValues.forEach((expression: any) => {\n const { path, value, createNewColumn, actionName, dynamoFuncName } =\n expression;\n\n //Dynamo functions replacement\n if (dynamoFuncName) {\n queryFunctions.push({ path, value, dynamoFuncName });\n }\n\n if (path.includes('.') && !dynamoFuncName) {\n const jsonExpr = this.getJSONBSetExpressionByAction(\n path,\n value,\n {\n createNewColumn,\n actionName,\n },\n );\n const columnName: string = jsonExpr.columnName;\n if (!jsonSetExpressionGroup[columnName]) {\n jsonSetExpressionGroup[columnName] = [jsonExpr];\n } else {\n jsonSetExpressionGroup[columnName].push(jsonExpr);\n }\n } else if (!dynamoFuncName) {\n let expValue;\n const column = this.crudSchema.columns[path];\n if (column?.type == undefined)\n throw `Column type definition for column: (${path}) must be in the CrudSchema`;\n let formattedValue;\n switch (column.type) {\n case 'object':\n {\n const valueSerialized = `${JSON.stringify(\n value,\n ).replace(/'/g, \"''\")}`;\n expValue = `'${valueSerialized}'::jsonb`;\n }\n break;\n case 'array':\n formattedValue = format.literal(value);\n expValue = `ARRAY[${formattedValue}]`;\n break;\n default:\n formattedValue = format.literal(value);\n expValue = formattedValue;\n break;\n }\n this.crudSchema.columns;\n updateClauses.push(`${format.ident(path)} = ${expValue}`);\n }\n });\n\n this.setCommonColumnsQueryFunctions(\n jsonSetExpressionGroup,\n queryFunctions,\n );\n\n if (Object.keys(jsonSetExpressionGroup).length > 0) {\n Object.keys(jsonSetExpressionGroup).forEach((groupIndex) => {\n const jsonSetExpression = this.buildJSONBExpression(\n jsonSetExpressionGroup[groupIndex],\n 'jsonb_set',\n );\n\n updateClauses.push(`${groupIndex} = ${jsonSetExpression}`);\n });\n }\n\n //This is for dynamo functions transformed to postgresql functions\n this.buildUpdateClausesFormDynamoFunctions(\n queryFunctions,\n updateClauses,\n );\n\n query += ` ${updateClauses.join(', ')}`;\n\n query += ' WHERE ';\n query += this.buildFilterClause(filters);\n\n return this.runQuery(query);\n }\n\n private buildUpdateClausesFormDynamoFunctions(\n queryFunctions: any,\n updateClauses: any,\n ) {\n if (queryFunctions.length > 0) {\n queryFunctions.forEach((queryFunction: any) => {\n if (typeof queryFunction.value == 'object') {\n const jsonExpr = this.buildJSONBExpression(\n queryFunction.value.jsonExpression,\n 'jsonb_insert',\n );\n updateClauses.push(\n `${format.ident(queryFunction.path)} = ${jsonExpr}`,\n );\n } else {\n updateClauses.push(\n `${format.ident(queryFunction.path)} = ${\n queryFunction.value\n }`,\n );\n }\n });\n }\n }\n\n private setCommonColumnsQueryFunctions(\n jsonSetExpressionGroup: any,\n queryFunctions: any,\n ) {\n Object.keys(jsonSetExpressionGroup).forEach((jsonSetExpr: any) => {\n queryFunctions.forEach((queryFunction: any, index: number) => {\n const columnPath = `\"${queryFunction.path}\"`;\n if (columnPath === jsonSetExpr) {\n jsonSetExpressionGroup[jsonSetExpr].push({\n ...queryFunction,\n isCommonColumn: true,\n });\n delete queryFunctions[index];\n }\n });\n });\n }\n\n /**\n * @description Builds a jsonb expression like jsonb_insert, or jsonb_set\n * @param jsonSetExpressions\n * @param functionName\n * @returns\n */\n private buildJSONBExpression(\n jsonSetExpressions: any,\n functionName: string,\n ) {\n let jsonSetStringExpr = '';\n jsonSetExpressions.forEach((expression: any, index: number) => {\n let _tempFunctionName = functionName;\n let { columnName, jsonExpr } = expression;\n //Is a common column for dynamoDBFunctions\n if (expression.isCommonColumn) {\n const jsonExpression = expression.value.jsonExpression[0];\n _tempFunctionName = jsonExpression.functionName;\n jsonExpr = jsonExpression.jsonExpr;\n columnName = jsonExpression.columnName;\n }\n if (index === 0) {\n jsonSetStringExpr = `${_tempFunctionName}(${columnName},${jsonExpr})`;\n } else {\n jsonSetStringExpr = `${_tempFunctionName}(${jsonSetStringExpr},${jsonExpr})`;\n }\n });\n return jsonSetStringExpr;\n }\n\n /**\n * @description Serializes a JSON value\n * @param value\n * @returns\n */\n private serializeJSONValue(value: any) {\n const valueSerialized =\n typeof value == 'object'\n ? `${JSON.stringify(value).replace(/'/g, \"''\")}`\n : value;\n return valueSerialized;\n }\n\n private getJSONBSetExpressionByAction(\n path: string,\n value: any,\n options: any,\n ) {\n path = path.replace(/\\[(\\d+)\\]/g, '.$1');\n const pathSplitted = path.split('.');\n const parentPath = pathSplitted[0];\n const { createNewColumn, actionName } = options;\n\n const pathSerialized = pathSplitted.slice(1).join(',');\n const valueSerialized = `'${JSON.stringify(value).replace(\n /'/g,\n \"''\",\n )}'`;\n\n if (actionName == DYNAMO_DB_UPDATE_ACTIONS.ADD) {\n if (typeof value != 'string' && !isNaN(value)) {\n const resultExpr = {\n jsonExpr: `'{${pathSerialized}}',to_jsonb(COALESCE((\"${parentPath}\"#>'{${pathSerialized}}')::numeric,0) + ${valueSerialized})`,\n columnName: `\"${parentPath}\"`,\n };\n return resultExpr;\n }\n }\n return {\n jsonExpr: `'{${pathSerialized}}',${valueSerialized},${createNewColumn}`,\n columnName: `\"${parentPath}\"`,\n };\n }\n\n private getListAppendDefFromValue(queryValue: string, columnType: string) {\n const regexListAppend = /list_append\\(([^)]+)\\)/gm;\n const listAppendString = 'list_append(';\n\n const matchList = queryValue.match(regexListAppend) || [];\n const groupResult = matchList[0];\n\n if (groupResult) {\n const attributesFromGroup = groupResult\n .slice(listAppendString.length, -1)\n .split(',');\n const attributes = {\n originalString: groupResult,\n path: attributesFromGroup[0].trim(),\n value: attributesFromGroup.slice(1).join(',').trim(),\n isDynamoFunction: true,\n functionExpr: '',\n jsonExpression: [{}],\n };\n if (columnType == 'array') {\n attributes['functionExpr'] =\n this.buildArrayAppendExpr(attributes);\n } else {\n attributes['jsonExpression'] =\n this.buildJsonbInsertExpr(attributes);\n }\n return attributes;\n }\n\n return null;\n }\n\n private buildArrayAppendExpr(params: any) {\n const arrayPath = params.path.split('.');\n const columnName = arrayPath.shift();\n return `ARRAY_APPEND(\"${columnName}\",${params.value})`;\n }\n\n private buildJsonbInsertExpr(params: any) {\n const arrayPath = params.path.split('.');\n const columnName = arrayPath.shift();\n const options = {\n isDynamoFunction: params?.isDynamoFunction,\n relativePath:\n arrayPath.length && Array.isArray(arrayPath) ? arrayPath : [],\n };\n const jsonbInsertExpressions =\n this.getExpressionsByDefinitionForJSONBInsert(\n columnName,\n params.value,\n options,\n );\n\n return jsonbInsertExpressions;\n }\n\n private getExpressionsByDefinitionForJSONBInsert(\n columnName: string,\n value: string,\n options: any,\n ) {\n const jsonbInsertExpressions = [];\n let pathToAffect = '0';\n if (options.isDynamoFunction == true) {\n options.relativePath.push('0');\n pathToAffect = options.relativePath.join(',');\n }\n try {\n const parsedValue = JSON.parse(value);\n\n if (Array.isArray(parsedValue)) {\n parsedValue.forEach((arrayValue) => {\n arrayValue =\n typeof arrayValue == 'string'\n ? `\"${arrayValue}\"`\n : arrayValue;\n jsonbInsertExpressions.push({\n jsonExpr: `'{${pathToAffect}}','${this.serializeJSONValue(\n arrayValue,\n )}'`,\n columnName: `\"${columnName}\"`,\n functionName: 'jsonb_insert',\n });\n });\n } else {\n jsonbInsertExpressions.push({\n jsonExpr: `'{${pathToAffect}}','${this.serializeJSONValue(\n parsedValue,\n )}'`,\n columnName: `\"${columnName}\"`,\n functionName: 'jsonb_insert',\n });\n }\n } catch (error) {\n jsonbInsertExpressions.push({\n jsonExpr: `'{${pathToAffect}}','${value}'`,\n columnName: `\"${columnName}\"`,\n functionName: 'jsonb_insert',\n });\n }\n return jsonbInsertExpressions;\n }\n\n private getInsertExprFromJsonbDef(queryValue: string, columnType: string) {\n const listAppendParams = this.getListAppendDefFromValue(\n queryValue,\n columnType,\n );\n if (\n listAppendParams != null &&\n listAppendParams?.jsonExpression.length === 0\n ) {\n queryValue = queryValue.replace(\n listAppendParams.originalString,\n listAppendParams.functionExpr,\n );\n } else {\n return listAppendParams;\n }\n\n return queryValue;\n }\n\n private replacePathAndValueByAttributeNames(\n actions: any[],\n options: IUpdateExpressionsOptions,\n columns: any,\n actionName: string,\n ) {\n return actions.map((action) => {\n action.path = this.replaceExpressionAttributeNames(\n action.path,\n options,\n );\n if (\n typeof action.value == 'string' &&\n action.value.includes('list_append')\n ) {\n action.path = action.path.split('.')[0];\n const column = columns[action.path];\n action.value =\n this.replaceExpressionAttributeValuesForDynamoFunctions(\n action.value,\n options,\n );\n action.value = this.getInsertExprFromJsonbDef(\n action.value,\n column.type,\n );\n action.dynamoFuncName = 'list_append';\n } else {\n action.value = this.replaceExpressionAttributeValues(\n action.value,\n options,\n );\n }\n\n action.actionName = actionName;\n action.createNewColumn = true;\n return action;\n });\n }\n\n private replaceExpressionAttributeValuesForDynamoFunctions(\n value: string,\n options: any,\n ) {\n const { expressionAttributeNames, expressionAttributeValues } = options;\n const exprAttributeNamesKeys = expressionAttributeNames\n ? Object.keys(expressionAttributeNames)\n : [];\n const exprAttributeValuesKeys = expressionAttributeValues\n ? Object.keys(expressionAttributeValues)\n : [];\n\n //Set for attribute names\n if (exprAttributeNamesKeys.length > 0) {\n exprAttributeNamesKeys.forEach((exprAttribute) => {\n value = value.replace(\n exprAttribute,\n expressionAttributeNames[exprAttribute],\n );\n });\n }\n\n //Set for attribute values\n if (exprAttributeValuesKeys.length > 0) {\n exprAttributeValuesKeys.forEach((exprAttribute) => {\n const valueSerialized = this.serializeJSONValue(\n expressionAttributeValues[exprAttribute],\n );\n value = value.replace(exprAttribute, `${valueSerialized}`);\n });\n }\n return value;\n }\n\n private replaceExpressionAttributeNames(\n path: string,\n options: IUpdateExpressionsOptions,\n ) {\n const { expressionAttributeNames } = options;\n\n if (expressionAttributeNames) {\n Object.keys(expressionAttributeNames).forEach(\n (attributeName: string) => {\n const attributeNameValue: string =\n expressionAttributeNames[attributeName];\n path = path.replace(attributeName, attributeNameValue);\n },\n );\n }\n return path;\n }\n\n private replaceExpressionAttributeValues(\n value: string,\n options: IUpdateExpressionsOptions,\n ) {\n const { expressionAttributeValues } = options;\n if (expressionAttributeValues[value] != undefined) {\n return expressionAttributeValues[value];\n }\n\n return value;\n }\n\n private getValueTypeAsPostgresDefinition(value: any) {\n switch (typeof value) {\n case 'number':\n return 'number';\n case 'boolean':\n return 'boolean';\n case 'string':\n default:\n return 'text';\n }\n }\n}\n","import { Client } from 'pg';\n\nexport default class ConnectionService {\n get connectionString() {\n const connectionString =\n process.env.MULTIPLATFORM_PG_CONNECTION_STRING || '';\n if (!connectionString) {\n throw new Error(\n 'MULTIPLATFORM_PG_CONNECTION_STRING environment variable must be configured',\n );\n }\n return connectionString;\n }\n\n async getClient(): Promise<Client> {\n const client: Client = new Client({\n connectionString: this.connectionString,\n });\n await client.connect();\n return client;\n }\n\n releaseClient(client: Client): void {\n try {\n client.end();\n } catch {\n // eslint-disable-next-line no-console\n console.log('Error releasing client');\n }\n }\n}\n","/* eslint-disable no-console */\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { Client, PoolClient, QueryResult } from 'pg';\nimport ConnectionService from './connection.service';\nimport { DbPool } from '../../../types';\n\nexport default class QueryService {\n private connectionService: ConnectionService;\n\n constructor(private pool?: DbPool) {\n this.connectionService = new ConnectionService();\n }\n\n async runQuery(\n queryText: string,\n values?: any[],\n ): Promise<QueryResult<any>> {\n const client: PoolClient | Client | any = await (this.pool\n ? this.pool.connect()\n : this.connectionService.getClient());\n\n try {\n if (process.env.NODE_ENV === 'debugging')\n console.log('queryText:::', queryText);\n const result = await client.query(queryText, values);\n return result;\n } finally {\n if (this.pool) {\n await client.release();\n } else {\n this.connectionService.releaseClient(client as Client);\n }\n }\n }\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport PostgresqlClientService from './postgreSqlClient.service';\nimport {\n ICompositeFilter,\n ICreateMultipleResponse,\n ICrudService,\n IFilter,\n IFindOptions,\n IFindResult,\n IRemoveOptions,\n IUpdateExpressions,\n IUpdateExpressionsOptions,\n} from '../../../interfaces';\nimport { CrudSchema } from '../../../schemas';\nimport { findIdColumnName } from '../../../helpers/tableHelper';\nimport { AGGREGATE_FUNCTIONS } from '../../../utils/constants';\nimport { buildAggFunctionAlias } from '../../../helpers/queryHelpers';\nimport { PersistenceErrorWrapper } from '../../../helpers/errorHelper';\nimport { DbPool } from '../../../types';\nexport class PostgreSqlCrudService<T>\n extends PostgresqlClientService<T>\n implements ICrudService<T>\n{\n constructor(\n private tableSchema: typeof CrudSchema,\n poolClient?: DbPool,\n ) {\n super(tableSchema, poolClient);\n }\n\n private get idColumnName(): string | undefined {\n return findIdColumnName(this.tableSchema.columns);\n }\n\n normalizeInputData(inputData: any) {\n inputData.qvAttributes = {};\n for (const key in inputData) {\n if (!this.tableSchema.columns[key] && key !== 'qvAttributes') {\n inputData.qvAttributes[key] = inputData[key];\n delete inputData[key];\n } else if (\n Array.isArray(inputData[key]) &&\n this.tableSchema.columns[key]?.type !== 'array'\n ) {\n inputData[key] = JSON.stringify(inputData[key]);\n }\n }\n }\n\n getItem(data: { [key: string]: any }): any {\n const schemaColumns = Object.entries(this.tableSchema.columns);\n schemaColumns.forEach(([key, value]) => {\n if (value.type === 'big_number') {\n if (data[key]) data[key] = Number(data[key]);\n }\n });\n const resultItem = { ...data, ...data.qvAttributes };\n delete resultItem['qvAttributes'];\n return resultItem;\n }\n\n prepareData(data: T): any {\n const inputData = { ...data } as { [key: string]: any };\n this.normalizeInputData(inputData);\n return inputData;\n }\n\n buildCreateResponseBatch(result: any): ICreateMultipleResponse {\n const rows = Array.isArray(result?.rows) ? result.rows : [];\n return {\n items: rows.map((r: any) => this.getItem(r)),\n unprocessedItems: [],\n };\n }\n\n create(data: T | T[]): Promise<T | ICreateMultipleResponse> {\n if (Array.isArray(data)) {\n const inputDataArray = data.map((item) => this.prepareData(item));\n return this.createCommand(inputDataArray).then((result) => {\n return this.buildCreateResponseBatch(result);\n });\n } else {\n const inputData = this.prepareData(data);\n return this.createCommand([inputData]).then((result) =>\n result.rowCount ? this.getItem(result.rows[0]) : null,\n );\n }\n }\n\n findItem(findOptions: IFindOptions): Promise<T | null> {\n return this.findCommand(findOptions).then((data) => {\n return data?.length\n ? this.getItem(data[0] as { [key: string]: any })\n : null;\n });\n }\n\n private async processQueryResult(\n findOptions: IFindOptions,\n omitPagination: boolean = false,\n ): Promise<IFindResult<T>> {\n const rows = await this.findCommand(findOptions);\n const items = rows.map((row) =>\n this.getItem(row as { [key: string]: any }),\n );\n\n const { limit, from } = findOptions?.pagination || {};\n const hasMoreRecords = items.length && items.length === limit;\n const newFrom = limit && hasMoreRecords ? limit + (from || 0) : null;\n\n const result: IFindResult<T> = {\n items,\n pagination: omitPagination ? null : { limit: limit, from: newFrom },\n count: items.length,\n };\n return result;\n }\n\n async find(findOptions: IFindOptions): Promise<IFindResult<T>> {\n return this.processQueryResult(findOptions);\n }\n\n async findAll(findOptions: IFindOptions): Promise<IFindResult<T>> {\n return this.processQueryResult(findOptions, true);\n }\n\n async findCount(findOptions: IFindOptions): Promise<number> {\n const items = await this.findCommand({\n ...findOptions,\n aggregateFunction: AGGREGATE_FUNCTIONS.COUNT,\n });\n\n const aggFunctionProperty = buildAggFunctionAlias(\n AGGREGATE_FUNCTIONS.COUNT,\n );\n const item: any = items.length ? items[0] : {};\n return item[aggFunctionProperty] || 0;\n }\n\n async update(\n filters: IFilter[] | ICompositeFilter,\n data: Partial<T>,\n ): Promise<any> {\n const savedRecord = await this.findItem({ filters });\n\n const inputData: any = {\n ...savedRecord,\n ...data,\n } as {\n [key: string]: any;\n };\n\n await this.updateCommand(filters, this.prepareData(inputData));\n return this.getItem(inputData);\n }\n\n async remove(\n filters: IFilter[] | ICompositeFilter | IFilter[][],\n options: IRemoveOptions,\n ): Promise<void> {\n await this.deleteCommand(filters, options?.filterGroups);\n }\n\n runQuery(querySentence: string, values?: any[]) {\n return super.runQuery(querySentence, values);\n }\n\n async updateExpressions(\n filters: IFilter[] | ICompositeFilter,\n actions: IUpdateExpressions,\n options: IUpdateExpressionsOptions,\n ): Promise<any> {\n const result = await this.updateExpressionCommand(\n filters,\n actions,\n options,\n );\n return PersistenceErrorWrapper(result);\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n runRawQuery(query: string, params: any[]): Promise<any> {\n throw super.runQuery(query, params);\n }\n}\n"]}
|