UNPKG

@golemio/pid

Version:
133 lines 8.93 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.CheckSavedRowsAndReplaceTablesTask = void 0; const RopidGtfsFacade_1 = require("../../../RopidGtfsFacade"); const RopidGtfsMetadataRepository_1 = require("../../../RopidGtfsMetadataRepository"); const RopidGtfsRepository_1 = require("../../../data-access/RopidGtfsRepository"); const DataCacheManager_1 = require("../../../helpers/DataCacheManager"); const SourceTableSuffixEnum_1 = require("../../../helpers/SourceTableSuffixEnum"); const RopidGtfsContainerToken_1 = require("../../../ioc/RopidGtfsContainerToken"); const constants_1 = require("../../../../vehicle-positions/workers/vehicle-positions/constants"); const CoreToken_1 = require("@golemio/core/dist/helpers/ioc/CoreToken"); const integration_engine_1 = require("@golemio/core/dist/integration-engine"); const workers_1 = require("@golemio/core/dist/integration-engine/workers"); const golemio_errors_1 = require("@golemio/core/dist/shared/golemio-errors"); const tsyringe_1 = require("@golemio/core/dist/shared/tsyringe"); const constants_2 = require("../constants"); const PrecomputedTablesFacade_1 = require("./helpers/PrecomputedTablesFacade"); const DownloadDataInputSchema_1 = require("./schema/DownloadDataInputSchema"); let CheckSavedRowsAndReplaceTablesTask = class CheckSavedRowsAndReplaceTablesTask extends workers_1.AbstractTask { constructor(metadataRepository, ropidGtfsRepository, precomputeTablesFacade, ropidGtfsFacade, config, logger) { super(constants_2.TIMETABLE_WORKER_NAME); this.metadataRepository = metadataRepository; this.ropidGtfsRepository = ropidGtfsRepository; this.precomputeTablesFacade = precomputeTablesFacade; this.ropidGtfsFacade = ropidGtfsFacade; this.config = config; this.logger = logger; this.queueName = "checkSavedRowsAndReplaceTables"; this.queueTtl = 23 * 60 * 60 * 1000; // 23 hours this.schema = DownloadDataInputSchema_1.DatasetsInputSchema; this.dataCacheManager = DataCacheManager_1.DataCacheManager.getInstance(); } async execute(data) { const { notDeployed, datasetDeployInfo } = await this.getDatasetsToDeploy(data); if (data.datasets.length !== notDeployed.length) { const names = notDeployed.map((el) => el.dataset); this.logger.error(`Error while synchronized download of datasets: [${names}] of [${data.datasets}] deployed already`); } if (!notDeployed.length) { this.logger.debug(`Datasets status: already deployed`); return; } const notDeployedVersions = notDeployed.map((el) => ({ dataset: el.dataset, version: el.lastModified.version })); const allSaved = await this.metadataRepository.checkAllTablesHasSavedState(notDeployedVersions); try { await this.checkSavedRows(allSaved, datasetDeployInfo); await this.precomputeTablesFacade.createAndPopulatePrecomputedTmpTables(SourceTableSuffixEnum_1.SourceTableSuffixEnum.Tmp); await this.ropidGtfsFacade.replaceTables(notDeployedVersions); await this.dataCacheManager.cleanCache(); await this.ropidGtfsRepository.cleanTmpAndOldTables(); const rabbitExchangeName = this.config.getValue("env.RABBIT_EXCHANGE_NAME"); await Promise.all([ // send message to VP worker to refresh GTFS trip data (see task description for more info) integration_engine_1.QueueManager.sendMessageToExchange(`${rabbitExchangeName}.${constants_1.WORKER_NAME.toLowerCase()}`, "refreshGTFSTripData", {}), // send message to GTFS timetable worker to refresh public GTFS departure cache // so that the new data is available in the public (Lítačka) API integration_engine_1.QueueManager.sendMessageToExchange(this.queuePrefix, "refreshPublicGtfsDepartureCache", {}), integration_engine_1.QueueManager.sendMessageToExchange(this.queuePrefix, "refreshGtfsStopsCache", {}), integration_engine_1.QueueManager.sendMessageToExchange(this.queuePrefix, "refreshGtfsTripStopsCache", {}), integration_engine_1.QueueManager.sendMessageToExchange(this.queuePrefix, "remapPresetsToGtfsStops", {}), ]); } catch (err) { await this.retryOrThrow(notDeployedVersions, data, err); } } async retryOrThrow(notDeployedVersions, data, err) { // log failed saving process await Promise.all(notDeployedVersions.map(async (el) => { await this.metadataRepository.rollbackFailedSaving(el.dataset, el.version); })); // check number of tries const retries = await Promise.all(notDeployedVersions.map(async (el) => { return await this.metadataRepository.getNumberOfDownloadRetries(el.dataset, el.version); })); await this.ropidGtfsRepository.cleanTmpAndOldTables(); if (Math.max(...retries) <= 5) { // send new downloadFiles, log it and finish integration_engine_1.QueueManager.sendMessageToExchange(this.queuePrefix, "downloadDatasets", data); integration_engine_1.IntegrationErrorHandler.handle(new golemio_errors_1.GeneralError(`Error while checking RopidGTFS saved rows. Attempt number ${Math.min(...retries)} was resent.`, this.constructor.name, err)); } else { // at least refresh precomputed tables and finish with error integration_engine_1.QueueManager.sendMessageToExchange(this.queuePrefix, "refreshPrecomputedTables", {}); throw new golemio_errors_1.GeneralError("Error while checking RopidGTFS saved rows.", this.constructor.name, err); } } async checkSavedRows(allSaved, datasetDeployInfo) { if (!allSaved) { throw new golemio_errors_1.GeneralError("Some GTFS datasets did not properly save", this.constructor.name); } await Promise.all(datasetDeployInfo.map(async (el) => { await this.ropidGtfsFacade.checkSavedTmpTables(el.dataset, el.lastModified.version); })); } async getDatasetsToDeploy(data) { const datasetDeployInfo = await Promise.all(data.datasets.map(async (dataset) => { const lastModified = await this.metadataRepository.getLastModified(dataset); const isDeployed = await this.metadataRepository.checkIfNewVersionIsAlreadyDeployed(dataset, lastModified.version); return { dataset, lastModified, isDeployed }; })); this.logger.debug(`Datasets status: ${JSON.stringify(datasetDeployInfo)}`); const notDeployed = datasetDeployInfo.filter((info) => !info.isDeployed); return { notDeployed, datasetDeployInfo }; } }; exports.CheckSavedRowsAndReplaceTablesTask = CheckSavedRowsAndReplaceTablesTask; exports.CheckSavedRowsAndReplaceTablesTask = CheckSavedRowsAndReplaceTablesTask = __decorate([ (0, tsyringe_1.injectable)(), __param(0, (0, tsyringe_1.inject)(RopidGtfsContainerToken_1.RopidGtfsContainerToken.RopidGtfsMetadataRepository)), __param(1, (0, tsyringe_1.inject)(RopidGtfsContainerToken_1.RopidGtfsContainerToken.RopidGtfsRepository)), __param(2, (0, tsyringe_1.inject)(RopidGtfsContainerToken_1.RopidGtfsContainerToken.PrecomputedTablesFacade)), __param(3, (0, tsyringe_1.inject)(RopidGtfsContainerToken_1.RopidGtfsContainerToken.RopidGtfsFacade)), __param(4, (0, tsyringe_1.inject)(CoreToken_1.CoreToken.SimpleConfig)), __param(5, (0, tsyringe_1.inject)(CoreToken_1.CoreToken.Logger)), __metadata("design:paramtypes", [RopidGtfsMetadataRepository_1.RopidGtfsMetadataRepository, RopidGtfsRepository_1.RopidGtfsRepository, PrecomputedTablesFacade_1.PrecomputedTablesFacade, RopidGtfsFacade_1.RopidGtfsFacade, Object, Object]) ], CheckSavedRowsAndReplaceTablesTask); //# sourceMappingURL=CheckSavedRowsAndReplaceTablesTask.js.map