UNPKG

cmp-aws-database

Version:

The package "cmp-aws-database" is for its database, which defines global tables. These tables are designed to be imported and used across multiple applications of "craft-my-plate."

245 lines 35.8 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.GenericDAO = exports.mapper = exports.dynamoDB = void 0; const client_dynamodb_1 = require("@aws-sdk/client-dynamodb"); const mapper_1 = require("@nova-odm/mapper"); exports.dynamoDB = new client_dynamodb_1.DynamoDB({ maxAttempts: 10 }); exports.mapper = new mapper_1.DataMapper({ client: exports.dynamoDB }); class GenericDAO { async batchUpdate(items, batchSize = 100, authContext) { let success = 0, totalToUpdate = items.length; let updateItems = []; while (items.length > 0) { let promises = []; let batch = items.splice(0, batchSize); promises = batch.map(item => this.update(item, authContext)); let results = await Promise.allSettled(promises); results.forEach(result => { if (result.status == "fulfilled") { success += 1; updateItems.push(result.value); } }); console.log(`${success}/${totalToUpdate}`); } return updateItems; } async parallelBatchPut(inputItems, batchSize = 1000, maxConcurrentSegments = 20, authContext) { let startTime = Date.now(); let items = []; items = items.concat(inputItems); items = items.map(item => { item.created_time = new Date(); item.created_user = authContext.userSub; return item; }); let maxSegments = []; let putItems = []; while (items.length > 0) { let batch = items.splice(0, batchSize * maxConcurrentSegments); let segment = []; while (batch.length > 0) { segment.push(batch.splice(0, batchSize)); } maxSegments.push(segment); } for (const segment of maxSegments) { let startTime = Date.now(); let promises = []; console.log(`batch length = ${segment.length}`); for (const batch of segment) { promises.push(this.batchPut(batch, authContext.userSub)); } let result = await Promise.all(promises); console.log("segment complete"); result.forEach((res) => { putItems = putItems.concat(res); }); console.log(`time for segment put ${Date.now() - startTime}`); } console.log(`total time for complete parallel put ${Date.now() - startTime}`); return putItems; } async parallelBatchDelete(inputItems, batchSize = 1000, maxConcurrentSegments = 20) { let startTime = Date.now(); let items = []; items = items.concat(inputItems); let maxSegments = []; let putItems = []; while (items.length > 0) { let batch = items.splice(0, batchSize * maxConcurrentSegments); let segment = []; while (batch.length > 0) { segment.push(batch.splice(0, batchSize)); } maxSegments.push(segment); } for (const segment of maxSegments) { let startTime = Date.now(); let promises = []; console.log(`batch length = ${segment.length}`); for (const batch of segment) { promises.push(this.batchDelete(batch)); } let result = await Promise.all(promises); console.log("segment complete"); result.forEach((res) => { putItems = putItems.concat(res); }); console.log(`time for segment delete ${Date.now() - startTime}`); } console.log(`total time for complete parallel delete ${Date.now() - startTime}`); return putItems; } /** * This function has to be used only in the scripts. * * @param valueConstructor the model class */ async parallelScan(valueConstructor, options) { let items = []; for await (const item of exports.mapper.parallelScan(valueConstructor, 4, options)) { items.push(item); if (items.length % 100000 == 0) { console.log("read 100K"); } } return items; } async scan(valueConstructor, options) { let items = []; for await (const item of exports.mapper.scan(valueConstructor, options)) { items.push(item); } return items; } async save(item, authContext) { item.created_time = new Date(); item.created_user = authContext.userSub; const res = await exports.mapper.put(item); return res; } async update(item, authContext) { item.updated_time = new Date(); item.updated_user = authContext.userSub; const res = await exports.mapper.update(item, { onMissing: "skip" }); return res; } async delete(item) { return await exports.mapper.delete(item, { returnValues: "ALL_OLD" }); } async get(item, readConsistency = "eventual") { const res = await exports.mapper.get(item, { readConsistency: readConsistency }); return res; } async batchPut(items, authContext) { let finalItems = []; items = items.map(item => { item.created_time = new Date(); item.created_user = authContext.userSub; return item; }); // console.log( "item:", items ) for await (const item of exports.mapper.batchPut(items)) { console.log(item); finalItems.push(item); } return finalItems; } async batchDelete(items) { let deleteItems = []; for await (const item of exports.mapper.batchDelete(items)) { deleteItems.push(item); } return deleteItems; } async batchGet(items, readConsistency = "eventual") { let getItems = []; for await (const item of exports.mapper.batchGet(items, { readConsistency: readConsistency })) { getItems.push(item); } return getItems; } async parallelBatchGet(inputItems, batchSize = 1000, maxConcurrentSegments = 20, readConsistency) { let startTime = Date.now(); let items = []; items = items.concat(inputItems); let maxSegments = []; let resultItems = []; while (items.length > 0) { let batch = items.splice(0, batchSize * maxConcurrentSegments); let segment = []; while (batch.length > 0) { segment.push(batch.splice(0, batchSize)); } maxSegments.push(segment); } for (const segment of maxSegments) { let startTime = Date.now(); let promises = []; console.log(`batch length = ${segment.length}`); for (const batch of segment) { promises.push(this.batchGet(batch, readConsistency)); } let result = await Promise.all(promises); console.log("segment complete"); result.forEach((res) => { resultItems = resultItems.concat(res); }); console.log(`time for segment get ${Date.now() - startTime}`); } console.log(`total time for complete parallel get ${Date.now() - startTime}`); return resultItems; } async parallelQuery(valueConstructor, keyConditions, maxConcurrentCalls = 20, options) { const startTime = Date.now(); const results = []; while (keyConditions.length > 0) { const segmentConditions = keyConditions.splice(0, maxConcurrentCalls); const queryPromises = segmentConditions.map((keyCondition) => { return this.customQuery(valueConstructor, keyCondition, options); }); const queryResults = await Promise.all(queryPromises); for (const queryResult of queryResults) { results.push(...queryResult); } } console.log(`total time for complete parallel query ${Date.now() - startTime}`); return results; } async customQuery(valueConstructor, keyConditions, options) { const startTime = Date.now(); const items = []; for await (const item of exports.mapper.query(valueConstructor, keyConditions, options)) { items.push(item); } console.log(`total time for complete query ${Date.now() - startTime}`); return items; } decode(continuationToken) { if (continuationToken) { try { let lastEvaluatedKey = JSON.parse(Buffer.from(continuationToken, 'base64').toString('utf8')); console.log("Incoming Last Evaluated Key " + lastEvaluatedKey); return lastEvaluatedKey; } catch (error) { throw new Error('Invalid continuationToken'); } } return undefined; } async encode(lastEvaluatedKey) { return Buffer.from(JSON.stringify(lastEvaluatedKey)).toString('base64'); } } exports.GenericDAO = GenericDAO; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-dao.js","sourceRoot":"","sources":["../src/base-dao.ts"],"names":[],"mappings":"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","sourcesContent":["import { DynamoDB } from '@aws-sdk/client-dynamodb';\nimport {\n    DataMapper,\n    ParallelScanOptions,\n    ParallelScanWorkerOptions,\n    QueryOptions,\n    ReadConsistency,\n    ScanOptions\n} from '@nova-odm/mapper';\nimport { ZeroArgumentsConstructor } from '@nova-odm/marshaller';\nimport { ConditionExpression, ConditionExpressionPredicate } from '@nova-odm/expressions';\nimport { BaseModel } from './base-model';\n\n\nexport const dynamoDB = new DynamoDB({\n    maxAttempts: 10\n}) as any\nexport const mapper = new DataMapper({ client: dynamoDB });\n\nexport class GenericDAO<T extends BaseModel> {\n    async batchUpdate(items: T[], batchSize = 100, authContext?: any): Promise<T[]> {\n        let success = 0, totalToUpdate = items.length\n        let updateItems: T[] = []\n        while (items.length > 0) {\n            let promises = []\n            let batch = items.splice(0, batchSize)\n            promises = batch.map(item => this.update(item, authContext))\n            let results = await Promise.allSettled(promises)\n            results.forEach(result => {\n                if (result.status == \"fulfilled\") {\n                    success += 1\n                    updateItems.push(result.value)\n                }\n            })\n            console.log(`${success}/${totalToUpdate}`)\n        }\n        return updateItems\n    }\n\n    async parallelBatchPut(inputItems: T[], batchSize: number = 1000, maxConcurrentSegments: number = 20, authContext?: any): Promise<T[]> {\n        let startTime = Date.now()\n        let items: T[] = []\n        items = items.concat(inputItems)\n        items = items.map(item => {\n            item.created_time = new Date()\n            item.created_user = authContext.userSub\n            return item\n        })\n        let maxSegments: T[][][] = []\n        let putItems: T[] = []\n        while (items.length > 0) {\n            let batch = items.splice(0, batchSize * maxConcurrentSegments)\n            let segment: T[][] = []\n            while (batch.length > 0) {\n                segment.push(batch.splice(0, batchSize))\n            }\n            maxSegments.push(segment)\n        }\n        for (const segment of maxSegments) {\n            let startTime = Date.now()\n            let promises: Promise<T[]>[] = []\n            console.log(`batch length = ${segment.length}`)\n            for (const batch of segment) {\n                promises.push(this.batchPut(batch, authContext.userSub))\n            }\n            let result = await Promise.all(promises)\n            console.log(\"segment complete\")\n            result.forEach((res) => {\n                putItems = putItems.concat(res)\n            })\n            console.log(`time for segment put ${Date.now() - startTime}`)\n        }\n        console.log(`total time for complete parallel put ${Date.now() - startTime}`)\n        return putItems\n    }\n\n    async parallelBatchDelete(inputItems: T[], batchSize: number = 1000, maxConcurrentSegments: number = 20): Promise<T[]> {\n        let startTime = Date.now()\n        let items: T[] = []\n        items = items.concat(inputItems)\n        let maxSegments: T[][][] = []\n        let putItems: T[] = []\n        while (items.length > 0) {\n            let batch = items.splice(0, batchSize * maxConcurrentSegments)\n            let segment: T[][] = []\n            while (batch.length > 0) {\n                segment.push(batch.splice(0, batchSize))\n            }\n            maxSegments.push(segment)\n        }\n        for (const segment of maxSegments) {\n            let startTime = Date.now()\n            let promises: Promise<T[]>[] = []\n            console.log(`batch length = ${segment.length}`)\n            for (const batch of segment) {\n                promises.push(this.batchDelete(batch))\n            }\n            let result = await Promise.all(promises)\n            console.log(\"segment complete\")\n            result.forEach((res) => {\n                putItems = putItems.concat(res)\n            })\n            console.log(`time for segment delete ${Date.now() - startTime}`)\n        }\n        console.log(`total time for complete parallel delete ${Date.now() - startTime}`)\n        return putItems\n    }\n\n    /**\n     * This function has to be used only in the scripts.\n     * \n     * @param valueConstructor the model class\n     */\n    async parallelScan(valueConstructor: ZeroArgumentsConstructor<T>, options?: ParallelScanOptions): Promise<T[]> {\n        let items: T[] = []\n        for await (const item of mapper.parallelScan(valueConstructor, 4, options)) {\n            items.push(item)\n            if (items.length % 100000 == 0) {\n                console.log(\"read 100K\")\n            }\n        }\n        return items\n    }\n\n    async scan(valueConstructor: ZeroArgumentsConstructor<T>, options?: ScanOptions | ParallelScanWorkerOptions): Promise<T[]> {\n        let items: T[] = []\n        for await (const item of mapper.scan(valueConstructor, options)) {\n            items.push(item)\n        }\n        return items\n    }\n\n    async save(item: T, authContext?: any): Promise<T> {\n        item.created_time = new Date()\n        item.created_user = authContext.userSub\n        const res = await mapper.put(item)\n        return res\n    }\n\n    async update(item: T, authContext?: any): Promise<T> {\n        item.updated_time = new Date()\n        item.updated_user = authContext.userSub\n        const res = await mapper.update(item, {\n            onMissing: \"skip\"\n        })\n        return res\n    }\n\n    async delete(item: T): Promise<T | undefined> {\n        return await mapper.delete(item, { returnValues: \"ALL_OLD\" })\n    }\n\n    async get(item: T, readConsistency: ReadConsistency = \"eventual\"): Promise<T> {\n        const res = await mapper.get(item, {\n            readConsistency: readConsistency\n        })\n        return res\n    }\n\n    async batchPut(items: T[], authContext?: any): Promise<T[]> {\n\n        let finalItems: T[] = []\n        items = items.map(item => {\n            item.created_time = new Date()\n            item.created_user = authContext.userSub\n            return item\n        })\n        // console.log( \"item:\", items )\n        for await (const item of mapper.batchPut(items)) {\n            console.log(item)\n            finalItems.push(item)\n        }\n        return finalItems\n    }\n\n    async batchDelete(items: T[]): Promise<T[]> {\n        let deleteItems: T[] = []\n        for await (const item of mapper.batchDelete(items)) {\n            deleteItems.push(item)\n        }\n        return deleteItems\n    }\n\n    async batchGet(items: T[], readConsistency: ReadConsistency = \"eventual\"): Promise<T[]> {\n        let getItems: T[] = []\n        for await (const item of mapper.batchGet(items, {\n            readConsistency: readConsistency\n        })) {\n            getItems.push(item)\n        }\n        return getItems\n    }\n\n    async parallelBatchGet(inputItems: T[], batchSize: number = 1000, maxConcurrentSegments: number = 20, readConsistency?: ReadConsistency): Promise<T[]> {\n        let startTime = Date.now()\n        let items: T[] = []\n        items = items.concat(inputItems)\n        let maxSegments: T[][][] = []\n        let resultItems: T[] = []\n        while (items.length > 0) {\n            let batch = items.splice(0, batchSize * maxConcurrentSegments)\n            let segment: T[][] = []\n            while (batch.length > 0) {\n                segment.push(batch.splice(0, batchSize))\n            }\n            maxSegments.push(segment)\n        }\n        for (const segment of maxSegments) {\n            let startTime = Date.now()\n            let promises: Promise<T[]>[] = []\n            console.log(`batch length = ${segment.length}`)\n            for (const batch of segment) {\n                promises.push(this.batchGet(batch, readConsistency))\n            }\n            let result = await Promise.all(promises)\n            console.log(\"segment complete\")\n            result.forEach((res) => {\n                resultItems = resultItems.concat(res)\n            })\n            console.log(`time for segment get ${Date.now() - startTime}`)\n        }\n        console.log(`total time for complete parallel get ${Date.now() - startTime}`)\n        return resultItems\n    }\n    async parallelQuery(\n        valueConstructor: ZeroArgumentsConstructor<T>,\n        keyConditions: Array<ConditionExpression | { [propertyName: string]: ConditionExpressionPredicate | any }>,\n        maxConcurrentCalls: number = 20,\n        options?: QueryOptions,\n\n    ): Promise<T[]> {\n        const startTime = Date.now()\n        const results: T[] = []\n        while (keyConditions.length > 0) {\n            const segmentConditions = keyConditions.splice(0, maxConcurrentCalls)\n            const queryPromises = segmentConditions.map((keyCondition) => {\n                return this.customQuery(valueConstructor, keyCondition, options)\n            }\n\n            )\n            const queryResults = await Promise.all(queryPromises)\n\n            for (const queryResult of queryResults) {\n                results.push(...queryResult)\n            }\n        }\n        console.log(`total time for complete parallel query ${Date.now() - startTime}`)\n        return results\n    }\n    private async customQuery(\n        valueConstructor: ZeroArgumentsConstructor<T>,\n        keyConditions: ConditionExpression | { [propertyName: string]: ConditionExpressionPredicate | any },\n        options?: QueryOptions\n    ): Promise<T[]> {\n        const startTime = Date.now()\n        const items: T[] = []\n\n        for await (const item of mapper.query(valueConstructor, keyConditions, options)) {\n            items.push(item)\n        }\n        console.log(`total time for complete query ${Date.now() - startTime}`)\n\n        return items\n    }\n    decode(continuationToken: string | undefined) {\n        if (continuationToken) {\n            try {\n                let lastEvaluatedKey = JSON.parse(Buffer.from(continuationToken, 'base64').toString('utf8'));\n                console.log(\"Incoming Last Evaluated Key \" + lastEvaluatedKey);\n                return lastEvaluatedKey;\n            } catch (error) {\n                throw new Error('Invalid continuationToken');\n            }\n        }\n        return undefined\n    }\n\n    async encode(lastEvaluatedKey: any): Promise<string> {\n        return Buffer.from(JSON.stringify(lastEvaluatedKey)).toString('base64')\n    }\n}"]}