@golemio/pid
Version:
Golemio PID Module
58 lines • 4.04 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.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