UNPKG

@golemio/pid

Version:
89 lines 5.12 kB
"use strict"; var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; var __param = (this && this.__param) || function (paramIndex, decorator) { return function (target, key) { decorator(target, key, paramIndex); } }; Object.defineProperty(exports, "__esModule", { value: true }); exports.JISInfotextsPresetsRepository = void 0; const const_1 = require("../../../schema-definitions/const"); const JISInfotextsPresetsModel_1 = require("../../../schema-definitions/jis/models/JISInfotextsPresetsModel"); const AbstractValidatableRepository_1 = require("@golemio/core/dist/helpers/data-access/postgres/repositories/AbstractValidatableRepository"); const CoreToken_1 = require("@golemio/core/dist/helpers/ioc/CoreToken"); const golemio_validator_1 = require("@golemio/core/dist/shared/golemio-validator"); const sequelize_1 = require("@golemio/core/dist/shared/sequelize"); const tsyringe_1 = require("@golemio/core/dist/shared/tsyringe"); const RepositoryUtils_1 = require("../../shared/RepositoryUtils"); let JISInfotextsPresetsRepository = class JISInfotextsPresetsRepository extends AbstractValidatableRepository_1.AbstractValidatableRepository { constructor(connector, logger) { super(connector, logger); this.schema = const_1.PG_SCHEMA; this.tableName = JISInfotextsPresetsModel_1.JISInfotextsPresetsModel.tableName; this.validator = new golemio_validator_1.JSONSchemaValidator("JISInfotextsPresetsRepository", JISInfotextsPresetsModel_1.JISInfotextsPresetsModel.jsonSchema); this.sequelizeModel = connector .getConnection() .define(this.tableName, JISInfotextsPresetsModel_1.JISInfotextsPresetsModel.attributeModel, { schema: this.schema }); } /** * Inserts new rows or updates existing ones. On conflict, all columns except `created_at` are overwritten — * `created_at` is intentionally preserved to track when a row was first seen, while `updated_at` advances * each cycle so stale-record cleanup can identify entries missing from the latest feed. */ async upsertAll(data, options) { try { return await this.sequelizeModel.bulkCreate(data, { updateOnDuplicate: this.getUpdateAttributes(), transaction: options?.transaction, }); } catch (err) { throw RepositoryUtils_1.RepositoryUtils.mapSequelizeError(err, this.constructor.name, "upsertAll"); } } /** * Removes rows that were not touched during the current refresh cycle — any row whose `updated_at` * predates `dateTime` was absent from the latest feed and is considered stale. * Call this after `upsertAll` with the timestamp captured at the start of the save to clean up vanished entries. */ async deleteAllLastUpdatedBefore(dateTime, options) { try { return await this.sequelizeModel.destroy({ where: { updated_at: { [sequelize_1.Op.lt]: dateTime }, }, transaction: options?.transaction, }); } catch (err) { throw RepositoryUtils_1.RepositoryUtils.mapSequelizeError(err, this.constructor.name, "deleteAllLastUpdatedBefore"); } } async deleteAll(options) { try { return await this.sequelizeModel.destroy({ where: {}, transaction: options?.transaction }); } catch (err) { throw RepositoryUtils_1.RepositoryUtils.mapSequelizeError(err, this.constructor.name, "deleteAll"); } } // created_at is excluded so that re-upserting an existing row doesn't overwrite // when it was first seen — only updated_at should advance on subsequent refreshes. getUpdateAttributes() { return Object.keys(JISInfotextsPresetsModel_1.JISInfotextsPresetsModel.attributeModel).filter((attribute) => attribute !== "created_at"); } }; exports.JISInfotextsPresetsRepository = JISInfotextsPresetsRepository; exports.JISInfotextsPresetsRepository = JISInfotextsPresetsRepository = __decorate([ (0, tsyringe_1.injectable)(), __param(0, (0, tsyringe_1.inject)(CoreToken_1.CoreToken.PostgresConnector)), __param(1, (0, tsyringe_1.inject)(CoreToken_1.CoreToken.Logger)), __metadata("design:paramtypes", [Object, Object]) ], JISInfotextsPresetsRepository); //# sourceMappingURL=JISInfotextsPresetsRepository.js.map