UNPKG

@golemio/pid

Version:
58 lines 4.04 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.RefreshDescriptorsTask = void 0; const VPContainerToken_1 = require("../../../ioc/VPContainerToken"); const integration_engine_1 = require("@golemio/core/dist/integration-engine"); const ContainerToken_1 = require("@golemio/core/dist/integration-engine/ioc/ContainerToken"); const tsyringe_1 = require("@golemio/core/dist/shared/tsyringe"); const constants_1 = require("../constants"); const DescriptorRepository_1 = require("../data-access/DescriptorRepository"); const DescriptorDataSourceFactory_1 = require("../datasources/DescriptorDataSourceFactory"); const DescriptorTransformation_1 = require("../transformations/DescriptorTransformation"); let RefreshDescriptorsTask = exports.RefreshDescriptorsTask = class RefreshDescriptorsTask extends integration_engine_1.AbstractEmptyTask { constructor(dataSourceFactory, descriptorFilter, descriptorRepository, descriptorTransformation, logger) { super(constants_1.WORKER_NAME); this.dataSourceFactory = dataSourceFactory; this.descriptorFilter = descriptorFilter; this.descriptorRepository = descriptorRepository; this.descriptorTransformation = descriptorTransformation; this.logger = logger; this.queueName = "refreshDescriptors"; this.queueTtl = 10 * 60 * 1000; // 10 minutes } async execute() { const dataSource = this.dataSourceFactory.getDataSource(DescriptorDataSourceFactory_1.DescriptorProvider.SeznamAutobusu); const descriptorsResult = await dataSource.getAll(); const descriptorsTransformed = await this.descriptorTransformation.transform(descriptorsResult); const descriptorsFiltered = [...this.descriptorFilter.yieldFilteredDescriptors(descriptorsTransformed)]; if (descriptorsFiltered.length === 0) { this.logger.warn(`${this.queueName}: no descriptors out of ${descriptorsResult.length} were transformed or were filtered out`); return; } await this.descriptorRepository.saveData(descriptorsFiltered); this.logger.info(`${this.queueName}: ${descriptorsFiltered.length}/${descriptorsResult.length} vehicle descriptors were saved`); } }; exports.RefreshDescriptorsTask = RefreshDescriptorsTask = __decorate([ (0, tsyringe_1.injectable)(), __param(0, (0, tsyringe_1.inject)(VPContainerToken_1.VPContainerToken.DescriptorDataSourceFactory)), __param(1, (0, tsyringe_1.inject)(VPContainerToken_1.VPContainerToken.DescriptorFilter)), __param(2, (0, tsyringe_1.inject)(VPContainerToken_1.VPContainerToken.DescriptorRepository)), __param(3, (0, tsyringe_1.inject)(VPContainerToken_1.VPContainerToken.DescriptorTransformation)), __param(4, (0, tsyringe_1.inject)(ContainerToken_1.ContainerToken.Logger)), __metadata("design:paramtypes", [DescriptorDataSourceFactory_1.DescriptorDataSourceFactory, Object, DescriptorRepository_1.DescriptorRepository, DescriptorTransformation_1.DescriptorTransformation, Object]) ], RefreshDescriptorsTask); //# sourceMappingURL=RefreshDescriptorsTask.js.map