@golemio/municipal-libraries 1.0.5-dev.568966813 → 1.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/db/example/.config.json +3 -0
- package/db/example/00_truncate_tables.sql +7 -0
- package/db/example/01_libraries.sql +50 -0
- package/db/migrations/postgresql/.config.json +3 -0
- package/db/migrations/postgresql/20220916133717-init.js +53 -0
- package/db/migrations/postgresql/package.json +3 -0
- package/db/migrations/postgresql/sqls/20220916133717-init-down.sql +6 -0
- package/db/migrations/postgresql/sqls/20220916133717-init-up.sql +102 -0
- package/db/migrations/postgresql/sqls/package.json +3 -0
- package/dist/integration-engine/datasources/MunicipalLibrariesDataSource.d.ts +4 -0
- package/dist/integration-engine/datasources/MunicipalLibrariesDataSource.js +21 -0
- package/dist/integration-engine/datasources/MunicipalLibrariesDataSource.js.map +1 -0
- package/dist/integration-engine/datasources/index.d.ts +1 -0
- package/dist/integration-engine/datasources/index.js +19 -0
- package/dist/integration-engine/datasources/index.js.map +1 -0
- package/dist/integration-engine/index.d.ts +2 -3
- package/dist/integration-engine/index.js +5 -3
- package/dist/integration-engine/index.js.map +1 -1
- package/dist/integration-engine/repositories/DepartmentsRepository.d.ts +4 -0
- package/dist/integration-engine/repositories/DepartmentsRepository.js +19 -0
- package/dist/integration-engine/repositories/DepartmentsRepository.js.map +1 -0
- package/dist/integration-engine/repositories/LibraryDepartmentsRepository.d.ts +4 -0
- package/dist/integration-engine/repositories/LibraryDepartmentsRepository.js +19 -0
- package/dist/integration-engine/repositories/LibraryDepartmentsRepository.js.map +1 -0
- package/dist/integration-engine/repositories/LibraryServicesRepository.d.ts +4 -0
- package/dist/integration-engine/repositories/LibraryServicesRepository.js +19 -0
- package/dist/integration-engine/repositories/LibraryServicesRepository.js.map +1 -0
- package/dist/integration-engine/repositories/MunicipalLibrariesRepository.d.ts +16 -0
- package/dist/integration-engine/repositories/MunicipalLibrariesRepository.js +140 -0
- package/dist/integration-engine/repositories/MunicipalLibrariesRepository.js.map +1 -0
- package/dist/integration-engine/repositories/OpeningHoursRepository.d.ts +4 -0
- package/dist/integration-engine/repositories/OpeningHoursRepository.js +19 -0
- package/dist/integration-engine/repositories/OpeningHoursRepository.js.map +1 -0
- package/dist/integration-engine/repositories/ServicesRepository.d.ts +4 -0
- package/dist/integration-engine/repositories/ServicesRepository.js +19 -0
- package/dist/integration-engine/repositories/ServicesRepository.js.map +1 -0
- package/dist/integration-engine/repositories/index.d.ts +6 -0
- package/dist/integration-engine/repositories/index.js +24 -0
- package/dist/integration-engine/repositories/index.js.map +1 -0
- package/dist/integration-engine/transformations/MunicipalLibrariesTransformation.d.ts +32 -0
- package/dist/integration-engine/transformations/MunicipalLibrariesTransformation.js +72 -0
- package/dist/integration-engine/transformations/MunicipalLibrariesTransformation.js.map +1 -0
- package/dist/integration-engine/transformations/helpers/TransformationHelper.d.ts +19 -0
- package/dist/integration-engine/transformations/helpers/TransformationHelper.js +95 -0
- package/dist/integration-engine/transformations/helpers/TransformationHelper.js.map +1 -0
- package/dist/integration-engine/workers/MunicipalLibrariesWorker.d.ts +5 -0
- package/dist/integration-engine/workers/MunicipalLibrariesWorker.js +16 -0
- package/dist/integration-engine/workers/MunicipalLibrariesWorker.js.map +1 -0
- package/dist/integration-engine/workers/index.d.ts +2 -0
- package/dist/integration-engine/workers/index.js +6 -0
- package/dist/integration-engine/workers/index.js.map +1 -0
- package/dist/integration-engine/workers/schemas/UpdateDistrictSchema.d.ts +6 -0
- package/dist/integration-engine/workers/schemas/UpdateDistrictSchema.js +21 -0
- package/dist/integration-engine/workers/schemas/UpdateDistrictSchema.js.map +1 -0
- package/dist/integration-engine/workers/tasks/RefreshDataInDBTask.d.ts +10 -0
- package/dist/integration-engine/workers/tasks/RefreshDataInDBTask.js +41 -0
- package/dist/integration-engine/workers/tasks/RefreshDataInDBTask.js.map +1 -0
- package/dist/integration-engine/workers/tasks/UpdateDistrictsTask.d.ts +12 -0
- package/dist/integration-engine/workers/tasks/UpdateDistrictsTask.js +47 -0
- package/dist/integration-engine/workers/tasks/UpdateDistrictsTask.js.map +1 -0
- package/dist/integration-engine/workers/tasks/index.d.ts +2 -0
- package/dist/integration-engine/workers/tasks/index.js +20 -0
- package/dist/integration-engine/workers/tasks/index.js.map +1 -0
- package/dist/output-gateway/MunicipalLibrariesRouter.d.ts +8 -0
- package/dist/output-gateway/MunicipalLibrariesRouter.js +15 -0
- package/dist/output-gateway/MunicipalLibrariesRouter.js.map +1 -0
- package/dist/output-gateway/index.d.ts +2 -0
- package/dist/output-gateway/index.js +19 -0
- package/dist/output-gateway/index.js.map +1 -0
- package/dist/output-gateway/repositories/DepartmentsRepository.d.ts +6 -0
- package/dist/output-gateway/repositories/DepartmentsRepository.js +28 -0
- package/dist/output-gateway/repositories/DepartmentsRepository.js.map +1 -0
- package/dist/output-gateway/repositories/LibraryDepartmentsRepository.d.ts +6 -0
- package/dist/output-gateway/repositories/LibraryDepartmentsRepository.js +28 -0
- package/dist/output-gateway/repositories/LibraryDepartmentsRepository.js.map +1 -0
- package/dist/output-gateway/repositories/LibraryServicesRepository.d.ts +6 -0
- package/dist/output-gateway/repositories/LibraryServicesRepository.js +28 -0
- package/dist/output-gateway/repositories/LibraryServicesRepository.js.map +1 -0
- package/dist/output-gateway/repositories/MunicipalLibrariesRepository.d.ts +17 -0
- package/dist/output-gateway/repositories/MunicipalLibrariesRepository.js +164 -0
- package/dist/output-gateway/repositories/MunicipalLibrariesRepository.js.map +1 -0
- package/dist/output-gateway/repositories/OpeningHoursRepository.d.ts +6 -0
- package/dist/output-gateway/repositories/OpeningHoursRepository.js +28 -0
- package/dist/output-gateway/repositories/OpeningHoursRepository.js.map +1 -0
- package/dist/output-gateway/repositories/ServicesRepository.d.ts +6 -0
- package/dist/output-gateway/repositories/ServicesRepository.js +28 -0
- package/dist/output-gateway/repositories/ServicesRepository.js.map +1 -0
- package/dist/output-gateway/repositories/index.d.ts +6 -0
- package/dist/output-gateway/repositories/index.js +23 -0
- package/dist/output-gateway/repositories/index.js.map +1 -0
- package/dist/schema-definitions/Departments.d.ts +10 -0
- package/dist/schema-definitions/Departments.js +8 -0
- package/dist/schema-definitions/Departments.js.map +1 -0
- package/dist/schema-definitions/Libraries.d.ts +16 -0
- package/dist/schema-definitions/Libraries.js +8 -0
- package/dist/schema-definitions/Libraries.js.map +1 -0
- package/dist/schema-definitions/LibraryDepartments.d.ts +8 -0
- package/dist/schema-definitions/LibraryDepartments.js +8 -0
- package/dist/schema-definitions/LibraryDepartments.js.map +1 -0
- package/dist/schema-definitions/LibraryServices.d.ts +8 -0
- package/dist/schema-definitions/LibraryServices.js +8 -0
- package/dist/schema-definitions/LibraryServices.js.map +1 -0
- package/dist/schema-definitions/OpeningHours.d.ts +15 -0
- package/dist/schema-definitions/OpeningHours.js +8 -0
- package/dist/schema-definitions/OpeningHours.js.map +1 -0
- package/dist/schema-definitions/Services.d.ts +9 -0
- package/dist/schema-definitions/Services.js +8 -0
- package/dist/schema-definitions/Services.js.map +1 -0
- package/dist/schema-definitions/datasources/MunicipalLibrariesJsonSchema.d.ts +78 -0
- package/dist/schema-definitions/datasources/MunicipalLibrariesJsonSchema.js +209 -0
- package/dist/schema-definitions/datasources/MunicipalLibrariesJsonSchema.js.map +1 -0
- package/dist/schema-definitions/index.d.ts +1 -314
- package/dist/schema-definitions/index.js +19 -265
- package/dist/schema-definitions/index.js.map +1 -1
- package/dist/schema-definitions/models/DepartmentsModel.d.ts +12 -0
- package/dist/schema-definitions/models/DepartmentsModel.js +33 -0
- package/dist/schema-definitions/models/DepartmentsModel.js.map +1 -0
- package/dist/schema-definitions/models/LibrariesModel.d.ts +18 -0
- package/dist/schema-definitions/models/LibrariesModel.js +46 -0
- package/dist/schema-definitions/models/LibrariesModel.js.map +1 -0
- package/dist/schema-definitions/models/LibraryDepartmentsModel.d.ts +10 -0
- package/dist/schema-definitions/models/LibraryDepartmentsModel.js +30 -0
- package/dist/schema-definitions/models/LibraryDepartmentsModel.js.map +1 -0
- package/dist/schema-definitions/models/LibraryServicesModel.d.ts +10 -0
- package/dist/schema-definitions/models/LibraryServicesModel.js +30 -0
- package/dist/schema-definitions/models/LibraryServicesModel.js.map +1 -0
- package/dist/schema-definitions/models/OpeningHoursModel.d.ts +17 -0
- package/dist/schema-definitions/models/OpeningHoursModel.js +44 -0
- package/dist/schema-definitions/models/OpeningHoursModel.js.map +1 -0
- package/dist/schema-definitions/models/ServicesModel.d.ts +11 -0
- package/dist/schema-definitions/models/ServicesModel.js +31 -0
- package/dist/schema-definitions/models/ServicesModel.js.map +1 -0
- package/dist/schema-definitions/models/index.d.ts +6 -0
- package/dist/schema-definitions/models/index.js +24 -0
- package/dist/schema-definitions/models/index.js.map +1 -0
- package/package.json +64 -58
- package/db/example/mongo_data/dataplatform/municipallibraries.bson +0 -0
- package/db/example/mongo_data/dataplatform/municipallibraries.metadata.json +0 -1
- package/dist/integration-engine/MunicipalLibrariesTransformation.d.ts +0 -9
- package/dist/integration-engine/MunicipalLibrariesTransformation.js +0 -150
- package/dist/integration-engine/MunicipalLibrariesTransformation.js.map +0 -1
- package/dist/integration-engine/MunicipalLibrariesWorker.d.ts +0 -11
- package/dist/integration-engine/MunicipalLibrariesWorker.js +0 -105
- package/dist/integration-engine/MunicipalLibrariesWorker.js.map +0 -1
- package/dist/integration-engine/queueDefinitions.d.ts +0 -3
- package/dist/integration-engine/queueDefinitions.js +0 -36
- package/dist/integration-engine/queueDefinitions.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"OpeningHoursRepository.js","sourceRoot":"","sources":["../../../src/integration-engine/repositories/OpeningHoursRepository.ts"],"names":[],"mappings":";;;AAAA,yEAAqF;AACrF,mFAAkF;AAClF,mDAA0C;AAC1C,4DAAgD;AAEhD,MAAa,sBAAuB,SAAQ,sBAAa;IACrD;QACI,KAAK,CACD,yBAAkB,CAAC,WAAW,CAAC,4BAA4B,CAAC,IAAI,GAAG,YAAY,EAC/E;YACI,yBAAyB,EAAE,0BAAiB,CAAC,cAAc;YAC3D,WAAW,EAAE,yBAAkB,CAAC,WAAW,CAAC,4BAA4B,CAAC,WAAW;YACpF,QAAQ,EAAE,yBAAkB,CAAC,QAAQ;YACrC,UAAU,EAAE,gBAAgB;SAC/B,EACD,IAAI,uCAAmB,CACnB,yBAAkB,CAAC,WAAW,CAAC,4BAA4B,CAAC,IAAI,GAAG,WAAW,EAC9E,0BAAiB,CAAC,UAAU,CAC/B,CACJ,CAAC;IACN,CAAC;CACJ;AAhBD,wDAgBC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ServicesRepository = void 0;
|
|
4
|
+
const models_1 = require("@golemio/core/dist/integration-engine/models");
|
|
5
|
+
const golemio_validator_1 = require("@golemio/core/dist/shared/golemio-validator");
|
|
6
|
+
const _sch_1 = require("../../schema-definitions");
|
|
7
|
+
const models_2 = require("../../schema-definitions/models");
|
|
8
|
+
class ServicesRepository extends models_1.PostgresModel {
|
|
9
|
+
constructor() {
|
|
10
|
+
super(_sch_1.MunicipalLibraries.definitions.municipalLibraryServices.name + "Repository", {
|
|
11
|
+
outputSequelizeAttributes: models_2.ServicesModel.attributeModel,
|
|
12
|
+
pgTableName: _sch_1.MunicipalLibraries.definitions.municipalLibraryServices.pgTableName,
|
|
13
|
+
pgSchema: _sch_1.MunicipalLibraries.pgSchema,
|
|
14
|
+
savingType: "insertOrUpdate",
|
|
15
|
+
}, new golemio_validator_1.JSONSchemaValidator(_sch_1.MunicipalLibraries.definitions.municipalLibraryServices.name + "Validator", models_2.ServicesModel.jsonSchema));
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
exports.ServicesRepository = ServicesRepository;
|
|
19
|
+
//# sourceMappingURL=ServicesRepository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ServicesRepository.js","sourceRoot":"","sources":["../../../src/integration-engine/repositories/ServicesRepository.ts"],"names":[],"mappings":";;;AAAA,yEAAqF;AACrF,mFAAkF;AAClF,mDAA0C;AAC1C,4DAA4C;AAE5C,MAAa,kBAAmB,SAAQ,sBAAa;IACjD;QACI,KAAK,CACD,yBAAkB,CAAC,WAAW,CAAC,wBAAwB,CAAC,IAAI,GAAG,YAAY,EAC3E;YACI,yBAAyB,EAAE,sBAAa,CAAC,cAAc;YACvD,WAAW,EAAE,yBAAkB,CAAC,WAAW,CAAC,wBAAwB,CAAC,WAAW;YAChF,QAAQ,EAAE,yBAAkB,CAAC,QAAQ;YACrC,UAAU,EAAE,gBAAgB;SAC/B,EACD,IAAI,uCAAmB,CACnB,yBAAkB,CAAC,WAAW,CAAC,wBAAwB,CAAC,IAAI,GAAG,WAAW,EAC1E,sBAAa,CAAC,UAAU,CAC3B,CACJ,CAAC;IACN,CAAC;CACJ;AAhBD,gDAgBC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export * from "./MunicipalLibrariesRepository";
|
|
2
|
+
export * from "./ServicesRepository";
|
|
3
|
+
export * from "./DepartmentsRepository";
|
|
4
|
+
export * from "./OpeningHoursRepository";
|
|
5
|
+
export * from "./LibraryServicesRepository";
|
|
6
|
+
export * from "./LibraryDepartmentsRepository";
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
/* ie/repositories/index.ts */
|
|
18
|
+
__exportStar(require("./MunicipalLibrariesRepository"), exports);
|
|
19
|
+
__exportStar(require("./ServicesRepository"), exports);
|
|
20
|
+
__exportStar(require("./DepartmentsRepository"), exports);
|
|
21
|
+
__exportStar(require("./OpeningHoursRepository"), exports);
|
|
22
|
+
__exportStar(require("./LibraryServicesRepository"), exports);
|
|
23
|
+
__exportStar(require("./LibraryDepartmentsRepository"), exports);
|
|
24
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/integration-engine/repositories/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,8BAA8B;AAC9B,iEAA+C;AAC/C,uDAAqC;AACrC,0DAAwC;AACxC,2DAAyC;AACzC,8DAA4C;AAC5C,iEAA+C"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { BaseTransformation, ITransformation } from "@golemio/core/dist/integration-engine/transformations";
|
|
2
|
+
import { ILibrariesInput } from "../../schema-definitions/datasources/MunicipalLibrariesJsonSchema";
|
|
3
|
+
import { ILibraries } from "../../schema-definitions/Libraries";
|
|
4
|
+
import { IServices } from "../../schema-definitions/Services";
|
|
5
|
+
import { IDepartments } from "../../schema-definitions/Departments";
|
|
6
|
+
import { IOpeningHours } from "../../schema-definitions/OpeningHours";
|
|
7
|
+
export interface ILibrariesTransformation {
|
|
8
|
+
libraries: ILibraries[];
|
|
9
|
+
services: Array<IServices & {
|
|
10
|
+
library_id: number;
|
|
11
|
+
}>;
|
|
12
|
+
departments: Array<IDepartments & {
|
|
13
|
+
library_id: number;
|
|
14
|
+
}>;
|
|
15
|
+
opening_hours: Array<Omit<IOpeningHours, "id">>;
|
|
16
|
+
}
|
|
17
|
+
interface ILibraryItemTransformation extends ILibraries {
|
|
18
|
+
services: Array<IServices & {
|
|
19
|
+
library_id: number;
|
|
20
|
+
}>;
|
|
21
|
+
departments: Array<IDepartments & {
|
|
22
|
+
library_id: number;
|
|
23
|
+
}>;
|
|
24
|
+
opening_hours: Array<Omit<IOpeningHours, "id">>;
|
|
25
|
+
}
|
|
26
|
+
export declare class MunicipalLibrariesTransformation extends BaseTransformation implements ITransformation {
|
|
27
|
+
name: string;
|
|
28
|
+
constructor();
|
|
29
|
+
transform: (data: ILibrariesInput[]) => Promise<ILibrariesTransformation>;
|
|
30
|
+
protected transformElement: (element: ILibrariesInput) => ILibraryItemTransformation;
|
|
31
|
+
}
|
|
32
|
+
export {};
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __rest = (this && this.__rest) || function (s, e) {
|
|
12
|
+
var t = {};
|
|
13
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
|
14
|
+
t[p] = s[p];
|
|
15
|
+
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
|
16
|
+
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
17
|
+
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
|
18
|
+
t[p[i]] = s[p[i]];
|
|
19
|
+
}
|
|
20
|
+
return t;
|
|
21
|
+
};
|
|
22
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
23
|
+
exports.MunicipalLibrariesTransformation = void 0;
|
|
24
|
+
const transformations_1 = require("@golemio/core/dist/integration-engine/transformations");
|
|
25
|
+
const _sch_1 = require("../../schema-definitions");
|
|
26
|
+
const TransformationHelper_1 = require("./helpers/TransformationHelper");
|
|
27
|
+
class MunicipalLibrariesTransformation extends transformations_1.BaseTransformation {
|
|
28
|
+
constructor() {
|
|
29
|
+
super();
|
|
30
|
+
this.transform = (data) => __awaiter(this, void 0, void 0, function* () {
|
|
31
|
+
const result = {
|
|
32
|
+
libraries: [],
|
|
33
|
+
services: [],
|
|
34
|
+
departments: [],
|
|
35
|
+
opening_hours: [],
|
|
36
|
+
};
|
|
37
|
+
for (const item of data) {
|
|
38
|
+
if (TransformationHelper_1.TransformationHelper.shouldProcess(item)) {
|
|
39
|
+
const _a = this.transformElement(item), { services, departments, opening_hours } = _a, library = __rest(_a, ["services", "departments", "opening_hours"]);
|
|
40
|
+
result.libraries.push(library);
|
|
41
|
+
result.opening_hours.push(...opening_hours);
|
|
42
|
+
result.services.push(...services);
|
|
43
|
+
result.departments.push(...departments);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
return result;
|
|
47
|
+
});
|
|
48
|
+
this.transformElement = (element) => {
|
|
49
|
+
const id = parseInt(element.id, 10);
|
|
50
|
+
const gps = element.adresa.gps.split(",").map((e) => parseFloat(e.trim()));
|
|
51
|
+
return {
|
|
52
|
+
id,
|
|
53
|
+
name: element.nazev,
|
|
54
|
+
geometry: {
|
|
55
|
+
coordinates: [gps[1], gps[0]],
|
|
56
|
+
type: "Point",
|
|
57
|
+
},
|
|
58
|
+
address: TransformationHelper_1.TransformationHelper.getAddress(element.adresa),
|
|
59
|
+
email: element.kontakt.email,
|
|
60
|
+
opening_hours: TransformationHelper_1.TransformationHelper.transformOpeningHours(element.oteviracidoby.oteviracidoba, id),
|
|
61
|
+
telephone: element.kontakt.telefon,
|
|
62
|
+
web: element.adresa.url,
|
|
63
|
+
district: null,
|
|
64
|
+
departments: element.oddeleni ? TransformationHelper_1.TransformationHelper.transformDepartments(element.oddeleni, id) : [],
|
|
65
|
+
services: element.sluzby ? TransformationHelper_1.TransformationHelper.transformServices(element.sluzby, id) : [],
|
|
66
|
+
};
|
|
67
|
+
};
|
|
68
|
+
this.name = _sch_1.MunicipalLibraries.name;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
exports.MunicipalLibrariesTransformation = MunicipalLibrariesTransformation;
|
|
72
|
+
//# sourceMappingURL=MunicipalLibrariesTransformation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MunicipalLibrariesTransformation.js","sourceRoot":"","sources":["../../../src/integration-engine/transformations/MunicipalLibrariesTransformation.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AACA,2FAA4G;AAC5G,mDAA0C;AAG1C,yEAAwF;AAkBxF,MAAa,gCAAiC,SAAQ,oCAAkB;IAGpE;QACI,KAAK,EAAE,CAAC;QAIL,cAAS,GAAG,CAAO,IAAuB,EAAqC,EAAE;YACpF,MAAM,MAAM,GAA6B;gBACrC,SAAS,EAAE,EAAE;gBACb,QAAQ,EAAE,EAAE;gBACZ,WAAW,EAAE,EAAE;gBACf,aAAa,EAAE,EAAE;aACpB,CAAC;YAEF,KAAK,MAAM,IAAI,IAAI,IAAI,EAAE;gBACrB,IAAI,2CAAoB,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE;oBAC1C,MAAM,KAAuD,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAlF,EAAE,QAAQ,EAAE,WAAW,EAAE,aAAa,OAA4C,EAAvC,OAAO,cAAlD,4CAAoD,CAA8B,CAAC;oBACzF,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;oBAC/B,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,GAAG,aAAa,CAAC,CAAC;oBAC5C,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,QAAQ,CAAC,CAAC;oBAClC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,WAAW,CAAC,CAAC;iBAC3C;aACJ;YAED,OAAO,MAAM,CAAC;QAClB,CAAC,CAAA,CAAC;QAEQ,qBAAgB,GAAG,CAAC,OAAwB,EAA8B,EAAE;YAClF,MAAM,EAAE,GAAG,QAAQ,CAAC,OAAO,CAAC,EAAG,EAAE,EAAE,CAAC,CAAC;YACrC,MAAM,GAAG,GAAG,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAS,EAAE,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;YAEnF,OAAO;gBACH,EAAE;gBACF,IAAI,EAAE,OAAO,CAAC,KAAK;gBACnB,QAAQ,EAAE;oBACN,WAAW,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;oBAC7B,IAAI,EAAE,OAAO;iBACP;gBACV,OAAO,EAAE,2CAAoB,CAAC,UAAU,CAAC,OAAO,CAAC,MAAM,CAAC;gBACxD,KAAK,EAAE,OAAO,CAAC,OAAO,CAAC,KAAK;gBAC5B,aAAa,EAAE,2CAAoB,CAAC,qBAAqB,CAAC,OAAO,CAAC,aAAa,CAAC,aAAa,EAAE,EAAE,CAAC;gBAClG,SAAS,EAAE,OAAO,CAAC,OAAO,CAAC,OAAO;gBAClC,GAAG,EAAE,OAAO,CAAC,MAAM,CAAC,GAAG;gBACvB,QAAQ,EAAE,IAAI;gBACd,WAAW,EAAE,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,2CAAoB,CAAC,oBAAoB,CAAC,OAAO,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE;gBACpG,QAAQ,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,2CAAoB,CAAC,iBAAiB,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE;aAC7F,CAAC;QACN,CAAC,CAAC;QA5CE,IAAI,CAAC,IAAI,GAAG,yBAAkB,CAAC,IAAI,CAAC;IACxC,CAAC;CA4CJ;AAlDD,4EAkDC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { IPostalAddress } from "@golemio/core/dist/integration-engine";
|
|
2
|
+
import { IAddressInput, IDepartmentsInput, ILibrariesInput, IServicesInput, TOpeningHoursInput } from "../../../schema-definitions/datasources/MunicipalLibrariesJsonSchema";
|
|
3
|
+
import { IOpeningHours } from "../../../schema-definitions/OpeningHours";
|
|
4
|
+
import { IServices } from "../../../schema-definitions/Services";
|
|
5
|
+
import { IDepartments } from "../../../schema-definitions/Departments";
|
|
6
|
+
export declare class TransformationHelper {
|
|
7
|
+
static shouldProcess: (library: ILibrariesInput) => boolean;
|
|
8
|
+
static getAddress: (address: IAddressInput) => IPostalAddress;
|
|
9
|
+
private static getOpeningHours;
|
|
10
|
+
static transformOpeningHours: (openingHours: TOpeningHoursInput | TOpeningHoursInput[], libraryId: number) => Array<Omit<IOpeningHours, "id">>;
|
|
11
|
+
private static getService;
|
|
12
|
+
static transformServices: (services: IServicesInput, libraryId: number) => Array<IServices & {
|
|
13
|
+
library_id: number;
|
|
14
|
+
}>;
|
|
15
|
+
private static getDepartment;
|
|
16
|
+
static transformDepartments: (departments: IDepartmentsInput, libraryId: number) => Array<IDepartments & {
|
|
17
|
+
library_id: number;
|
|
18
|
+
}>;
|
|
19
|
+
}
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
var _a;
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.TransformationHelper = void 0;
|
|
8
|
+
const integration_engine_1 = require("@golemio/core/dist/integration-engine");
|
|
9
|
+
const moment_timezone_1 = __importDefault(require("@golemio/core/dist/shared/moment-timezone"));
|
|
10
|
+
const MunicipalLibrariesJsonSchema_1 = require("../../../schema-definitions/datasources/MunicipalLibrariesJsonSchema");
|
|
11
|
+
class TransformationHelper {
|
|
12
|
+
}
|
|
13
|
+
exports.TransformationHelper = TransformationHelper;
|
|
14
|
+
_a = TransformationHelper;
|
|
15
|
+
TransformationHelper.shouldProcess = (library) => {
|
|
16
|
+
if (library.id === null) {
|
|
17
|
+
return false;
|
|
18
|
+
}
|
|
19
|
+
// filter sub-departments
|
|
20
|
+
if (library.nadrazena !== null) {
|
|
21
|
+
integration_engine_1.log.debug(`Sub-department '${library.nazev}' was filtered out.`);
|
|
22
|
+
return false;
|
|
23
|
+
}
|
|
24
|
+
// filter departments without gps
|
|
25
|
+
const gps = library.adresa.gps.split(",").map((e) => parseFloat(e.trim()));
|
|
26
|
+
if (gps[0] === 0 || gps[1] === 0) {
|
|
27
|
+
integration_engine_1.log.debug(`Department '${library.nazev}' was filtered out.`);
|
|
28
|
+
return false;
|
|
29
|
+
}
|
|
30
|
+
return true;
|
|
31
|
+
};
|
|
32
|
+
TransformationHelper.getAddress = (address) => {
|
|
33
|
+
return {
|
|
34
|
+
address_country: "Česko",
|
|
35
|
+
address_formatted: `${address.ulice} ${address.cislo}, ${address.psc} ${address.mesto}, Česko`,
|
|
36
|
+
address_locality: address.mesto,
|
|
37
|
+
postal_code: address.psc,
|
|
38
|
+
street_address: `${address.ulice} ${address.cislo}`,
|
|
39
|
+
};
|
|
40
|
+
};
|
|
41
|
+
TransformationHelper.getOpeningHours = (openingHours, libraryId) => {
|
|
42
|
+
var _b, _c;
|
|
43
|
+
const res = [];
|
|
44
|
+
const common = {
|
|
45
|
+
library_id: libraryId,
|
|
46
|
+
description: openingHours.nazev,
|
|
47
|
+
is_default: openingHours.defaultni === "true",
|
|
48
|
+
valid_from: ((_b = openingHours.platnost) === null || _b === void 0 ? void 0 : _b.od) ? moment_timezone_1.default.tz(openingHours.platnost.od, "Europe/Prague").toISOString() : null,
|
|
49
|
+
valid_through: ((_c = openingHours.platnost) === null || _c === void 0 ? void 0 : _c.do) ? moment_timezone_1.default.tz(openingHours.platnost.do, "Europe/Prague").toISOString() : null,
|
|
50
|
+
};
|
|
51
|
+
for (const day of Object.keys(MunicipalLibrariesJsonSchema_1.OpeningHoursDays)) {
|
|
52
|
+
if (openingHours[day]) {
|
|
53
|
+
if (openingHours[day].rano) {
|
|
54
|
+
res.push(Object.assign({ opens: openingHours[day].rano.od, closes: openingHours[day].rano.do, day_of_week: MunicipalLibrariesJsonSchema_1.OpeningHoursDays[day] }, common));
|
|
55
|
+
}
|
|
56
|
+
if (openingHours[day].odpoledne) {
|
|
57
|
+
res.push(Object.assign({ opens: openingHours[day].odpoledne.od, closes: openingHours[day].odpoledne.do, day_of_week: MunicipalLibrariesJsonSchema_1.OpeningHoursDays[day] }, common));
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
return res;
|
|
62
|
+
};
|
|
63
|
+
TransformationHelper.transformOpeningHours = (openingHours, libraryId) => {
|
|
64
|
+
return openingHours instanceof Array
|
|
65
|
+
? openingHours.flatMap((o) => _a.getOpeningHours(o, libraryId))
|
|
66
|
+
: _a.getOpeningHours(openingHours, libraryId);
|
|
67
|
+
};
|
|
68
|
+
TransformationHelper.getService = (service, libraryId) => {
|
|
69
|
+
return {
|
|
70
|
+
id: parseInt(service.id, 10),
|
|
71
|
+
library_id: libraryId,
|
|
72
|
+
name: service.nazev,
|
|
73
|
+
description: service.popis,
|
|
74
|
+
};
|
|
75
|
+
};
|
|
76
|
+
TransformationHelper.transformServices = (services, libraryId) => {
|
|
77
|
+
return services.sluzba instanceof Array
|
|
78
|
+
? services.sluzba.map((s) => _a.getService(s, libraryId))
|
|
79
|
+
: [_a.getService(services.sluzba, libraryId)];
|
|
80
|
+
};
|
|
81
|
+
TransformationHelper.getDepartment = (departments, libraryId) => {
|
|
82
|
+
return {
|
|
83
|
+
id: departments.id,
|
|
84
|
+
library_id: libraryId,
|
|
85
|
+
name: departments.nazev,
|
|
86
|
+
type: departments.typ,
|
|
87
|
+
url: departments.url,
|
|
88
|
+
};
|
|
89
|
+
};
|
|
90
|
+
TransformationHelper.transformDepartments = (departments, libraryId) => {
|
|
91
|
+
return departments.oddeleni instanceof Array
|
|
92
|
+
? departments.oddeleni.map((d) => _a.getDepartment(d, libraryId))
|
|
93
|
+
: [_a.getDepartment(departments.oddeleni, libraryId)];
|
|
94
|
+
};
|
|
95
|
+
//# sourceMappingURL=TransformationHelper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TransformationHelper.js","sourceRoot":"","sources":["../../../../src/integration-engine/transformations/helpers/TransformationHelper.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.MunicipalLibrariesWorker = void 0;
|
|
4
|
+
const workers_1 = require("@golemio/core/dist/integration-engine/workers");
|
|
5
|
+
const RefreshDataInDBTask_1 = require("./tasks/RefreshDataInDBTask");
|
|
6
|
+
const UpdateDistrictsTask_1 = require("./tasks/UpdateDistrictsTask");
|
|
7
|
+
class MunicipalLibrariesWorker extends workers_1.AbstractWorker {
|
|
8
|
+
constructor() {
|
|
9
|
+
super();
|
|
10
|
+
this.name = "MunicipalLibraries";
|
|
11
|
+
this.registerTask(new RefreshDataInDBTask_1.RefreshDataInDBTask(this.getQueuePrefix()));
|
|
12
|
+
this.registerTask(new UpdateDistrictsTask_1.UpdateDistrictsTask(this.getQueuePrefix()));
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
exports.MunicipalLibrariesWorker = MunicipalLibrariesWorker;
|
|
16
|
+
//# sourceMappingURL=MunicipalLibrariesWorker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MunicipalLibrariesWorker.js","sourceRoot":"","sources":["../../../src/integration-engine/workers/MunicipalLibrariesWorker.ts"],"names":[],"mappings":";;;AAAA,2EAA+E;AAC/E,qEAA4E;AAC5E,qEAA4E;AAE5E,MAAa,wBAAyB,SAAQ,wBAAc;IAGxD;QACI,KAAK,EAAE,CAAC;QAHO,SAAI,GAAG,oBAAoB,CAAC;QAI3C,IAAI,CAAC,YAAY,CAAC,IAAI,yCAAmB,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC,CAAC;QAClE,IAAI,CAAC,YAAY,CAAC,IAAI,yCAAmB,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC,CAAC;IACtE,CAAC;CACJ;AARD,4DAQC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.workers = void 0;
|
|
4
|
+
const MunicipalLibrariesWorker_1 = require("./MunicipalLibrariesWorker");
|
|
5
|
+
exports.workers = [MunicipalLibrariesWorker_1.MunicipalLibrariesWorker];
|
|
6
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/integration-engine/workers/index.ts"],"names":[],"mappings":";;;AAAA,yEAAsE;AAEzD,QAAA,OAAO,GAAG,CAAC,mDAAwB,CAAC,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
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;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.UpdateDistrictValidationSchema = void 0;
|
|
13
|
+
const class_validator_1 = require("@golemio/core/dist/shared/class-validator");
|
|
14
|
+
class UpdateDistrictValidationSchema {
|
|
15
|
+
}
|
|
16
|
+
__decorate([
|
|
17
|
+
(0, class_validator_1.IsInt)(),
|
|
18
|
+
__metadata("design:type", Number)
|
|
19
|
+
], UpdateDistrictValidationSchema.prototype, "id", void 0);
|
|
20
|
+
exports.UpdateDistrictValidationSchema = UpdateDistrictValidationSchema;
|
|
21
|
+
//# sourceMappingURL=UpdateDistrictSchema.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"UpdateDistrictSchema.js","sourceRoot":"","sources":["../../../../src/integration-engine/workers/schemas/UpdateDistrictSchema.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,+EAAkE;AAMlE,MAAa,8BAA8B;CAG1C;AADG;IADC,IAAA,uBAAK,GAAE;;0DACI;AAFhB,wEAGC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { AbstractEmptyTask } from "@golemio/core/dist/integration-engine";
|
|
2
|
+
export declare class RefreshDataInDBTask extends AbstractEmptyTask {
|
|
3
|
+
readonly queueName = "refreshDataInDB";
|
|
4
|
+
readonly queueTtl: number;
|
|
5
|
+
private dataSource;
|
|
6
|
+
private transformation;
|
|
7
|
+
private repository;
|
|
8
|
+
constructor(queuePrefix: string);
|
|
9
|
+
protected execute(): Promise<void>;
|
|
10
|
+
}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.RefreshDataInDBTask = void 0;
|
|
13
|
+
const integration_engine_1 = require("@golemio/core/dist/integration-engine");
|
|
14
|
+
const _ie_1 = require("../..");
|
|
15
|
+
const repositories_1 = require("../../repositories");
|
|
16
|
+
const datasources_1 = require("../../datasources");
|
|
17
|
+
class RefreshDataInDBTask extends integration_engine_1.AbstractEmptyTask {
|
|
18
|
+
constructor(queuePrefix) {
|
|
19
|
+
super(queuePrefix);
|
|
20
|
+
this.queueName = "refreshDataInDB";
|
|
21
|
+
this.queueTtl = 59 * 60 * 1000; // 59 minutes
|
|
22
|
+
this.dataSource = datasources_1.MunicipalLibrariesDataSourceFactory.getDataSource();
|
|
23
|
+
this.transformation = new _ie_1.MunicipalLibrariesTransformation();
|
|
24
|
+
this.repository = new repositories_1.MunicipalLibrariesRepository();
|
|
25
|
+
}
|
|
26
|
+
execute() {
|
|
27
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
28
|
+
const data = yield this.dataSource.getAll();
|
|
29
|
+
const transformedData = yield this.transformation.transform(data);
|
|
30
|
+
yield this.repository.saveLibraries(transformedData);
|
|
31
|
+
const promises = transformedData.libraries.map((data) => {
|
|
32
|
+
return integration_engine_1.QueueManager.sendMessageToExchange(this.queuePrefix, "updateDistrict", {
|
|
33
|
+
id: data.id,
|
|
34
|
+
});
|
|
35
|
+
});
|
|
36
|
+
yield Promise.all(promises);
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
exports.RefreshDataInDBTask = RefreshDataInDBTask;
|
|
41
|
+
//# sourceMappingURL=RefreshDataInDBTask.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RefreshDataInDBTask.js","sourceRoot":"","sources":["../../../../src/integration-engine/workers/tasks/RefreshDataInDBTask.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,8EAAwF;AAExF,+BAAuD;AACvD,qDAAgE;AAChE,mDAAsE;AAGtE,MAAa,mBAAoB,SAAQ,sCAAiB;IAQtD,YAAY,WAAmB;QAC3B,KAAK,CAAC,WAAW,CAAC,CAAC;QARP,cAAS,GAAG,iBAAiB,CAAC;QAC9B,aAAQ,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC,aAAa;QAQpD,IAAI,CAAC,UAAU,GAAG,iDAAmC,CAAC,aAAa,EAAE,CAAC;QACtE,IAAI,CAAC,cAAc,GAAG,IAAI,sCAAgC,EAAE,CAAC;QAC7D,IAAI,CAAC,UAAU,GAAG,IAAI,2CAA4B,EAAE,CAAC;IACzD,CAAC;IAEe,OAAO;;YACnB,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC;YAC5C,MAAM,eAAe,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;YAClE,MAAM,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,eAAe,CAAC,CAAC;YAErD,MAAM,QAAQ,GAAG,eAAe,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,IAAgB,EAAE,EAAE;gBAChE,OAAO,iCAAY,CAAC,qBAAqB,CAAC,IAAI,CAAC,WAAW,EAAE,gBAAgB,EAAE;oBAC1E,EAAE,EAAE,IAAI,CAAC,EAAE;iBACd,CAAC,CAAC;YACP,CAAC,CAAC,CAAC;YACH,MAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAChC,CAAC;KAAA;CACJ;AA3BD,kDA2BC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { AbstractTask } from "@golemio/core/dist/integration-engine";
|
|
2
|
+
import { MunicipalLibrariesRepository } from "../../repositories";
|
|
3
|
+
import { IUpdateDistrictInput, UpdateDistrictValidationSchema } from "../schemas/UpdateDistrictSchema";
|
|
4
|
+
export declare class UpdateDistrictsTask extends AbstractTask<IUpdateDistrictInput> {
|
|
5
|
+
readonly queueName = "updateDistrict";
|
|
6
|
+
readonly queueTtl: number;
|
|
7
|
+
readonly schema: typeof UpdateDistrictValidationSchema;
|
|
8
|
+
repository: MunicipalLibrariesRepository;
|
|
9
|
+
private readonly cityDistrictsModel;
|
|
10
|
+
constructor(queuePrefix: string);
|
|
11
|
+
protected execute(msg: IUpdateDistrictInput): Promise<void>;
|
|
12
|
+
}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.UpdateDistrictsTask = void 0;
|
|
16
|
+
const integration_engine_1 = require("@golemio/core/dist/integration-engine");
|
|
17
|
+
const golemio_errors_1 = require("@golemio/core/dist/shared/golemio-errors");
|
|
18
|
+
const CityDistrictModel_1 = __importDefault(require("@golemio/city-districts/dist/integration-engine/models/CityDistrictModel"));
|
|
19
|
+
const repositories_1 = require("../../repositories");
|
|
20
|
+
const UpdateDistrictSchema_1 = require("../schemas/UpdateDistrictSchema");
|
|
21
|
+
class UpdateDistrictsTask extends integration_engine_1.AbstractTask {
|
|
22
|
+
constructor(queuePrefix) {
|
|
23
|
+
super(queuePrefix);
|
|
24
|
+
this.queueName = "updateDistrict";
|
|
25
|
+
this.queueTtl = 59 * 60 * 1000; // 59 minutes
|
|
26
|
+
this.schema = UpdateDistrictSchema_1.UpdateDistrictValidationSchema;
|
|
27
|
+
this.repository = new repositories_1.MunicipalLibrariesRepository();
|
|
28
|
+
this.cityDistrictsModel = new CityDistrictModel_1.default();
|
|
29
|
+
}
|
|
30
|
+
execute(msg) {
|
|
31
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
32
|
+
try {
|
|
33
|
+
const data = yield this.repository.findOne({
|
|
34
|
+
where: { id: msg.id },
|
|
35
|
+
raw: true,
|
|
36
|
+
});
|
|
37
|
+
data.district = yield this.cityDistrictsModel.getDistrict(data.geometry.coordinates[0], data.geometry.coordinates[1]);
|
|
38
|
+
yield this.repository.save([data]);
|
|
39
|
+
}
|
|
40
|
+
catch (err) {
|
|
41
|
+
throw new golemio_errors_1.CustomError("Error while updating city district.", true, this.constructor.name, 5001, err);
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
exports.UpdateDistrictsTask = UpdateDistrictsTask;
|
|
47
|
+
//# sourceMappingURL=UpdateDistrictsTask.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"UpdateDistrictsTask.js","sourceRoot":"","sources":["../../../../src/integration-engine/workers/tasks/UpdateDistrictsTask.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,8EAAqE;AACrE,6EAAuE;AACvE,iIAA0G;AAC1G,qDAAgE;AAChE,0EAAgH;AAGhH,MAAa,mBAAoB,SAAQ,iCAAkC;IAQvE,YAAY,WAAmB;QAC3B,KAAK,CAAC,WAAW,CAAC,CAAC;QARP,cAAS,GAAG,gBAAgB,CAAC;QAC7B,aAAQ,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC,aAAa;QACxC,WAAM,GAAG,qDAA8B,CAAC;QAOpD,IAAI,CAAC,UAAU,GAAG,IAAI,2CAA4B,EAAE,CAAC;QACrD,IAAI,CAAC,kBAAkB,GAAG,IAAI,2BAAkB,EAAE,CAAC;IACvD,CAAC;IAEe,OAAO,CAAC,GAAyB;;YAC7C,IAAI;gBACA,MAAM,IAAI,GAAmB,MAAM,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC;oBACvD,KAAK,EAAE,EAAE,EAAE,EAAE,GAAG,CAAC,EAAE,EAAE;oBACrB,GAAG,EAAE,IAAI;iBACZ,CAAC,CAAC;gBAEH,IAAI,CAAC,QAAQ,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;gBAEtH,MAAM,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;aACtC;YAAC,OAAO,GAAG,EAAE;gBACV,MAAM,IAAI,4BAAW,CAAC,qCAAqC,EAAE,IAAI,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,IAAI,EAAE,GAAG,CAAC,CAAC;aACxG;QACL,CAAC;KAAA;CACJ;AA5BD,kDA4BC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
/* ie/workers/tasks/index.ts */
|
|
18
|
+
__exportStar(require("./UpdateDistrictsTask"), exports);
|
|
19
|
+
__exportStar(require("./RefreshDataInDBTask"), exports);
|
|
20
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/integration-engine/workers/tasks/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,+BAA+B;AAC/B,wDAAsC;AACtC,wDAAsC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/// <reference types="express" />
|
|
2
|
+
import { Router } from "@golemio/core/dist/shared/express";
|
|
3
|
+
import { GeoJsonRouter } from "@golemio/core/dist/output-gateway/routes";
|
|
4
|
+
export declare class MunicipalLibrariesRouter extends GeoJsonRouter {
|
|
5
|
+
constructor();
|
|
6
|
+
}
|
|
7
|
+
declare const municipalLibrariesRouter: Router;
|
|
8
|
+
export { municipalLibrariesRouter };
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.municipalLibrariesRouter = exports.MunicipalLibrariesRouter = void 0;
|
|
4
|
+
const routes_1 = require("@golemio/core/dist/output-gateway/routes");
|
|
5
|
+
const repositories_1 = require("./repositories");
|
|
6
|
+
class MunicipalLibrariesRouter extends routes_1.GeoJsonRouter {
|
|
7
|
+
constructor() {
|
|
8
|
+
super(new repositories_1.MunicipalLibrariesRepository());
|
|
9
|
+
this.initRoutes();
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
exports.MunicipalLibrariesRouter = MunicipalLibrariesRouter;
|
|
13
|
+
const municipalLibrariesRouter = new MunicipalLibrariesRouter().router;
|
|
14
|
+
exports.municipalLibrariesRouter = municipalLibrariesRouter;
|
|
15
|
+
//# sourceMappingURL=MunicipalLibrariesRouter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MunicipalLibrariesRouter.js","sourceRoot":"","sources":["../../src/output-gateway/MunicipalLibrariesRouter.ts"],"names":[],"mappings":";;;AACA,qEAAyE;AACzE,iDAAgE;AAEhE,MAAa,wBAAyB,SAAQ,sBAAa;IACvD;QACI,KAAK,CAAC,IAAI,2CAA4B,EAAE,CAAC,CAAC;QAC1C,IAAI,CAAC,UAAU,EAAE,CAAC;IACtB,CAAC;CACJ;AALD,4DAKC;AAED,MAAM,wBAAwB,GAAW,IAAI,wBAAwB,EAAE,CAAC,MAAM,CAAC;AAEtE,4DAAwB"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./repositories"), exports);
|
|
18
|
+
__exportStar(require("./MunicipalLibrariesRouter"), exports);
|
|
19
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/output-gateway/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,iDAA+B;AAC/B,6DAA2C"}
|