UNPKG

@golemio/parkings

Version:
71 lines 4.14 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.UpdateAddressAndNameTask = void 0; const ModuleContainerToken_1 = require("../../ioc/ModuleContainerToken"); const ParkingsRepository_1 = require("../../repositories/ParkingsRepository"); const constants_1 = require("../constants"); const UpdateAddressSchema_1 = require("../schemas/UpdateAddressSchema"); const CoreToken_1 = require("@golemio/core/dist/helpers/ioc/CoreToken"); const integration_engine_1 = require("@golemio/core/dist/integration-engine"); const GeocodeApi_1 = require("@golemio/core/dist/integration-engine/helpers/GeocodeApi"); const ioc_1 = require("@golemio/core/dist/integration-engine/ioc"); const tsyringe_1 = require("@golemio/core/dist/shared/tsyringe"); let UpdateAddressAndNameTask = exports.UpdateAddressAndNameTask = class UpdateAddressAndNameTask extends integration_engine_1.AbstractTask { constructor(log, geocodeApi, repository) { super(constants_1.NEW_PARKINGS_WORKER_NAME); this.log = log; this.geocodeApi = geocodeApi; this.repository = repository; this.queueName = "updateAddressAndName"; this.queueTtl = 60 * 60 * 1000; // 1h this.schema = UpdateAddressSchema_1.UpdateAddressValidationSchema; } async execute(data) { const now = Date.now(); try { const address = (await this.geocodeApi.getExtendedAddressFromPhoton(data.point.coordinates[1], data.point.coordinates[0])); const name = this.buildName(address, data); await this.repository.update({ address, name, address_updated_at: now }, { where: { id: data.id }, fields: ["address", "name", "address_updated_at"] }); } catch (err) { this.log.error( // eslint-disable-next-line max-len `Error while updating address: ${data?.name} [${data?.point?.coordinates[1]},${data?.point?.coordinates[0]}] ${err}`); await this.postponeNextCheck(data.id); } } buildName(address, data) { return `${data.name} ${address.street_address}, ${address.address_region}`; } // temporary solution to decrease the number of requests to the geocoding service. Should be solved in // https://gitlab.com/operator-ict/golemio/code/modules/core/-/issues/120 async postponeNextCheck(parkingId) { try { await this.repository.update({ address_updated_at: Date.now() }, { where: { id: parkingId }, fields: ["address_updated_at"] }); } catch (err) { this.log.error(`Error while postponing next check for parking and name with id ${parkingId} ${err}`); } } }; exports.UpdateAddressAndNameTask = UpdateAddressAndNameTask = __decorate([ (0, tsyringe_1.injectable)(), __param(0, (0, tsyringe_1.inject)(CoreToken_1.CoreToken.Logger)), __param(1, (0, tsyringe_1.inject)(ioc_1.ContainerToken.GeocodeApi)), __param(2, (0, tsyringe_1.inject)(ModuleContainerToken_1.ModuleContainerToken.ParkingsRepository)), __metadata("design:paramtypes", [Object, GeocodeApi_1.GeocodeApi, ParkingsRepository_1.ParkingsRepository]) ], UpdateAddressAndNameTask); //# sourceMappingURL=UpdateAddressAndNameTask.js.map