UNPKG

@qbcart/cosmos

Version:

Azure Cosmos DB access common across the QBCart node ecosystem.

122 lines (121 loc) 3.48 kB
/*********************************************** * @license * Copyright (c) QBCart Inc. All rights reserved. ************************************************/ export default class Base { container; constructor(container) { this.container = container; } async read(id, partitionKey) { try { const { resource: item } = await this.container .item(id, partitionKey) .read(); return item; } catch (error) { return null; } } async queryFirst(query, partitionKey) { try { const { resources: items } = await this.container.items .query(query, { bufferItems: true, partitionKey: partitionKey }) .fetchAll(); return items[0]; } catch (error) { console.error(error); return null; } } async queryAll(query, partitionKey) { try { const { resources: items } = await this.container.items .query(query, { bufferItems: true, partitionKey: partitionKey }) .fetchAll(); return items; } catch (error) { console.error(error); return []; } } async create(object) { try { object.Created = new Date(); const { resource: item } = await this.container.items.create(object); return item; } catch (error) { return null; } } async upsert(object) { try { const { resource: item } = await this.container.items.upsert(object); return item; } catch (error) { return null; } } async replace(object) { try { const { resource: item } = await this.container .item(object.id, object.Discriminator) .replace(object); return item; } catch (error) { return null; } } async safeReplace(object) { let retry = 9; while (retry--) try { const { resource: item } = await this.container .item(object.id, object.Discriminator) .replace(object, { accessCondition: { type: 'IfMatch', condition: object._etag } }); return item; } catch (error) { if (error.code == 412) { continue; } else { return null; } } } async delete(object) { try { const { resource: item } = await this.container .item(object.id, object.Discriminator) .delete(); return item; } catch (error) { return null; } } async sync(returnProps, filter, partitionKey, lastSynced) { try { const query = lastSynced ? `SELECT ${returnProps.join()} FROM c WHERE c._ts > ${lastSynced}` : `SELECT ${returnProps.join()} FROM c WHERE ${filter}`; return (await this.queryAll(query, partitionKey)) ?? []; } catch (error) { console.log(error); return []; } } }