@golemio/pid
Version:
Golemio PID Module
107 lines • 6.57 kB
JavaScript
;
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.RopidDeparturesPresetsRoutesRepository = void 0;
const const_1 = require("../../../schema-definitions/const");
const RopidDeparturesPresetsRoutesModel_1 = require("../../../schema-definitions/jis/models/RopidDeparturesPresetsRoutesModel");
const precomputed_1 = require("../../../schema-definitions/ropid-gtfs/models/precomputed");
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_errors_1 = require("@golemio/core/dist/shared/golemio-errors");
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 RopidDeparturesPresetsRopidGTFSStopsRepository_1 = require("./RopidDeparturesPresetsRopidGTFSStopsRepository");
const RopidGtfsContainerToken_1 = require("../../ropid-gtfs/ioc/RopidGtfsContainerToken");
let RopidDeparturesPresetsRoutesRepository = class RopidDeparturesPresetsRoutesRepository extends AbstractValidatableRepository_1.AbstractValidatableRepository {
constructor(connector, logger, presetsStopsRepository) {
super(connector, logger);
this.schema = const_1.PG_SCHEMA;
this.tableName = RopidDeparturesPresetsRoutesModel_1.RopidDeparturesPresetsRoutesModel.tableName;
this.validator = new golemio_validator_1.JSONSchemaValidator("RopidDeparturesPresetsRoutesRepository", RopidDeparturesPresetsRoutesModel_1.RopidDeparturesPresetsRoutesModel.jsonSchema);
const db = connector.getConnection();
this.sequelizeModel = db.define(RopidDeparturesPresetsRoutesModel_1.RopidDeparturesPresetsRoutesModel.tableName, RopidDeparturesPresetsRoutesModel_1.RopidDeparturesPresetsRoutesModel.attributeModel, { schema: this.schema });
this.junctionModel = presetsStopsRepository.sequelizeModel;
this.departuresModel = db.define(precomputed_1.DeparturesModel.TABLE_NAME, precomputed_1.DeparturesModel.attributeModel, { schema: this.schema });
this.junctionModel.hasMany(this.departuresModel, {
foreignKey: "stop_id",
sourceKey: "stop_id",
as: "departures",
constraints: false,
});
}
async findAllWithRoutes() {
// https://github.com/sequelize/sequelize/issues/2996
return (await this.junctionModel.findAll({
attributes: [
[
sequelize_1.Sequelize.literal(`DISTINCT ON(
"ropid_departures_presets_ropidgtfs_stops"."preset_id",
"ropid_departures_presets_ropidgtfs_stops"."stop_id",
"departures"."route_id"
) "ropid_departures_presets_ropidgtfs_stops"."preset_id"`),
"preset_id",
],
[sequelize_1.Sequelize.literal('"ropid_departures_presets_ropidgtfs_stops"."stop_id"'), "stop_id"],
[sequelize_1.Sequelize.literal('"departures"."route_id"'), "route_id"],
[sequelize_1.Sequelize.literal('"departures"."route_type"'), "route_type"],
[sequelize_1.Sequelize.literal('"departures"."route_short_name"'), "route_short_name"],
],
include: [
{
model: this.departuresModel,
as: "departures",
attributes: [],
required: true,
},
],
order: [
[sequelize_1.Sequelize.literal('"ropid_departures_presets_ropidgtfs_stops"."preset_id"'), "ASC"],
[sequelize_1.Sequelize.literal('"ropid_departures_presets_ropidgtfs_stops"."stop_id"'), "ASC"],
[sequelize_1.Sequelize.literal('"departures"."route_id"'), "ASC"],
],
raw: true,
}));
}
async refreshData(data) {
const transaction = await this.connector.getConnection().transaction();
try {
const updateTime = new Date();
await this.sequelizeModel.bulkCreate(data, {
updateOnDuplicate: ["route_type", "route_short_name", "updated_at"],
transaction,
});
await this.sequelizeModel.destroy({
where: {
updated_at: { [sequelize_1.Op.lt]: updateTime },
},
transaction,
});
await transaction.commit();
}
catch (error) {
await transaction.rollback();
throw new golemio_errors_1.GeneralError("Error in refreshData", this.constructor.name, error);
}
}
};
exports.RopidDeparturesPresetsRoutesRepository = RopidDeparturesPresetsRoutesRepository;
exports.RopidDeparturesPresetsRoutesRepository = RopidDeparturesPresetsRoutesRepository = __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)),
__param(2, (0, tsyringe_1.inject)(RopidGtfsContainerToken_1.RopidGtfsContainerToken.RopidDeparturesPresetsRopidGTFSStopsRepository)),
__metadata("design:paramtypes", [Object, Object, RopidDeparturesPresetsRopidGTFSStopsRepository_1.RopidDeparturesPresetsRopidGTFSStopsRepository])
], RopidDeparturesPresetsRoutesRepository);
//# sourceMappingURL=RopidDeparturesPresetsRoutesRepository.js.map