@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.
Files changed (147) hide show
  1. package/db/example/.config.json +3 -0
  2. package/db/example/00_truncate_tables.sql +7 -0
  3. package/db/example/01_libraries.sql +50 -0
  4. package/db/migrations/postgresql/.config.json +3 -0
  5. package/db/migrations/postgresql/20220916133717-init.js +53 -0
  6. package/db/migrations/postgresql/package.json +3 -0
  7. package/db/migrations/postgresql/sqls/20220916133717-init-down.sql +6 -0
  8. package/db/migrations/postgresql/sqls/20220916133717-init-up.sql +102 -0
  9. package/db/migrations/postgresql/sqls/package.json +3 -0
  10. package/dist/integration-engine/datasources/MunicipalLibrariesDataSource.d.ts +4 -0
  11. package/dist/integration-engine/datasources/MunicipalLibrariesDataSource.js +21 -0
  12. package/dist/integration-engine/datasources/MunicipalLibrariesDataSource.js.map +1 -0
  13. package/dist/integration-engine/datasources/index.d.ts +1 -0
  14. package/dist/integration-engine/datasources/index.js +19 -0
  15. package/dist/integration-engine/datasources/index.js.map +1 -0
  16. package/dist/integration-engine/index.d.ts +2 -3
  17. package/dist/integration-engine/index.js +5 -3
  18. package/dist/integration-engine/index.js.map +1 -1
  19. package/dist/integration-engine/repositories/DepartmentsRepository.d.ts +4 -0
  20. package/dist/integration-engine/repositories/DepartmentsRepository.js +19 -0
  21. package/dist/integration-engine/repositories/DepartmentsRepository.js.map +1 -0
  22. package/dist/integration-engine/repositories/LibraryDepartmentsRepository.d.ts +4 -0
  23. package/dist/integration-engine/repositories/LibraryDepartmentsRepository.js +19 -0
  24. package/dist/integration-engine/repositories/LibraryDepartmentsRepository.js.map +1 -0
  25. package/dist/integration-engine/repositories/LibraryServicesRepository.d.ts +4 -0
  26. package/dist/integration-engine/repositories/LibraryServicesRepository.js +19 -0
  27. package/dist/integration-engine/repositories/LibraryServicesRepository.js.map +1 -0
  28. package/dist/integration-engine/repositories/MunicipalLibrariesRepository.d.ts +16 -0
  29. package/dist/integration-engine/repositories/MunicipalLibrariesRepository.js +140 -0
  30. package/dist/integration-engine/repositories/MunicipalLibrariesRepository.js.map +1 -0
  31. package/dist/integration-engine/repositories/OpeningHoursRepository.d.ts +4 -0
  32. package/dist/integration-engine/repositories/OpeningHoursRepository.js +19 -0
  33. package/dist/integration-engine/repositories/OpeningHoursRepository.js.map +1 -0
  34. package/dist/integration-engine/repositories/ServicesRepository.d.ts +4 -0
  35. package/dist/integration-engine/repositories/ServicesRepository.js +19 -0
  36. package/dist/integration-engine/repositories/ServicesRepository.js.map +1 -0
  37. package/dist/integration-engine/repositories/index.d.ts +6 -0
  38. package/dist/integration-engine/repositories/index.js +24 -0
  39. package/dist/integration-engine/repositories/index.js.map +1 -0
  40. package/dist/integration-engine/transformations/MunicipalLibrariesTransformation.d.ts +32 -0
  41. package/dist/integration-engine/transformations/MunicipalLibrariesTransformation.js +72 -0
  42. package/dist/integration-engine/transformations/MunicipalLibrariesTransformation.js.map +1 -0
  43. package/dist/integration-engine/transformations/helpers/TransformationHelper.d.ts +19 -0
  44. package/dist/integration-engine/transformations/helpers/TransformationHelper.js +95 -0
  45. package/dist/integration-engine/transformations/helpers/TransformationHelper.js.map +1 -0
  46. package/dist/integration-engine/workers/MunicipalLibrariesWorker.d.ts +5 -0
  47. package/dist/integration-engine/workers/MunicipalLibrariesWorker.js +16 -0
  48. package/dist/integration-engine/workers/MunicipalLibrariesWorker.js.map +1 -0
  49. package/dist/integration-engine/workers/index.d.ts +2 -0
  50. package/dist/integration-engine/workers/index.js +6 -0
  51. package/dist/integration-engine/workers/index.js.map +1 -0
  52. package/dist/integration-engine/workers/schemas/UpdateDistrictSchema.d.ts +6 -0
  53. package/dist/integration-engine/workers/schemas/UpdateDistrictSchema.js +21 -0
  54. package/dist/integration-engine/workers/schemas/UpdateDistrictSchema.js.map +1 -0
  55. package/dist/integration-engine/workers/tasks/RefreshDataInDBTask.d.ts +10 -0
  56. package/dist/integration-engine/workers/tasks/RefreshDataInDBTask.js +41 -0
  57. package/dist/integration-engine/workers/tasks/RefreshDataInDBTask.js.map +1 -0
  58. package/dist/integration-engine/workers/tasks/UpdateDistrictsTask.d.ts +12 -0
  59. package/dist/integration-engine/workers/tasks/UpdateDistrictsTask.js +47 -0
  60. package/dist/integration-engine/workers/tasks/UpdateDistrictsTask.js.map +1 -0
  61. package/dist/integration-engine/workers/tasks/index.d.ts +2 -0
  62. package/dist/integration-engine/workers/tasks/index.js +20 -0
  63. package/dist/integration-engine/workers/tasks/index.js.map +1 -0
  64. package/dist/output-gateway/MunicipalLibrariesRouter.d.ts +8 -0
  65. package/dist/output-gateway/MunicipalLibrariesRouter.js +15 -0
  66. package/dist/output-gateway/MunicipalLibrariesRouter.js.map +1 -0
  67. package/dist/output-gateway/index.d.ts +2 -0
  68. package/dist/output-gateway/index.js +19 -0
  69. package/dist/output-gateway/index.js.map +1 -0
  70. package/dist/output-gateway/repositories/DepartmentsRepository.d.ts +6 -0
  71. package/dist/output-gateway/repositories/DepartmentsRepository.js +28 -0
  72. package/dist/output-gateway/repositories/DepartmentsRepository.js.map +1 -0
  73. package/dist/output-gateway/repositories/LibraryDepartmentsRepository.d.ts +6 -0
  74. package/dist/output-gateway/repositories/LibraryDepartmentsRepository.js +28 -0
  75. package/dist/output-gateway/repositories/LibraryDepartmentsRepository.js.map +1 -0
  76. package/dist/output-gateway/repositories/LibraryServicesRepository.d.ts +6 -0
  77. package/dist/output-gateway/repositories/LibraryServicesRepository.js +28 -0
  78. package/dist/output-gateway/repositories/LibraryServicesRepository.js.map +1 -0
  79. package/dist/output-gateway/repositories/MunicipalLibrariesRepository.d.ts +17 -0
  80. package/dist/output-gateway/repositories/MunicipalLibrariesRepository.js +164 -0
  81. package/dist/output-gateway/repositories/MunicipalLibrariesRepository.js.map +1 -0
  82. package/dist/output-gateway/repositories/OpeningHoursRepository.d.ts +6 -0
  83. package/dist/output-gateway/repositories/OpeningHoursRepository.js +28 -0
  84. package/dist/output-gateway/repositories/OpeningHoursRepository.js.map +1 -0
  85. package/dist/output-gateway/repositories/ServicesRepository.d.ts +6 -0
  86. package/dist/output-gateway/repositories/ServicesRepository.js +28 -0
  87. package/dist/output-gateway/repositories/ServicesRepository.js.map +1 -0
  88. package/dist/output-gateway/repositories/index.d.ts +6 -0
  89. package/dist/output-gateway/repositories/index.js +23 -0
  90. package/dist/output-gateway/repositories/index.js.map +1 -0
  91. package/dist/schema-definitions/Departments.d.ts +10 -0
  92. package/dist/schema-definitions/Departments.js +8 -0
  93. package/dist/schema-definitions/Departments.js.map +1 -0
  94. package/dist/schema-definitions/Libraries.d.ts +16 -0
  95. package/dist/schema-definitions/Libraries.js +8 -0
  96. package/dist/schema-definitions/Libraries.js.map +1 -0
  97. package/dist/schema-definitions/LibraryDepartments.d.ts +8 -0
  98. package/dist/schema-definitions/LibraryDepartments.js +8 -0
  99. package/dist/schema-definitions/LibraryDepartments.js.map +1 -0
  100. package/dist/schema-definitions/LibraryServices.d.ts +8 -0
  101. package/dist/schema-definitions/LibraryServices.js +8 -0
  102. package/dist/schema-definitions/LibraryServices.js.map +1 -0
  103. package/dist/schema-definitions/OpeningHours.d.ts +15 -0
  104. package/dist/schema-definitions/OpeningHours.js +8 -0
  105. package/dist/schema-definitions/OpeningHours.js.map +1 -0
  106. package/dist/schema-definitions/Services.d.ts +9 -0
  107. package/dist/schema-definitions/Services.js +8 -0
  108. package/dist/schema-definitions/Services.js.map +1 -0
  109. package/dist/schema-definitions/datasources/MunicipalLibrariesJsonSchema.d.ts +78 -0
  110. package/dist/schema-definitions/datasources/MunicipalLibrariesJsonSchema.js +209 -0
  111. package/dist/schema-definitions/datasources/MunicipalLibrariesJsonSchema.js.map +1 -0
  112. package/dist/schema-definitions/index.d.ts +1 -314
  113. package/dist/schema-definitions/index.js +19 -265
  114. package/dist/schema-definitions/index.js.map +1 -1
  115. package/dist/schema-definitions/models/DepartmentsModel.d.ts +12 -0
  116. package/dist/schema-definitions/models/DepartmentsModel.js +33 -0
  117. package/dist/schema-definitions/models/DepartmentsModel.js.map +1 -0
  118. package/dist/schema-definitions/models/LibrariesModel.d.ts +18 -0
  119. package/dist/schema-definitions/models/LibrariesModel.js +46 -0
  120. package/dist/schema-definitions/models/LibrariesModel.js.map +1 -0
  121. package/dist/schema-definitions/models/LibraryDepartmentsModel.d.ts +10 -0
  122. package/dist/schema-definitions/models/LibraryDepartmentsModel.js +30 -0
  123. package/dist/schema-definitions/models/LibraryDepartmentsModel.js.map +1 -0
  124. package/dist/schema-definitions/models/LibraryServicesModel.d.ts +10 -0
  125. package/dist/schema-definitions/models/LibraryServicesModel.js +30 -0
  126. package/dist/schema-definitions/models/LibraryServicesModel.js.map +1 -0
  127. package/dist/schema-definitions/models/OpeningHoursModel.d.ts +17 -0
  128. package/dist/schema-definitions/models/OpeningHoursModel.js +44 -0
  129. package/dist/schema-definitions/models/OpeningHoursModel.js.map +1 -0
  130. package/dist/schema-definitions/models/ServicesModel.d.ts +11 -0
  131. package/dist/schema-definitions/models/ServicesModel.js +31 -0
  132. package/dist/schema-definitions/models/ServicesModel.js.map +1 -0
  133. package/dist/schema-definitions/models/index.d.ts +6 -0
  134. package/dist/schema-definitions/models/index.js +24 -0
  135. package/dist/schema-definitions/models/index.js.map +1 -0
  136. package/package.json +64 -58
  137. package/db/example/mongo_data/dataplatform/municipallibraries.bson +0 -0
  138. package/db/example/mongo_data/dataplatform/municipallibraries.metadata.json +0 -1
  139. package/dist/integration-engine/MunicipalLibrariesTransformation.d.ts +0 -9
  140. package/dist/integration-engine/MunicipalLibrariesTransformation.js +0 -150
  141. package/dist/integration-engine/MunicipalLibrariesTransformation.js.map +0 -1
  142. package/dist/integration-engine/MunicipalLibrariesWorker.d.ts +0 -11
  143. package/dist/integration-engine/MunicipalLibrariesWorker.js +0 -105
  144. package/dist/integration-engine/MunicipalLibrariesWorker.js.map +0 -1
  145. package/dist/integration-engine/queueDefinitions.d.ts +0 -3
  146. package/dist/integration-engine/queueDefinitions.js +0 -36
  147. 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,4 @@
1
+ import { IModel, PostgresModel } from "@golemio/core/dist/integration-engine/models";
2
+ export declare class ServicesRepository extends PostgresModel implements IModel {
3
+ constructor();
4
+ }
@@ -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":";;;;;;;AAAA,8EAA4E;AAC5E,gGAA+D;AAC/D,uHAUuD;AAKvD,MAAa,oBAAoB;;AAAjC,oDAgHC;;AA/GiB,kCAAa,GAAG,CAAC,OAAwB,EAAW,EAAE;IAChE,IAAI,OAAO,CAAC,EAAE,KAAK,IAAI,EAAE;QACrB,OAAO,KAAK,CAAC;KAChB;IAED,yBAAyB;IACzB,IAAI,OAAO,CAAC,SAAS,KAAK,IAAI,EAAE;QAC5B,wBAAG,CAAC,KAAK,CAAC,mBAAmB,OAAO,CAAC,KAAK,qBAAqB,CAAC,CAAC;QACjE,OAAO,KAAK,CAAC;KAChB;IAED,iCAAiC;IACjC,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;IACnF,IAAI,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE;QAC9B,wBAAG,CAAC,KAAK,CAAC,eAAe,OAAO,CAAC,KAAK,qBAAqB,CAAC,CAAC;QAC7D,OAAO,KAAK,CAAC;KAChB;IAED,OAAO,IAAI,CAAC;AAChB,CAAE,CAAA;AAEY,+BAAU,GAAG,CAAC,OAAsB,EAAkB,EAAE;IAClE,OAAO;QACH,eAAe,EAAE,OAAO;QACxB,iBAAiB,EAAE,GAAG,OAAO,CAAC,KAAK,IAAI,OAAO,CAAC,KAAK,KAAK,OAAO,CAAC,GAAG,IAAI,OAAO,CAAC,KAAK,SAAS;QAC9F,gBAAgB,EAAE,OAAO,CAAC,KAAK;QAC/B,WAAW,EAAE,OAAO,CAAC,GAAG;QACxB,cAAc,EAAE,GAAG,OAAO,CAAC,KAAK,IAAI,OAAO,CAAC,KAAK,EAAE;KACtD,CAAC;AACN,CAAE,CAAA;AAEa,oCAAe,GAAG,CAAC,YAAgC,EAAE,SAAiB,EAAoC,EAAE;;IACvH,MAAM,GAAG,GAAqC,EAAE,CAAC;IAEjD,MAAM,MAAM,GAAG;QACX,UAAU,EAAE,SAAS;QACrB,WAAW,EAAE,YAAY,CAAC,KAAK;QAC/B,UAAU,EAAE,YAAY,CAAC,SAAS,KAAK,MAAM;QAC7C,UAAU,EAAE,CAAA,MAAA,YAAY,CAAC,QAAQ,0CAAE,EAAE,EAAC,CAAC,CAAC,yBAAM,CAAC,EAAE,CAAC,YAAY,CAAC,QAAQ,CAAC,EAAE,EAAE,eAAe,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,IAAI;QACjH,aAAa,EAAE,CAAA,MAAA,YAAY,CAAC,QAAQ,0CAAE,EAAE,EAAC,CAAC,CAAC,yBAAM,CAAC,EAAE,CAAC,YAAY,CAAC,QAAQ,CAAC,EAAE,EAAE,eAAe,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,IAAI;KACvH,CAAC;IAEF,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,+CAAgB,CAAwB,EAAE;QACpE,IAAI,YAAY,CAAC,GAAG,CAAC,EAAE;YACnB,IAAI,YAAY,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE;gBACxB,GAAG,CAAC,IAAI,iBACJ,KAAK,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,EAChC,MAAM,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,EACjC,WAAW,EAAE,+CAAgB,CAAC,GAAG,CAAC,IAC/B,MAAM,EACX,CAAC;aACN;YACD,IAAI,YAAY,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE;gBAC7B,GAAG,CAAC,IAAI,iBACJ,KAAK,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC,SAAU,CAAC,EAAE,EACtC,MAAM,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC,SAAU,CAAC,EAAE,EACvC,WAAW,EAAE,+CAAgB,CAAC,GAAG,CAAC,IAC/B,MAAM,EACX,CAAC;aACN;SACJ;KACJ;IAED,OAAO,GAAG,CAAC;AACf,CAAE,CAAA;AAEY,0CAAqB,GAAG,CAClC,YAAuD,EACvD,SAAiB,EACe,EAAE;IAClC,OAAO,YAAY,YAAY,KAAK;QAChC,CAAC,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,EAAI,CAAC,eAAe,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;QACtE,CAAC,CAAC,EAAI,CAAC,eAAe,CAAC,YAAY,EAAE,SAAS,CAAC,CAAC;AACxD,CAAE,CAAA;AAEa,+BAAU,GAAG,CAAC,OAAsB,EAAE,SAAiB,EAAsC,EAAE;IAC1G,OAAO;QACH,EAAE,EAAE,QAAQ,CAAC,OAAO,CAAC,EAAE,EAAE,EAAE,CAAC;QAC5B,UAAU,EAAE,SAAS;QACrB,IAAI,EAAE,OAAO,CAAC,KAAK;QACnB,WAAW,EAAE,OAAO,CAAC,KAAK;KAC7B,CAAC;AACN,CAAE,CAAA;AAEY,sCAAiB,GAAG,CAC9B,QAAwB,EACxB,SAAiB,EACwB,EAAE;IAC3C,OAAO,QAAQ,CAAC,MAAM,YAAY,KAAK;QACnC,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,EAAI,CAAC,UAAU,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;QAC3D,CAAC,CAAC,CAAC,EAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC;AACxD,CAAE,CAAA;AAEa,kCAAa,GAAG,CAAC,WAA6B,EAAE,SAAiB,EAAyC,EAAE;IACvH,OAAO;QACH,EAAE,EAAE,WAAW,CAAC,EAAE;QAClB,UAAU,EAAE,SAAS;QACrB,IAAI,EAAE,WAAW,CAAC,KAAK;QACvB,IAAI,EAAE,WAAW,CAAC,GAAG;QACrB,GAAG,EAAE,WAAW,CAAC,GAAG;KACvB,CAAC;AACN,CAAE,CAAA;AAEY,yCAAoB,GAAG,CACjC,WAA8B,EAC9B,SAAiB,EAC2B,EAAE;IAC9C,OAAO,WAAW,CAAC,QAAQ,YAAY,KAAK;QACxC,CAAC,CAAC,WAAW,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,EAAI,CAAC,aAAa,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;QACnE,CAAC,CAAC,CAAC,EAAI,CAAC,aAAa,CAAC,WAAW,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC,CAAC;AAChE,CAAE,CAAA"}
@@ -0,0 +1,5 @@
1
+ import { AbstractWorker } from "@golemio/core/dist/integration-engine/workers";
2
+ export declare class MunicipalLibrariesWorker extends AbstractWorker {
3
+ protected readonly name = "MunicipalLibraries";
4
+ constructor();
5
+ }
@@ -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,2 @@
1
+ import { MunicipalLibrariesWorker } from "./MunicipalLibrariesWorker";
2
+ export declare const workers: (typeof MunicipalLibrariesWorker)[];
@@ -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,6 @@
1
+ export interface IUpdateDistrictInput {
2
+ id: number;
3
+ }
4
+ export declare class UpdateDistrictValidationSchema implements IUpdateDistrictInput {
5
+ id: number;
6
+ }
@@ -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,2 @@
1
+ export * from "./UpdateDistrictsTask";
2
+ export * from "./RefreshDataInDBTask";
@@ -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,2 @@
1
+ export * from "./repositories";
2
+ export * from "./MunicipalLibrariesRouter";
@@ -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"}
@@ -0,0 +1,6 @@
1
+ import { SequelizeModel } from "@golemio/core/dist/output-gateway/models";
2
+ export declare class DepartmentsRepository extends SequelizeModel {
3
+ constructor();
4
+ GetAll: () => Promise<any>;
5
+ GetOne: () => Promise<any>;
6
+ }