UNPKG

@citrineos/data

Version:

The OCPP data module which includes all persistence layer implementation.

93 lines 4.03 kB
"use strict"; // Copyright Contributors to the CitrineOS Project // // SPDX-License-Identifier: Apache 2.0 var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; Object.defineProperty(exports, "__esModule", { value: true }); exports.SequelizeTariffRepository = void 0; const Base_1 = require("./Base"); const Tariff_1 = require("../model/Tariff"); const sequelize_1 = require("sequelize"); class SequelizeTariffRepository extends Base_1.SequelizeRepository { constructor(config, logger, sequelizeInstance) { super(config, Tariff_1.Tariff.MODEL_NAME, logger, sequelizeInstance); } findByStationIds(tenantId, stationIds) { const _super = Object.create(null, { readAllByQuery: { get: () => super.readAllByQuery } }); return __awaiter(this, void 0, void 0, function* () { return _super.readAllByQuery.call(this, tenantId, { where: { stationId: { [sequelize_1.Op.in]: stationIds, }, }, }); }); } findByStationId(tenantId, stationId) { const _super = Object.create(null, { readOnlyOneByQuery: { get: () => super.readOnlyOneByQuery } }); return __awaiter(this, void 0, void 0, function* () { return _super.readOnlyOneByQuery.call(this, tenantId, { where: { stationId: stationId, }, }); }); } upsertTariff(tenantId, tariff) { return __awaiter(this, void 0, void 0, function* () { tariff.tenantId = tenantId; return yield this.s.transaction((transaction) => __awaiter(this, void 0, void 0, function* () { const savedTariff = yield this.readOnlyOneByQuery(tenantId, { where: { id: tariff.id }, transaction, }); if (savedTariff) { const updatedTariff = yield savedTariff.set(tariff.data).save({ transaction }); this.emit('updated', [updatedTariff]); return updatedTariff; } const createdTariff = yield tariff.save({ transaction }); this.emit('created', [createdTariff]); return createdTariff; })); }); } readAllByQuerystring(tenantId, query) { const _super = Object.create(null, { readAllByQuery: { get: () => super.readAllByQuery } }); return __awaiter(this, void 0, void 0, function* () { return _super.readAllByQuery.call(this, tenantId, { where: Object.assign({}, (query.id && { id: query.id })), }); }); } deleteAllByQuerystring(tenantId, query) { const _super = Object.create(null, { deleteAllByQuery: { get: () => super.deleteAllByQuery } }); return __awaiter(this, void 0, void 0, function* () { if (!query.id) { throw new Error('Must specify at least one query parameter'); } return _super.deleteAllByQuery.call(this, tenantId, { where: Object.assign({}, (query.id && { id: query.id })), }); }); } } exports.SequelizeTariffRepository = SequelizeTariffRepository; //# sourceMappingURL=Tariff.js.map