@golemio/pid 4.1.3-dev.2031784972 → 4.1.3-dev.2040558248
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/dist/helpers/jis/JISEventTranslationHelper.d.ts +4 -0
- package/dist/helpers/jis/JISEventTranslationHelper.js +46 -0
- package/dist/helpers/jis/JISEventTranslationHelper.js.map +1 -0
- package/dist/helpers/jis/interfaces/IJISEventCustomFormatDto.d.ts +33 -0
- package/dist/helpers/jis/interfaces/IJISEventCustomFormatDto.js +3 -0
- package/dist/helpers/jis/interfaces/IJISEventCustomFormatDto.js.map +1 -0
- package/dist/input-gateway/jis/controllers/JISEventsController.js +1 -1
- package/dist/input-gateway/jis/controllers/JISEventsController.js.map +1 -1
- package/dist/integration-engine/jis/datasources/JISEventsDataSourceFactory.js +7 -5
- package/dist/integration-engine/jis/datasources/JISEventsDataSourceFactory.js.map +1 -1
- package/dist/integration-engine/jis/datasources/JISInfotextsDataSourceFactory.js +7 -5
- package/dist/integration-engine/jis/datasources/JISInfotextsDataSourceFactory.js.map +1 -1
- package/dist/integration-engine/jis/ioc/Di.js +7 -1
- package/dist/integration-engine/jis/ioc/Di.js.map +1 -1
- package/dist/integration-engine/jis/ioc/JISContainerToken.d.ts +3 -0
- package/dist/integration-engine/jis/ioc/JISContainerToken.js +3 -0
- package/dist/integration-engine/jis/ioc/JISContainerToken.js.map +1 -1
- package/dist/integration-engine/jis/services/JISEventsDataService.d.ts +2 -1
- package/dist/integration-engine/jis/services/JISEventsDataService.js +7 -1
- package/dist/integration-engine/jis/services/JISEventsDataService.js.map +1 -1
- package/dist/integration-engine/jis/transformations/UpdateEventWebhookTransformation.d.ts +13 -0
- package/dist/integration-engine/jis/transformations/UpdateEventWebhookTransformation.js +62 -0
- package/dist/integration-engine/jis/transformations/UpdateEventWebhookTransformation.js.map +1 -0
- package/dist/integration-engine/jis/workers/JISWorker.js +1 -0
- package/dist/integration-engine/jis/workers/JISWorker.js.map +1 -1
- package/dist/integration-engine/jis/workers/tasks/RefreshJISEventsTask.d.ts +9 -2
- package/dist/integration-engine/jis/workers/tasks/RefreshJISEventsTask.js +28 -3
- package/dist/integration-engine/jis/workers/tasks/RefreshJISEventsTask.js.map +1 -1
- package/dist/integration-engine/jis/workers/tasks/UpdateEventWebhookTask.d.ts +21 -0
- package/dist/integration-engine/jis/workers/tasks/UpdateEventWebhookTask.js +132 -0
- package/dist/integration-engine/jis/workers/tasks/UpdateEventWebhookTask.js.map +1 -0
- package/dist/integration-engine/vehicle-positions/workers/gtfs-rt/helpers/AlertsGenerator.js +1 -1
- package/dist/integration-engine/vehicle-positions/workers/gtfs-rt/helpers/AlertsGenerator.js.map +1 -1
- package/dist/integration-engine/vehicle-positions/workers/vehicle-positions/helpers/DelayComputationManager.js +1 -1
- package/dist/integration-engine/vehicle-positions/workers/vehicle-positions/helpers/DelayComputationManager.js.map +1 -1
- package/dist/output-gateway/jis/domain/IJISEventsInterfaces.d.ts +0 -31
- package/dist/output-gateway/jis/ioc/Di.js +1 -5
- package/dist/output-gateway/jis/ioc/Di.js.map +1 -1
- package/dist/output-gateway/jis/ioc/OgJisToken.d.ts +0 -1
- package/dist/output-gateway/jis/ioc/OgJisToken.js +0 -1
- package/dist/output-gateway/jis/ioc/OgJisToken.js.map +1 -1
- package/dist/output-gateway/jis/transformations/JISEventsCustomFormatTransformation.d.ts +2 -5
- package/dist/output-gateway/jis/transformations/JISEventsCustomFormatTransformation.js +6 -16
- package/dist/output-gateway/jis/transformations/JISEventsCustomFormatTransformation.js.map +1 -1
- package/dist/schema-definitions/jis/constants/jisEventType.d.ts +2 -0
- package/dist/schema-definitions/jis/constants/jisEventType.js +5 -0
- package/dist/schema-definitions/jis/constants/jisEventType.js.map +1 -0
- package/dist/schema-definitions/jis/datasources/JISEventsJsonSchema.js +2 -1
- package/dist/schema-definitions/jis/datasources/JISEventsJsonSchema.js.map +1 -1
- package/dist/schema-definitions/jis/datasources/interfaces/IJISEvent.d.ts +2 -1
- package/dist/schema-definitions/jis/models/JISEventsModel.js +2 -1
- package/dist/schema-definitions/jis/models/JISEventsModel.js.map +1 -1
- package/docs/asyncapi.yaml +33 -5
- package/docs/implementation_documentation.md +55 -8
- package/package.json +1 -1
- package/dist/output-gateway/jis/helpers/TranslationHelper.d.ts +0 -4
- package/dist/output-gateway/jis/helpers/TranslationHelper.js +0 -48
- package/dist/output-gateway/jis/helpers/TranslationHelper.js.map +0 -1
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.JISEventTranslationHelper = void 0;
|
|
4
|
+
class JISEventTranslationHelper {
|
|
5
|
+
static effectToCs(effect) {
|
|
6
|
+
const effects = {
|
|
7
|
+
NO_SERVICE: "Přerušení provozu",
|
|
8
|
+
REDUCED_SERVICE: "Omezení provozu",
|
|
9
|
+
SIGNIFICANT_DELAYS: "Zpoždění",
|
|
10
|
+
DETOUR: "Odklon",
|
|
11
|
+
ADDITIONAL_SERVICE: "Posílení spojů",
|
|
12
|
+
MODIFIED_SERVICE: "Změna provozu",
|
|
13
|
+
OTHER_EFFECT: "Ostatní opatření",
|
|
14
|
+
UNKNOWN_EFFECT: "Neznámé opatření",
|
|
15
|
+
STOP_MOVED: "Zastávka přemístěna",
|
|
16
|
+
NO_EFFECT: "Bez opatření",
|
|
17
|
+
ACCESSIBILITY_ISSUE: "Omezení bezbariérového přístupu",
|
|
18
|
+
};
|
|
19
|
+
if (!effects[effect]) {
|
|
20
|
+
return "Neplatný typ události";
|
|
21
|
+
}
|
|
22
|
+
return effects[effect].charAt(0).toUpperCase() + effects[effect].slice(1);
|
|
23
|
+
}
|
|
24
|
+
static causeToCs(cause) {
|
|
25
|
+
const causes = {
|
|
26
|
+
ACCIDENT: "Nehoda",
|
|
27
|
+
STRIKE: "Stávka",
|
|
28
|
+
TECHNICAL_PROBLEM: "Technický problém",
|
|
29
|
+
CONSTRUCTION: "Stavba",
|
|
30
|
+
WEATHER: "Počasí",
|
|
31
|
+
DEMONSTRATION: "Demonstrace",
|
|
32
|
+
POLICE_ACTIVITY: "Policejní uzávěra",
|
|
33
|
+
MEDICAL_EMERGENCY: "Zásah záchranné služby",
|
|
34
|
+
OTHER_CAUSE: "Jiný důvod",
|
|
35
|
+
UNKNOWN_CAUSE: "Neznámý důvod",
|
|
36
|
+
HOLIDAY: "Svátek",
|
|
37
|
+
MAINTENANCE: "Údržba",
|
|
38
|
+
};
|
|
39
|
+
if (!causes[cause]) {
|
|
40
|
+
return "Neplatný důvod události";
|
|
41
|
+
}
|
|
42
|
+
return causes[cause].charAt(0).toUpperCase() + causes[cause].slice(1);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
exports.JISEventTranslationHelper = JISEventTranslationHelper;
|
|
46
|
+
//# sourceMappingURL=JISEventTranslationHelper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"JISEventTranslationHelper.js","sourceRoot":"","sources":["../../../src/helpers/jis/JISEventTranslationHelper.ts"],"names":[],"mappings":";;;AAAA,MAAa,yBAAyB;IAC3B,MAAM,CAAC,UAAU,CAAC,MAAc;QACnC,MAAM,OAAO,GAA2B;YACpC,UAAU,EAAE,mBAAmB;YAC/B,eAAe,EAAE,iBAAiB;YAClC,kBAAkB,EAAE,UAAU;YAC9B,MAAM,EAAE,QAAQ;YAChB,kBAAkB,EAAE,gBAAgB;YACpC,gBAAgB,EAAE,eAAe;YACjC,YAAY,EAAE,kBAAkB;YAChC,cAAc,EAAE,kBAAkB;YAClC,UAAU,EAAE,qBAAqB;YACjC,SAAS,EAAE,cAAc;YACzB,mBAAmB,EAAE,iCAAiC;SACzD,CAAC;QACF,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YAClB,OAAO,uBAAuB,CAAC;SAClC;QACD,OAAO,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAC9E,CAAC;IAEM,MAAM,CAAC,SAAS,CAAC,KAAa;QACjC,MAAM,MAAM,GAA2B;YACnC,QAAQ,EAAE,QAAQ;YAClB,MAAM,EAAE,QAAQ;YAChB,iBAAiB,EAAE,mBAAmB;YACtC,YAAY,EAAE,QAAQ;YACtB,OAAO,EAAE,QAAQ;YACjB,aAAa,EAAE,aAAa;YAC5B,eAAe,EAAE,mBAAmB;YACpC,iBAAiB,EAAE,wBAAwB;YAC3C,WAAW,EAAE,YAAY;YACzB,aAAa,EAAE,eAAe;YAC9B,OAAO,EAAE,QAAQ;YACjB,WAAW,EAAE,QAAQ;SACxB,CAAC;QACF,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE;YAChB,OAAO,yBAAyB,CAAC;SACpC;QAED,OAAO,MAAM,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAC1E,CAAC;CACJ;AA1CD,8DA0CC"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { IJISTranslationText } from "../../../schema-definitions/jis/models/interfaces";
|
|
2
|
+
import { RouteDto } from "../../../schema-definitions/ropid-gtfs/models/RouteDto";
|
|
3
|
+
export interface IJISEventCustomFormatDto {
|
|
4
|
+
id: string;
|
|
5
|
+
type: string;
|
|
6
|
+
header_text: IJISTranslationText;
|
|
7
|
+
cause: IJISTranslationText;
|
|
8
|
+
cause_detail: IJISTranslationText;
|
|
9
|
+
severity_level: string;
|
|
10
|
+
active_period: {
|
|
11
|
+
start: string;
|
|
12
|
+
end?: string | null;
|
|
13
|
+
};
|
|
14
|
+
display_period: {
|
|
15
|
+
start: string;
|
|
16
|
+
end?: string | null;
|
|
17
|
+
};
|
|
18
|
+
effects: IJISTranslationText[];
|
|
19
|
+
description_text: IJISTranslationText;
|
|
20
|
+
description_html: IJISTranslationText;
|
|
21
|
+
organization_name: string;
|
|
22
|
+
informed_entity?: {
|
|
23
|
+
routes?: Array<{
|
|
24
|
+
id: string;
|
|
25
|
+
route_short_name: string;
|
|
26
|
+
route_long_name: string;
|
|
27
|
+
route_type: number;
|
|
28
|
+
}>;
|
|
29
|
+
} | null;
|
|
30
|
+
last_modified_timestamp: string;
|
|
31
|
+
created_timestamp: string;
|
|
32
|
+
}
|
|
33
|
+
export type IJISEventRouteDto = Pick<RouteDto, "route_long_name" | "route_short_name" | "route_type" | "route_id">;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"IJISEventCustomFormatDto.js","sourceRoot":"","sources":["../../../../src/helpers/jis/interfaces/IJISEventCustomFormatDto.ts"],"names":[],"mappings":""}
|
|
@@ -11,7 +11,7 @@ class JISEventsController extends controllers_1.BaseController {
|
|
|
11
11
|
this.processData = async (inputData) => {
|
|
12
12
|
try {
|
|
13
13
|
await this.validator.Validate(inputData);
|
|
14
|
-
await this.sendMessageToExchange("input." + this.queuePrefix + ".refreshJISEvents", JSON.stringify(inputData));
|
|
14
|
+
await this.sendMessageToExchange("input." + this.queuePrefix + ".refreshJISEvents", JSON.stringify({ data: inputData, shouldTriggerWebhooks: true }));
|
|
15
15
|
}
|
|
16
16
|
catch (err) {
|
|
17
17
|
if (err instanceof golemio_errors_1.AbstractGolemioError) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"JISEventsController.js","sourceRoot":"","sources":["../../../../src/input-gateway/jis/controllers/JISEventsController.ts"],"names":[],"mappings":";;;AAAA,yGAA+E;AAC/E,8EAA8E;AAC9E,6EAA8F;AAC9F,mFAAkF;AAElF,MAAa,mBAAoB,SAAQ,4BAAc;IAKnD;QACI,KAAK,CAAC,KAAK,EAAE,IAAI,uCAAmB,CAAC,yBAAyB,EAAE,yCAAmB,CAAC,CAAC,CAAC;QAInF,gBAAW,GAAG,KAAK,EAAE,SAAc,EAAiB,EAAE;YACzD,IAAI;gBACA,MAAM,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;gBACzC,MAAM,IAAI,CAAC,qBAAqB,
|
|
1
|
+
{"version":3,"file":"JISEventsController.js","sourceRoot":"","sources":["../../../../src/input-gateway/jis/controllers/JISEventsController.ts"],"names":[],"mappings":";;;AAAA,yGAA+E;AAC/E,8EAA8E;AAC9E,6EAA8F;AAC9F,mFAAkF;AAElF,MAAa,mBAAoB,SAAQ,4BAAc;IAKnD;QACI,KAAK,CAAC,KAAK,EAAE,IAAI,uCAAmB,CAAC,yBAAyB,EAAE,yCAAmB,CAAC,CAAC,CAAC;QAInF,gBAAW,GAAG,KAAK,EAAE,SAAc,EAAiB,EAAE;YACzD,IAAI;gBACA,MAAM,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;gBACzC,MAAM,IAAI,CAAC,qBAAqB,CAC5B,QAAQ,GAAG,IAAI,CAAC,WAAW,GAAG,mBAAmB,EACjD,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,qBAAqB,EAAE,IAAI,EAAE,CAAC,CACnE,CAAC;aACL;YAAC,OAAO,GAAG,EAAE;gBACV,IAAI,GAAG,YAAY,qCAAoB,EAAE;oBACrC,MAAM,GAAG,CAAC;iBACb;qBAAM;oBACH,MAAM,IAAI,6BAAY,CAAC,oCAAoC,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;iBACjG;aACJ;QACL,CAAC,CAAC;QAjBE,IAAI,CAAC,IAAI,GAAG,qBAAqB,CAAC;IACtC,CAAC;CAiBJ;AAzBD,kDAyBC"}
|
|
@@ -28,16 +28,18 @@ let JISEventsDataSourceFactory = exports.JISEventsDataSourceFactory = JISEventsD
|
|
|
28
28
|
return new integration_engine_1.DataSource(JISEventsDataSourceFactory_1.DATASOURCE_NAME, this.getProtocolStrategy(etag), new integration_engine_1.JSONDataTypeStrategy({ resultsPath: "" }), new golemio_validator_1.JSONSchemaValidator(JISEventsDataSourceFactory_1.DATASOURCE_NAME + "Validator", JISEventsJsonSchema_1.jisEventsJsonSchema));
|
|
29
29
|
}
|
|
30
30
|
getProtocolStrategy(etag) {
|
|
31
|
-
const baseUrl = this.config.getValue("module.pid.jis.baseUrl");
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
31
|
+
const baseUrl = this.config.getValue("module.pid.jis.vymiApi.baseUrl");
|
|
32
|
+
const urlPath = this.config.getValue("module.pid.jis.vymiApi.events.path");
|
|
33
|
+
let headers = {
|
|
34
|
+
...this.config.getValue("module.pid.jis.vymiApi.commonHeaders", {}),
|
|
35
|
+
...this.config.getValue("module.pid.jis.vymiApi.events.headers", {}),
|
|
36
|
+
};
|
|
35
37
|
if (typeof etag === "string") {
|
|
36
38
|
headers = { ...headers, "If-None-Match": etag, "Cache-Control": "no-store" };
|
|
37
39
|
}
|
|
38
40
|
return new HTTPFetchProtocolStrategy_1.HTTPFetchProtocolStrategy({
|
|
39
41
|
method: "GET",
|
|
40
|
-
url,
|
|
42
|
+
url: new URL(urlPath, baseUrl).toString(),
|
|
41
43
|
headers,
|
|
42
44
|
timeoutInSeconds: 20,
|
|
43
45
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"JISEventsDataSourceFactory.js","sourceRoot":"","sources":["../../../../src/integration-engine/jis/datasources/JISEventsDataSourceFactory.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AACA,yGAA+E;AAE/E,wEAAqE;AACrE,8EAAwH;AACxH,6IAA0I;AAC1I,mFAAkF;AAClF,iEAAwE;AAGjE,IAAM,0BAA0B,uEAAhC,MAAM,0BAA0B;IACnC,YAAoD,MAAqB;QAArB,WAAM,GAAN,MAAM,CAAe;IAAG,CAAC;IAItE,aAAa,CAAC,IAAa;QAC9B,OAAO,IAAI,+BAAU,CACjB,4BAA0B,CAAC,eAAe,EAC1C,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,EAC9B,IAAI,yCAAoB,CAAC,EAAE,WAAW,EAAE,EAAE,EAAE,CAAC,EAC7C,IAAI,uCAAmB,CAAC,4BAA0B,CAAC,eAAe,GAAG,WAAW,EAAE,yCAAmB,CAAC,CACzG,CAAC;IACN,CAAC;IAEO,mBAAmB,CAAC,IAAa;QACrC,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAS,
|
|
1
|
+
{"version":3,"file":"JISEventsDataSourceFactory.js","sourceRoot":"","sources":["../../../../src/integration-engine/jis/datasources/JISEventsDataSourceFactory.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AACA,yGAA+E;AAE/E,wEAAqE;AACrE,8EAAwH;AACxH,6IAA0I;AAC1I,mFAAkF;AAClF,iEAAwE;AAGjE,IAAM,0BAA0B,uEAAhC,MAAM,0BAA0B;IACnC,YAAoD,MAAqB;QAArB,WAAM,GAAN,MAAM,CAAe;IAAG,CAAC;IAItE,aAAa,CAAC,IAAa;QAC9B,OAAO,IAAI,+BAAU,CACjB,4BAA0B,CAAC,eAAe,EAC1C,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,EAC9B,IAAI,yCAAoB,CAAC,EAAE,WAAW,EAAE,EAAE,EAAE,CAAC,EAC7C,IAAI,uCAAmB,CAAC,4BAA0B,CAAC,eAAe,GAAG,WAAW,EAAE,yCAAmB,CAAC,CACzG,CAAC;IACN,CAAC;IAEO,mBAAmB,CAAC,IAAa;QACrC,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAS,gCAAgC,CAAC,CAAC;QAC/E,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAS,oCAAoC,CAAC,CAAC;QAEnF,IAAI,OAAO,GAAgB;YACvB,GAAI,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAc,sCAAsC,EAAE,EAAE,CAAiB;YACjG,GAAI,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAc,uCAAuC,EAAE,EAAE,CAAiB;SACrG,CAAC;QACF,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE;YAC1B,OAAO,GAAG,EAAE,GAAG,OAAO,EAAE,eAAe,EAAE,IAAI,EAAE,eAAe,EAAE,UAAU,EAAE,CAAC;SAChF;QAED,OAAO,IAAI,qDAAyB,CAAC;YACjC,MAAM,EAAE,KAAK;YACb,GAAG,EAAE,IAAI,GAAG,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,QAAQ,EAAE;YACzC,OAAO;YACP,gBAAgB,EAAE,EAAE;SACvB,CAAC,CAAC;IACP,CAAC;;AA7Bc,0CAAe,GAAG,qBAAqB,AAAxB,CAAyB;qCAH9C,0BAA0B;IADtC,IAAA,qBAAU,GAAE;IAEI,WAAA,IAAA,iBAAM,EAAC,qBAAS,CAAC,YAAY,CAAC,CAAA;;GADlC,0BAA0B,CAiCtC"}
|
|
@@ -28,16 +28,18 @@ let JISInfotextsDataSourceFactory = exports.JISInfotextsDataSourceFactory = JISI
|
|
|
28
28
|
return new integration_engine_1.DataSource(JISInfotextsDataSourceFactory_1.DATASOURCE_NAME, this.getProtocolStrategy(etag), new integration_engine_1.JSONDataTypeStrategy({ resultsPath: "" }), new golemio_validator_1.JSONSchemaValidator(JISInfotextsDataSourceFactory_1.DATASOURCE_NAME + "Validator", JISInfotextsJsonSchema_1.jisInfotextsJsonSchema));
|
|
29
29
|
}
|
|
30
30
|
getProtocolStrategy(etag) {
|
|
31
|
-
const baseUrl = this.config.getValue("module.pid.jis.baseUrl");
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
31
|
+
const baseUrl = this.config.getValue("module.pid.jis.vymiApi.baseUrl");
|
|
32
|
+
const urlPath = this.config.getValue("module.pid.jis.vymiApi.infotexts.path");
|
|
33
|
+
let headers = {
|
|
34
|
+
...this.config.getValue("module.pid.jis.vymiApi.commonHeaders", {}),
|
|
35
|
+
...this.config.getValue("module.pid.jis.vymiApi.infotexts.headers", {}),
|
|
36
|
+
};
|
|
35
37
|
if (typeof etag === "string") {
|
|
36
38
|
headers = { ...headers, "If-None-Match": etag, "Cache-Control": "no-store" };
|
|
37
39
|
}
|
|
38
40
|
return new HTTPFetchProtocolStrategy_1.HTTPFetchProtocolStrategy({
|
|
39
41
|
method: "GET",
|
|
40
|
-
url,
|
|
42
|
+
url: new URL(urlPath, baseUrl).toString(),
|
|
41
43
|
headers,
|
|
42
44
|
timeoutInSeconds: 20,
|
|
43
45
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"JISInfotextsDataSourceFactory.js","sourceRoot":"","sources":["../../../../src/integration-engine/jis/datasources/JISInfotextsDataSourceFactory.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AACA,+GAAqF;AAErF,wEAAqE;AACrE,8EAAwH;AACxH,6IAA0I;AAC1I,mFAAkF;AAClF,iEAAwE;AAGjE,IAAM,6BAA6B,6EAAnC,MAAM,6BAA6B;IACtC,YAAoD,MAAqB;QAArB,WAAM,GAAN,MAAM,CAAe;IAAG,CAAC;IAItE,aAAa,CAAC,IAAa;QAC9B,OAAO,IAAI,+BAAU,CACjB,+BAA6B,CAAC,eAAe,EAC7C,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,EAC9B,IAAI,yCAAoB,CAAC,EAAE,WAAW,EAAE,EAAE,EAAE,CAAC,EAC7C,IAAI,uCAAmB,CAAC,+BAA6B,CAAC,eAAe,GAAG,WAAW,EAAE,+CAAsB,CAAC,CAC/G,CAAC;IACN,CAAC;IAEO,mBAAmB,CAAC,IAAa;QACrC,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAS,
|
|
1
|
+
{"version":3,"file":"JISInfotextsDataSourceFactory.js","sourceRoot":"","sources":["../../../../src/integration-engine/jis/datasources/JISInfotextsDataSourceFactory.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AACA,+GAAqF;AAErF,wEAAqE;AACrE,8EAAwH;AACxH,6IAA0I;AAC1I,mFAAkF;AAClF,iEAAwE;AAGjE,IAAM,6BAA6B,6EAAnC,MAAM,6BAA6B;IACtC,YAAoD,MAAqB;QAArB,WAAM,GAAN,MAAM,CAAe;IAAG,CAAC;IAItE,aAAa,CAAC,IAAa;QAC9B,OAAO,IAAI,+BAAU,CACjB,+BAA6B,CAAC,eAAe,EAC7C,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,EAC9B,IAAI,yCAAoB,CAAC,EAAE,WAAW,EAAE,EAAE,EAAE,CAAC,EAC7C,IAAI,uCAAmB,CAAC,+BAA6B,CAAC,eAAe,GAAG,WAAW,EAAE,+CAAsB,CAAC,CAC/G,CAAC;IACN,CAAC;IAEO,mBAAmB,CAAC,IAAa;QACrC,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAS,gCAAgC,CAAC,CAAC;QAC/E,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAS,uCAAuC,CAAC,CAAC;QAEtF,IAAI,OAAO,GAAgB;YACvB,GAAI,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAc,sCAAsC,EAAE,EAAE,CAAiB;YACjG,GAAI,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAc,0CAA0C,EAAE,EAAE,CAAiB;SACxG,CAAC;QACF,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE;YAC1B,OAAO,GAAG,EAAE,GAAG,OAAO,EAAE,eAAe,EAAE,IAAI,EAAE,eAAe,EAAE,UAAU,EAAE,CAAC;SAChF;QAED,OAAO,IAAI,qDAAyB,CAAC;YACjC,MAAM,EAAE,KAAK;YACb,GAAG,EAAE,IAAI,GAAG,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,QAAQ,EAAE;YACzC,OAAO;YACP,gBAAgB,EAAE,EAAE;SACvB,CAAC,CAAC;IACP,CAAC;;AA7Bc,6CAAe,GAAG,wBAAwB,AAA3B,CAA4B;wCAHjD,6BAA6B;IADzC,IAAA,qBAAU,GAAE;IAEI,WAAA,IAAA,iBAAM,EAAC,qBAAS,CAAC,YAAY,CAAC,CAAA;;GADlC,6BAA6B,CAiCzC"}
|
|
@@ -15,14 +15,17 @@ const JISEventsDataService_1 = require("../services/JISEventsDataService");
|
|
|
15
15
|
const JISInfotextsDataService_1 = require("../services/JISInfotextsDataService");
|
|
16
16
|
const JISEventsGtfsRtTransformation_1 = require("../transformations/JISEventsGtfsRtTransformation");
|
|
17
17
|
const JISEventsTransformation_1 = require("../transformations/JISEventsTransformation");
|
|
18
|
+
const JISInfotextCacheTranformation_1 = require("../transformations/JISInfotextCacheTranformation");
|
|
18
19
|
const JISInfotextsTransformation_1 = require("../transformations/JISInfotextsTransformation");
|
|
20
|
+
const UpdateEventWebhookTransformation_1 = require("../transformations/UpdateEventWebhookTransformation");
|
|
19
21
|
const FetchJISEventsTask_1 = require("../workers/tasks/FetchJISEventsTask");
|
|
20
22
|
const FetchJISInfotextsTask_1 = require("../workers/tasks/FetchJISInfotextsTask");
|
|
21
23
|
const RefreshJISEventsTask_1 = require("../workers/tasks/RefreshJISEventsTask");
|
|
22
24
|
const RefreshJISInfotextsCacheTask_1 = require("../workers/tasks/RefreshJISInfotextsCacheTask");
|
|
23
25
|
const RefreshJISInfotextsTask_1 = require("../workers/tasks/RefreshJISInfotextsTask");
|
|
26
|
+
const UpdateEventWebhookTask_1 = require("../workers/tasks/UpdateEventWebhookTask");
|
|
24
27
|
const JISContainerToken_1 = require("./JISContainerToken");
|
|
25
|
-
const
|
|
28
|
+
const RopidGTFSRoutesRepository_1 = require("../../ropid-gtfs/data-access/RopidGTFSRoutesRepository");
|
|
26
29
|
//#region Initialization
|
|
27
30
|
const JISContainer = Di_1.PidContainer.createChildContainer();
|
|
28
31
|
exports.JISContainer = JISContainer;
|
|
@@ -41,6 +44,7 @@ JISContainer.registerSingleton(JISContainerToken_1.JISContainerToken.JISInfotext
|
|
|
41
44
|
JISContainer.registerSingleton(JISContainerToken_1.JISContainerToken.JISInfotextsRopidGTFSStopsRepository, JISInfotextsRopidGTFSStopsRepository_1.JISInfotextsRopidGTFSStopsRepository);
|
|
42
45
|
JISContainer.registerSingleton(JISContainerToken_1.JISContainerToken.JISMetadataRepository, JISMetadataRepository_1.JISMetadataRepository);
|
|
43
46
|
JISContainer.registerSingleton(JISContainerToken_1.JISContainerToken.RopidGTFSStopsRepository, RopidGTFSStopsModel_1.RopidGTFSStopsModel);
|
|
47
|
+
JISContainer.registerSingleton(JISContainerToken_1.JISContainerToken.RopidGTFSRoutesRepository, RopidGTFSRoutesRepository_1.RopidGTFSRoutesRepository);
|
|
44
48
|
//#endregion
|
|
45
49
|
//#region Services
|
|
46
50
|
JISContainer.registerSingleton(JISContainerToken_1.JISContainerToken.JISEventsDataService, JISEventsDataService_1.JISEventsDataService);
|
|
@@ -52,10 +56,12 @@ JISContainer.registerSingleton(JISContainerToken_1.JISContainerToken.FetchJISInf
|
|
|
52
56
|
JISContainer.registerSingleton(JISContainerToken_1.JISContainerToken.RefreshJISEventsTask, RefreshJISEventsTask_1.RefreshJISEventsTask);
|
|
53
57
|
JISContainer.registerSingleton(JISContainerToken_1.JISContainerToken.RefreshJISInfotextsTask, RefreshJISInfotextsTask_1.RefreshJISInfotextsTask);
|
|
54
58
|
JISContainer.registerSingleton(JISContainerToken_1.JISContainerToken.RefreshJISInfotextsCacheTask, RefreshJISInfotextsCacheTask_1.RefreshJISInfotextsCacheTask);
|
|
59
|
+
JISContainer.registerSingleton(JISContainerToken_1.JISContainerToken.UpdateEventWebhookTask, UpdateEventWebhookTask_1.UpdateEventWebhookTask);
|
|
55
60
|
//#endregion
|
|
56
61
|
//#region Transformations
|
|
57
62
|
JISContainer.registerSingleton(JISContainerToken_1.JISContainerToken.JISEventsTransformation, JISEventsTransformation_1.JISEventsTransformation);
|
|
58
63
|
JISContainer.registerSingleton(JISContainerToken_1.JISContainerToken.JISEventsGtfsRtTransformation, JISEventsGtfsRtTransformation_1.JISEventsGtfsRtTransformation);
|
|
59
64
|
JISContainer.registerSingleton(JISContainerToken_1.JISContainerToken.JISInfotextsTransformation, JISInfotextsTransformation_1.JISInfotextsTransformation);
|
|
60
65
|
JISContainer.registerSingleton(JISContainerToken_1.JISContainerToken.JISInfotextCacheTranformation, JISInfotextCacheTranformation_1.JISInfotextCacheTranformation);
|
|
66
|
+
JISContainer.registerSingleton(JISContainerToken_1.JISContainerToken.UpdateEventWebhookTransformation, UpdateEventWebhookTransformation_1.UpdateEventWebhookTransformation);
|
|
61
67
|
//# sourceMappingURL=Di.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Di.js","sourceRoot":"","sources":["../../../../src/integration-engine/jis/ioc/Di.ts"],"names":[],"mappings":";;;AAAA,qCAA0C;AAC1C,8EAAyE;AAEzE,0FAAuF;AACvF,gGAA6F;AAC7F,6EAA0E;AAC1E,2GAAwG;AACxG,6FAA0F;AAC1F,mFAAgF;AAChF,+GAA4G;AAC5G,iFAA8E;AAC9E,2EAAwE;AACxE,iFAA8E;AAC9E,oGAAiG;AACjG,wFAAqF;AACrF,8FAA2F;AAC3F,4EAAyE;AACzE,kFAA+E;AAC/E,gFAA6E;AAC7E,gGAA6F;AAC7F,sFAAmF;AACnF,2DAAwD;AACxD,
|
|
1
|
+
{"version":3,"file":"Di.js","sourceRoot":"","sources":["../../../../src/integration-engine/jis/ioc/Di.ts"],"names":[],"mappings":"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"}
|
|
@@ -8,16 +8,19 @@ declare const JISContainerToken: {
|
|
|
8
8
|
JISInfotextsRopidGTFSStopsRepository: symbol;
|
|
9
9
|
JISMetadataRepository: symbol;
|
|
10
10
|
RopidGTFSStopsRepository: symbol;
|
|
11
|
+
RopidGTFSRoutesRepository: symbol;
|
|
11
12
|
JISEventsDataService: symbol;
|
|
12
13
|
JISInfotextsDataService: symbol;
|
|
13
14
|
JISEventsTransformation: symbol;
|
|
14
15
|
JISEventsGtfsRtTransformation: symbol;
|
|
15
16
|
JISInfotextsTransformation: symbol;
|
|
16
17
|
JISInfotextCacheTranformation: symbol;
|
|
18
|
+
UpdateEventWebhookTransformation: symbol;
|
|
17
19
|
FetchJISEventsTask: symbol;
|
|
18
20
|
FetchJISInfotextsTask: symbol;
|
|
19
21
|
RefreshJISEventsTask: symbol;
|
|
20
22
|
RefreshJISInfotextsTask: symbol;
|
|
21
23
|
RefreshJISInfotextsCacheTask: symbol;
|
|
24
|
+
UpdateEventWebhookTask: symbol;
|
|
22
25
|
};
|
|
23
26
|
export { JISContainerToken };
|
|
@@ -14,6 +14,7 @@ const JISContainerToken = {
|
|
|
14
14
|
JISInfotextsRopidGTFSStopsRepository: Symbol("JISInfotextsRopidGTFSStopsRepository"),
|
|
15
15
|
JISMetadataRepository: Symbol("JISMetadataRepository"),
|
|
16
16
|
RopidGTFSStopsRepository: Symbol("RopidGTFSStopsRepository"),
|
|
17
|
+
RopidGTFSRoutesRepository: Symbol("RopidGTFSRoutesRepository"),
|
|
17
18
|
/* Services */
|
|
18
19
|
JISEventsDataService: Symbol("JISEventsDataService"),
|
|
19
20
|
JISInfotextsDataService: Symbol("JISInfotextsDataService"),
|
|
@@ -22,12 +23,14 @@ const JISContainerToken = {
|
|
|
22
23
|
JISEventsGtfsRtTransformation: Symbol("JISEventsGtfsRtTransformation"),
|
|
23
24
|
JISInfotextsTransformation: Symbol("JISInfotextsTransformation"),
|
|
24
25
|
JISInfotextCacheTranformation: Symbol("JISInfotextCacheTranformation"),
|
|
26
|
+
UpdateEventWebhookTransformation: Symbol("UpdateEventWebhookTransformation"),
|
|
25
27
|
/* Tasks */
|
|
26
28
|
FetchJISEventsTask: Symbol("FetchJISEventsTask"),
|
|
27
29
|
FetchJISInfotextsTask: Symbol("FetchJISInfotextsTask"),
|
|
28
30
|
RefreshJISEventsTask: Symbol("RefreshJISEventsTask"),
|
|
29
31
|
RefreshJISInfotextsTask: Symbol("RefreshJISInfotextsTask"),
|
|
30
32
|
RefreshJISInfotextsCacheTask: Symbol("RefreshJISInfotextsCacheTask"),
|
|
33
|
+
UpdateEventWebhookTask: Symbol("UpdateEventWebhookTask"),
|
|
31
34
|
};
|
|
32
35
|
exports.JISContainerToken = JISContainerToken;
|
|
33
36
|
//# sourceMappingURL=JISContainerToken.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"JISContainerToken.js","sourceRoot":"","sources":["../../../../src/integration-engine/jis/ioc/JISContainerToken.ts"],"names":[],"mappings":";;;AAAA,MAAM,iBAAiB,GAAG;IACtB,kBAAkB;IAClB,0BAA0B,EAAE,MAAM,CAAC,4BAA4B,CAAC;IAChE,6BAA6B,EAAE,MAAM,CAAC,+BAA+B,CAAC;IACtE,wBAAwB;IACxB,2BAA2B,EAAE,MAAM,CAAC,6BAA6B,CAAC;IAClE,kBAAkB;IAClB,mBAAmB,EAAE,MAAM,CAAC,qBAAqB,CAAC;IAClD,kCAAkC,EAAE,MAAM,CAAC,oCAAoC,CAAC;IAChF,sBAAsB,EAAE,MAAM,CAAC,wBAAwB,CAAC;IACxD,oCAAoC,EAAE,MAAM,CAAC,sCAAsC,CAAC;IACpF,qBAAqB,EAAE,MAAM,CAAC,uBAAuB,CAAC;IACtD,wBAAwB,EAAE,MAAM,CAAC,0BAA0B,CAAC;IAC5D,cAAc;IACd,oBAAoB,EAAE,MAAM,CAAC,sBAAsB,CAAC;IACpD,uBAAuB,EAAE,MAAM,CAAC,yBAAyB,CAAC;IAC1D,qBAAqB;IACrB,uBAAuB,EAAE,MAAM,CAAC,yBAAyB,CAAC;IAC1D,6BAA6B,EAAE,MAAM,CAAC,+BAA+B,CAAC;IACtE,0BAA0B,EAAE,MAAM,CAAC,4BAA4B,CAAC;IAChE,6BAA6B,EAAE,MAAM,CAAC,+BAA+B,CAAC;IACtE,WAAW;IACX,kBAAkB,EAAE,MAAM,CAAC,oBAAoB,CAAC;IAChD,qBAAqB,EAAE,MAAM,CAAC,uBAAuB,CAAC;IACtD,oBAAoB,EAAE,MAAM,CAAC,sBAAsB,CAAC;IACpD,uBAAuB,EAAE,MAAM,CAAC,yBAAyB,CAAC;IAC1D,4BAA4B,EAAE,MAAM,CAAC,8BAA8B,CAAC;
|
|
1
|
+
{"version":3,"file":"JISContainerToken.js","sourceRoot":"","sources":["../../../../src/integration-engine/jis/ioc/JISContainerToken.ts"],"names":[],"mappings":";;;AAAA,MAAM,iBAAiB,GAAG;IACtB,kBAAkB;IAClB,0BAA0B,EAAE,MAAM,CAAC,4BAA4B,CAAC;IAChE,6BAA6B,EAAE,MAAM,CAAC,+BAA+B,CAAC;IACtE,wBAAwB;IACxB,2BAA2B,EAAE,MAAM,CAAC,6BAA6B,CAAC;IAClE,kBAAkB;IAClB,mBAAmB,EAAE,MAAM,CAAC,qBAAqB,CAAC;IAClD,kCAAkC,EAAE,MAAM,CAAC,oCAAoC,CAAC;IAChF,sBAAsB,EAAE,MAAM,CAAC,wBAAwB,CAAC;IACxD,oCAAoC,EAAE,MAAM,CAAC,sCAAsC,CAAC;IACpF,qBAAqB,EAAE,MAAM,CAAC,uBAAuB,CAAC;IACtD,wBAAwB,EAAE,MAAM,CAAC,0BAA0B,CAAC;IAC5D,yBAAyB,EAAE,MAAM,CAAC,2BAA2B,CAAC;IAC9D,cAAc;IACd,oBAAoB,EAAE,MAAM,CAAC,sBAAsB,CAAC;IACpD,uBAAuB,EAAE,MAAM,CAAC,yBAAyB,CAAC;IAC1D,qBAAqB;IACrB,uBAAuB,EAAE,MAAM,CAAC,yBAAyB,CAAC;IAC1D,6BAA6B,EAAE,MAAM,CAAC,+BAA+B,CAAC;IACtE,0BAA0B,EAAE,MAAM,CAAC,4BAA4B,CAAC;IAChE,6BAA6B,EAAE,MAAM,CAAC,+BAA+B,CAAC;IACtE,gCAAgC,EAAE,MAAM,CAAC,kCAAkC,CAAC;IAC5E,WAAW;IACX,kBAAkB,EAAE,MAAM,CAAC,oBAAoB,CAAC;IAChD,qBAAqB,EAAE,MAAM,CAAC,uBAAuB,CAAC;IACtD,oBAAoB,EAAE,MAAM,CAAC,sBAAsB,CAAC;IACpD,uBAAuB,EAAE,MAAM,CAAC,yBAAyB,CAAC;IAC1D,4BAA4B,EAAE,MAAM,CAAC,8BAA8B,CAAC;IACpE,sBAAsB,EAAE,MAAM,CAAC,wBAAwB,CAAC;CAC3D,CAAC;AAEO,8CAAiB"}
|
|
@@ -15,6 +15,7 @@ export declare class JISEventsDataService {
|
|
|
15
15
|
*
|
|
16
16
|
* @param events Array of JIS events to insert or update.
|
|
17
17
|
* @param eventsRopidGTFSRoutes Array of corresponding ROPID-GTFS route records to insert or update.
|
|
18
|
+
* @returns boolean true if any events were saved, false if no events were saved.
|
|
18
19
|
*/
|
|
19
|
-
upsertAll(events: IJISEvent[], eventsRopidGTFSRoutes: IJISEventsRopidGTFSRoutes[]): Promise<
|
|
20
|
+
upsertAll(events: IJISEvent[], eventsRopidGTFSRoutes: IJISEventsRopidGTFSRoutes[]): Promise<boolean>;
|
|
20
21
|
}
|
|
@@ -33,6 +33,7 @@ let JISEventsDataService = exports.JISEventsDataService = class JISEventsDataSer
|
|
|
33
33
|
*
|
|
34
34
|
* @param events Array of JIS events to insert or update.
|
|
35
35
|
* @param eventsRopidGTFSRoutes Array of corresponding ROPID-GTFS route records to insert or update.
|
|
36
|
+
* @returns boolean true if any events were saved, false if no events were saved.
|
|
36
37
|
*/
|
|
37
38
|
async upsertAll(events, eventsRopidGTFSRoutes) {
|
|
38
39
|
const connection = this.databaseConnector.getConnection();
|
|
@@ -42,10 +43,11 @@ let JISEventsDataService = exports.JISEventsDataService = class JISEventsDataSer
|
|
|
42
43
|
if (events.length === 0) {
|
|
43
44
|
this.logger.info(`${this.constructor.name}.upsertAll: 0 events were imported - keeping existing data`);
|
|
44
45
|
await transaction.commit();
|
|
46
|
+
return false;
|
|
45
47
|
}
|
|
46
48
|
else {
|
|
47
49
|
const isSingleUpdate = events.length === 1;
|
|
48
|
-
await this.eventsRepository.upsertAll(events, { transaction });
|
|
50
|
+
const savedEvents = await this.eventsRepository.upsertAll(events, { transaction });
|
|
49
51
|
await this.eventsRopidGTFSRoutesRepository.upsertAll(eventsRopidGTFSRoutes, { transaction });
|
|
50
52
|
await this.eventsRopidGTFSRoutesRepository.deleteAllLastUpdatedBefore(saveTime, events, {
|
|
51
53
|
transaction,
|
|
@@ -54,6 +56,10 @@ let JISEventsDataService = exports.JISEventsDataService = class JISEventsDataSer
|
|
|
54
56
|
this.logger.info(`${this.constructor.name}.upsertAll: ${events.length} JIS events and ` +
|
|
55
57
|
`${eventsRopidGTFSRoutes.length} JIS eventsRopidGTFSRoutes were saved ` +
|
|
56
58
|
(isSingleUpdate ? "(single update)" : "(full sync)"));
|
|
59
|
+
if (savedEvents.length === 0) {
|
|
60
|
+
return false;
|
|
61
|
+
}
|
|
62
|
+
return true;
|
|
57
63
|
}
|
|
58
64
|
}
|
|
59
65
|
catch (err) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"JISEventsDataService.js","sourceRoot":"","sources":["../../../../src/integration-engine/jis/services/JISEventsDataService.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,gEAAkE;AAClE,6EAA+E;AAC/E,2GAA6G;AAI7G,wEAAqE;AACrE,6EAAwE;AACxE,iEAAwE;AAGjE,IAAM,oBAAoB,kCAA1B,MAAM,oBAAoB;IAC7B,YAEY,gBAAqC,EAErC,+BAAmE,EAC9B,iBAAqC,EAChD,MAAe;QAJzC,qBAAgB,GAAhB,gBAAgB,CAAqB;QAErC,oCAA+B,GAA/B,+BAA+B,CAAoC;QAC9B,sBAAiB,GAAjB,iBAAiB,CAAoB;QAChD,WAAM,GAAN,MAAM,CAAS;QAEjD,aAAa;IACjB,CAAC;IAED
|
|
1
|
+
{"version":3,"file":"JISEventsDataService.js","sourceRoot":"","sources":["../../../../src/integration-engine/jis/services/JISEventsDataService.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,gEAAkE;AAClE,6EAA+E;AAC/E,2GAA6G;AAI7G,wEAAqE;AACrE,6EAAwE;AACxE,iEAAwE;AAGjE,IAAM,oBAAoB,kCAA1B,MAAM,oBAAoB;IAC7B,YAEY,gBAAqC,EAErC,+BAAmE,EAC9B,iBAAqC,EAChD,MAAe;QAJzC,qBAAgB,GAAhB,gBAAgB,CAAqB;QAErC,oCAA+B,GAA/B,+BAA+B,CAAoC;QAC9B,sBAAiB,GAAjB,iBAAiB,CAAoB;QAChD,WAAM,GAAN,MAAM,CAAS;QAEjD,aAAa;IACjB,CAAC;IAED;;;;;;;OAOG;IACI,KAAK,CAAC,SAAS,CAAC,MAAmB,EAAE,qBAAkD;QAC1F,MAAM,UAAU,GAAG,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC;QAC1D,MAAM,WAAW,GAAG,MAAM,UAAU,CAAC,WAAW,EAAE,CAAC;QACnD,MAAM,QAAQ,GAAG,IAAI,IAAI,EAAE,CAAC;QAE5B,IAAI;YACA,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE;gBACrB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,4DAA4D,CAAC,CAAC;gBACvG,MAAM,WAAW,CAAC,MAAM,EAAE,CAAC;gBAC3B,OAAO,KAAK,CAAC;aAChB;iBAAM;gBACH,MAAM,cAAc,GAAG,MAAM,CAAC,MAAM,KAAK,CAAC,CAAC;gBAC3C,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,MAAM,EAAE,EAAE,WAAW,EAAE,CAAC,CAAC;gBACnF,MAAM,IAAI,CAAC,+BAA+B,CAAC,SAAS,CAAC,qBAAqB,EAAE,EAAE,WAAW,EAAE,CAAC,CAAC;gBAC7F,MAAM,IAAI,CAAC,+BAA+B,CAAC,0BAA0B,CAAC,QAAQ,EAAE,MAAM,EAAE;oBACpF,WAAW;iBACd,CAAC,CAAC;gBACH,MAAM,WAAW,CAAC,MAAM,EAAE,CAAC;gBAC3B,IAAI,CAAC,MAAM,CAAC,IAAI,CACZ,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,eAAe,MAAM,CAAC,MAAM,kBAAkB;oBAClE,GAAG,qBAAqB,CAAC,MAAM,wCAAwC;oBACvE,CAAC,cAAc,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,aAAa,CAAC,CAC3D,CAAC;gBAEF,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE;oBAC1B,OAAO,KAAK,CAAC;iBAChB;gBACD,OAAO,IAAI,CAAC;aACf;SACJ;QAAC,OAAO,GAAG,EAAE;YACV,MAAM,WAAW,CAAC,QAAQ,EAAE,CAAC;YAC7B,IAAI,GAAG,YAAY,6BAAY;gBAAE,MAAM,GAAG,CAAC;YAC3C,MAAM,IAAI,6BAAY,CAAC,0CAA0C,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;SAClG;IACL,CAAC;CACJ,CAAA;+BAvDY,oBAAoB;IADhC,IAAA,qBAAU,GAAE;IAGJ,WAAA,IAAA,iBAAM,EAAC,qCAAiB,CAAC,mBAAmB,CAAC,CAAA;IAE7C,WAAA,IAAA,iBAAM,EAAC,qCAAiB,CAAC,kCAAkC,CAAC,CAAA;IAE5D,WAAA,IAAA,iBAAM,EAAC,qBAAS,CAAC,iBAAiB,CAAC,CAAA;IACnC,WAAA,IAAA,iBAAM,EAAC,qBAAS,CAAC,MAAM,CAAC,CAAA;qCAJC,yCAAmB;QAEJ,uEAAkC;GALtE,oBAAoB,CAuDhC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { IJISEventRouteDto, IJISEventCustomFormatDto } from "../../../helpers/jis/interfaces/IJISEventCustomFormatDto";
|
|
2
|
+
import { IJISEvent } from "../../../schema-definitions/jis/datasources/interfaces";
|
|
3
|
+
import { AbstractTransformation } from "@golemio/core/dist/helpers/transformation/AbstractTransformation";
|
|
4
|
+
export declare class UpdateEventWebhookTransformation extends AbstractTransformation<{
|
|
5
|
+
event: IJISEvent;
|
|
6
|
+
routes: IJISEventRouteDto[];
|
|
7
|
+
}, IJISEventCustomFormatDto> {
|
|
8
|
+
name: string;
|
|
9
|
+
protected transformInternal: ({ event, routes, }: {
|
|
10
|
+
event: IJISEvent;
|
|
11
|
+
routes: IJISEventRouteDto[];
|
|
12
|
+
}) => IJISEventCustomFormatDto;
|
|
13
|
+
}
|
|
@@ -0,0 +1,62 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.UpdateEventWebhookTransformation = void 0;
|
|
10
|
+
const JISEventTranslationHelper_1 = require("../../../helpers/jis/JISEventTranslationHelper");
|
|
11
|
+
const AbstractTransformation_1 = require("@golemio/core/dist/helpers/transformation/AbstractTransformation");
|
|
12
|
+
const tsyringe_1 = require("@golemio/core/dist/shared/tsyringe");
|
|
13
|
+
let UpdateEventWebhookTransformation = exports.UpdateEventWebhookTransformation = class UpdateEventWebhookTransformation extends AbstractTransformation_1.AbstractTransformation {
|
|
14
|
+
constructor() {
|
|
15
|
+
super(...arguments);
|
|
16
|
+
this.name = "UpdateEventWebhookTransformation";
|
|
17
|
+
this.transformInternal = ({ event, routes, }) => {
|
|
18
|
+
return {
|
|
19
|
+
id: event.id,
|
|
20
|
+
type: event.type,
|
|
21
|
+
header_text: event.header_text,
|
|
22
|
+
cause: {
|
|
23
|
+
cs: JISEventTranslationHelper_1.JISEventTranslationHelper.causeToCs(event.cause),
|
|
24
|
+
en: event.cause.charAt(0).toUpperCase() + event.cause.slice(1).toLowerCase().replaceAll("_", " "),
|
|
25
|
+
},
|
|
26
|
+
cause_detail: event.cause_detail,
|
|
27
|
+
severity_level: event.severity_level,
|
|
28
|
+
active_period: {
|
|
29
|
+
start: event.active_period.start,
|
|
30
|
+
end: event.active_period.end,
|
|
31
|
+
},
|
|
32
|
+
display_period: {
|
|
33
|
+
start: event.display_period.start,
|
|
34
|
+
end: event.display_period.end || null,
|
|
35
|
+
},
|
|
36
|
+
effects: [
|
|
37
|
+
{
|
|
38
|
+
cs: JISEventTranslationHelper_1.JISEventTranslationHelper.effectToCs(event.effect),
|
|
39
|
+
en: event.effect.charAt(0).toUpperCase() + event.effect.slice(1).toLowerCase().replaceAll("_", " "),
|
|
40
|
+
},
|
|
41
|
+
],
|
|
42
|
+
description_text: event.description_text,
|
|
43
|
+
description_html: event.description_html,
|
|
44
|
+
organization_name: event.organization_name,
|
|
45
|
+
informed_entity: {
|
|
46
|
+
routes: routes.map((r) => ({
|
|
47
|
+
id: r.route_id,
|
|
48
|
+
route_long_name: r.route_long_name,
|
|
49
|
+
route_short_name: r.route_short_name,
|
|
50
|
+
route_type: r.route_type,
|
|
51
|
+
})),
|
|
52
|
+
},
|
|
53
|
+
last_modified_timestamp: event.last_modified_timestamp,
|
|
54
|
+
created_timestamp: event.created_timestamp,
|
|
55
|
+
};
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
};
|
|
59
|
+
exports.UpdateEventWebhookTransformation = UpdateEventWebhookTransformation = __decorate([
|
|
60
|
+
(0, tsyringe_1.injectable)()
|
|
61
|
+
], UpdateEventWebhookTransformation);
|
|
62
|
+
//# sourceMappingURL=UpdateEventWebhookTransformation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"UpdateEventWebhookTransformation.js","sourceRoot":"","sources":["../../../../src/integration-engine/jis/transformations/UpdateEventWebhookTransformation.ts"],"names":[],"mappings":";;;;;;;;;AACA,8FAAmF;AAEnF,6GAA0G;AAC1G,iEAAgE;AAGzD,IAAM,gCAAgC,8CAAtC,MAAM,gCAAiC,SAAQ,+CAMrD;IANM;;QAOI,SAAI,GAAG,kCAAkC,CAAC;QAEvC,sBAAiB,GAAG,CAAC,EAC3B,KAAK,EACL,MAAM,GAIT,EAA4B,EAAE;YAC3B,OAAO;gBACH,EAAE,EAAE,KAAK,CAAC,EAAE;gBACZ,IAAI,EAAE,KAAK,CAAC,IAAI;gBAChB,WAAW,EAAE,KAAK,CAAC,WAAW;gBAC9B,KAAK,EAAE;oBACH,EAAE,EAAE,qDAAyB,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC;oBACpD,EAAE,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,GAAG,EAAE,GAAG,CAAC;iBACpG;gBACD,YAAY,EAAE,KAAK,CAAC,YAAY;gBAChC,cAAc,EAAE,KAAK,CAAC,cAAc;gBACpC,aAAa,EAAE;oBACX,KAAK,EAAE,KAAK,CAAC,aAAa,CAAC,KAAK;oBAChC,GAAG,EAAE,KAAK,CAAC,aAAa,CAAC,GAAG;iBAC/B;gBACD,cAAc,EAAE;oBACZ,KAAK,EAAE,KAAK,CAAC,cAAc,CAAC,KAAK;oBACjC,GAAG,EAAE,KAAK,CAAC,cAAc,CAAC,GAAG,IAAI,IAAI;iBACxC;gBACD,OAAO,EAAE;oBACL;wBACI,EAAE,EAAE,qDAAyB,CAAC,UAAU,CAAC,KAAK,CAAC,MAAM,CAAC;wBACtD,EAAE,EAAE,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,GAAG,EAAE,GAAG,CAAC;qBACtG;iBACJ;gBACD,gBAAgB,EAAE,KAAK,CAAC,gBAAgB;gBACxC,gBAAgB,EAAE,KAAK,CAAC,gBAAgB;gBACxC,iBAAiB,EAAE,KAAK,CAAC,iBAAiB;gBAC1C,eAAe,EAAE;oBACb,MAAM,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC,CAAoB,EAAE,EAAE,CAAC,CAAC;wBAC1C,EAAE,EAAE,CAAC,CAAC,QAAQ;wBACd,eAAe,EAAE,CAAC,CAAC,eAAe;wBAClC,gBAAgB,EAAE,CAAC,CAAC,gBAAgB;wBACpC,UAAU,EAAE,CAAC,CAAC,UAAU;qBAC3B,CAAC,CAAC;iBACN;gBACD,uBAAuB,EAAE,KAAK,CAAC,uBAAuB;gBACtD,iBAAiB,EAAE,KAAK,CAAC,iBAAiB;aAC7C,CAAC;QACN,CAAC,CAAC;IACN,CAAC;CAAA,CAAA;2CAvDY,gCAAgC;IAD5C,IAAA,qBAAU,GAAE;GACA,gCAAgC,CAuD5C"}
|
|
@@ -19,6 +19,7 @@ class JISWorker extends workers_1.AbstractWorker {
|
|
|
19
19
|
this.registerTask(Di_1.JISContainer.resolve(JISContainerToken_1.JISContainerToken.RefreshJISEventsTask));
|
|
20
20
|
this.registerTask(Di_1.JISContainer.resolve(JISContainerToken_1.JISContainerToken.RefreshJISInfotextsTask));
|
|
21
21
|
this.registerTask(Di_1.JISContainer.resolve(JISContainerToken_1.JISContainerToken.RefreshJISInfotextsCacheTask));
|
|
22
|
+
this.registerTask(Di_1.JISContainer.resolve(JISContainerToken_1.JISContainerToken.UpdateEventWebhookTask));
|
|
22
23
|
}
|
|
23
24
|
}
|
|
24
25
|
exports.JISWorker = JISWorker;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"JISWorker.js","sourceRoot":"","sources":["../../../../src/integration-engine/jis/workers/JISWorker.ts"],"names":[],"mappings":";;;AAAA,2EAA+E;AAE/E,kCAAyC;AACzC,gEAA6D;AAC7D,2CAA8C;
|
|
1
|
+
{"version":3,"file":"JISWorker.js","sourceRoot":"","sources":["../../../../src/integration-engine/jis/workers/JISWorker.ts"],"names":[],"mappings":";;;AAAA,2EAA+E;AAE/E,kCAAyC;AACzC,gEAA6D;AAC7D,2CAA8C;AAQ9C,MAAa,SAAU,SAAQ,wBAAc;IAGzC;QACI,KAAK,EAAE,CAAC;QAHF,SAAI,GAAG,2BAAe,CAAC,WAAW,EAAE,CAAC;QAcxC,iBAAY,GAAG,CAAC,IAAW,EAAQ,EAAE;YACxC,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;YACzB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;QAC7C,CAAC,CAAC;QAZE,iBAAiB;QACjB,IAAI,CAAC,YAAY,CAAC,iBAAY,CAAC,OAAO,CAAqB,qCAAiB,CAAC,kBAAkB,CAAC,CAAC,CAAC;QAClG,IAAI,CAAC,YAAY,CAAC,iBAAY,CAAC,OAAO,CAAwB,qCAAiB,CAAC,qBAAqB,CAAC,CAAC,CAAC;QACxG,IAAI,CAAC,YAAY,CAAC,iBAAY,CAAC,OAAO,CAAuB,qCAAiB,CAAC,oBAAoB,CAAC,CAAC,CAAC;QACtG,IAAI,CAAC,YAAY,CAAC,iBAAY,CAAC,OAAO,CAA0B,qCAAiB,CAAC,uBAAuB,CAAC,CAAC,CAAC;QAC5G,IAAI,CAAC,YAAY,CAAC,iBAAY,CAAC,OAAO,CAA+B,qCAAiB,CAAC,4BAA4B,CAAC,CAAC,CAAC;QACtH,IAAI,CAAC,YAAY,CAAC,iBAAY,CAAC,OAAO,CAAyB,qCAAiB,CAAC,sBAAsB,CAAC,CAAC,CAAC;IAC9G,CAAC;CAMJ;AAnBD,8BAmBC"}
|
|
@@ -3,12 +3,19 @@ import { JISEventsTransformation } from "../../transformations/JISEventsTransfor
|
|
|
3
3
|
import { IJISEvent } from "../../../../schema-definitions/jis/datasources/interfaces";
|
|
4
4
|
import { AbstractTaskJsonSchema } from "@golemio/core/dist/integration-engine/workers/AbstractTaskJsonSchema";
|
|
5
5
|
import { JSONSchemaValidator } from "@golemio/core/dist/shared/golemio-validator";
|
|
6
|
-
export declare class RefreshJISEventsTask extends AbstractTaskJsonSchema<
|
|
6
|
+
export declare class RefreshJISEventsTask extends AbstractTaskJsonSchema<{
|
|
7
|
+
data: IJISEvent[];
|
|
8
|
+
shouldTriggerWebhooks?: boolean;
|
|
9
|
+
}> {
|
|
7
10
|
private eventsDataService;
|
|
8
11
|
private eventsTransformation;
|
|
9
12
|
readonly schema: JSONSchemaValidator;
|
|
10
13
|
readonly queueName = "refreshJISEvents";
|
|
11
14
|
readonly queueTtl: number;
|
|
12
15
|
constructor(eventsDataService: JISEventsDataService, eventsTransformation: JISEventsTransformation);
|
|
13
|
-
protected execute(
|
|
16
|
+
protected execute(input: {
|
|
17
|
+
data: IJISEvent[];
|
|
18
|
+
shouldTriggerWebhooks?: boolean;
|
|
19
|
+
}): Promise<void>;
|
|
20
|
+
private transformAndSave;
|
|
14
21
|
}
|
|
@@ -17,6 +17,7 @@ const JISContainerToken_1 = require("../../ioc/JISContainerToken");
|
|
|
17
17
|
const JISEventsDataService_1 = require("../../services/JISEventsDataService");
|
|
18
18
|
const JISEventsTransformation_1 = require("../../transformations/JISEventsTransformation");
|
|
19
19
|
const JISEventsJsonSchema_1 = require("../../../../schema-definitions/jis/datasources/JISEventsJsonSchema");
|
|
20
|
+
const integration_engine_1 = require("@golemio/core/dist/integration-engine");
|
|
20
21
|
const AbstractTaskJsonSchema_1 = require("@golemio/core/dist/integration-engine/workers/AbstractTaskJsonSchema");
|
|
21
22
|
const golemio_validator_1 = require("@golemio/core/dist/shared/golemio-validator");
|
|
22
23
|
const tsyringe_1 = require("@golemio/core/dist/shared/tsyringe");
|
|
@@ -26,11 +27,35 @@ let RefreshJISEventsTask = exports.RefreshJISEventsTask = class RefreshJISEvents
|
|
|
26
27
|
super(constants_1.JIS_WORKER_NAME.toLowerCase());
|
|
27
28
|
this.eventsDataService = eventsDataService;
|
|
28
29
|
this.eventsTransformation = eventsTransformation;
|
|
29
|
-
this.schema = new golemio_validator_1.JSONSchemaValidator("JISEventsDataValidation",
|
|
30
|
+
this.schema = new golemio_validator_1.JSONSchemaValidator("JISEventsDataValidation", {
|
|
31
|
+
type: "object",
|
|
32
|
+
properties: {
|
|
33
|
+
data: JISEventsJsonSchema_1.jisEventsJsonSchema,
|
|
34
|
+
shouldTriggerWebhooks: { type: "boolean" },
|
|
35
|
+
},
|
|
36
|
+
required: ["data"],
|
|
37
|
+
definitions: {
|
|
38
|
+
Translation: {
|
|
39
|
+
type: "object",
|
|
40
|
+
properties: {
|
|
41
|
+
cs: { type: "string" },
|
|
42
|
+
en: { oneOf: [{ type: "string" }, { type: "null", nullable: true }] },
|
|
43
|
+
},
|
|
44
|
+
additionalProperties: false,
|
|
45
|
+
required: ["cs"],
|
|
46
|
+
},
|
|
47
|
+
},
|
|
48
|
+
});
|
|
30
49
|
this.queueName = "refreshJISEvents";
|
|
31
50
|
this.queueTtl = 60 * 1000; // 1 minute
|
|
32
51
|
}
|
|
33
|
-
async execute(
|
|
52
|
+
async execute(input) {
|
|
53
|
+
const savedData = await this.transformAndSave(input.data);
|
|
54
|
+
if (input.shouldTriggerWebhooks && savedData) {
|
|
55
|
+
await integration_engine_1.QueueManager.sendMessageToExchange(this.queuePrefix, "updateEventWebhook", input.data);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
async transformAndSave(data) {
|
|
34
59
|
const transformedData = this.eventsTransformation.transformArray(data);
|
|
35
60
|
const events = [];
|
|
36
61
|
const eventsRopidGTFSRoutes = [];
|
|
@@ -38,7 +63,7 @@ let RefreshJISEventsTask = exports.RefreshJISEventsTask = class RefreshJISEvents
|
|
|
38
63
|
events.push(event);
|
|
39
64
|
eventsRopidGTFSRoutes.push(...routes);
|
|
40
65
|
}
|
|
41
|
-
await this.eventsDataService.upsertAll(events, eventsRopidGTFSRoutes);
|
|
66
|
+
return await this.eventsDataService.upsertAll(events, eventsRopidGTFSRoutes);
|
|
42
67
|
}
|
|
43
68
|
};
|
|
44
69
|
exports.RefreshJISEventsTask = RefreshJISEventsTask = __decorate([
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"RefreshJISEventsTask.js","sourceRoot":"","sources":["../../../../../src/integration-engine/jis/workers/tasks/RefreshJISEventsTask.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,mEAAkE;AAClE,8EAA6E;AAC7E,2FAA0F;AAE1F,4GAA+E;AAE/E,iHAA8G;AAC9G,mFAAkF;AAClF,iEAAwE;AACxE,4CAA+C;AAGxC,IAAM,oBAAoB,kCAA1B,MAAM,oBAAqB,SAAQ,+
|
|
1
|
+
{"version":3,"file":"RefreshJISEventsTask.js","sourceRoot":"","sources":["../../../../../src/integration-engine/jis/workers/tasks/RefreshJISEventsTask.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,mEAAkE;AAClE,8EAA6E;AAC7E,2FAA0F;AAE1F,4GAA+E;AAE/E,8EAAqE;AACrE,iHAA8G;AAC9G,mFAAkF;AAClF,iEAAwE;AACxE,4CAA+C;AAGxC,IAAM,oBAAoB,kCAA1B,MAAM,oBAAqB,SAAQ,+CAA8E;IAuBpH,YAEI,iBAA+C,EAE/C,oBAAqD;QAErD,KAAK,CAAC,2BAAe,CAAC,WAAW,EAAE,CAAC,CAAC;QAJ7B,sBAAiB,GAAjB,iBAAiB,CAAsB;QAEvC,yBAAoB,GAApB,oBAAoB,CAAyB;QA1BzC,WAAM,GAAG,IAAI,uCAAmB,CAAC,yBAAyB,EAAE;YACxE,IAAI,EAAE,QAAQ;YACd,UAAU,EAAE;gBACR,IAAI,EAAE,yCAAmB;gBACzB,qBAAqB,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE;aAC7C;YACD,QAAQ,EAAE,CAAC,MAAM,CAAC;YAClB,WAAW,EAAE;gBACT,WAAW,EAAE;oBACT,IAAI,EAAE,QAAQ;oBACd,UAAU,EAAE;wBACR,EAAE,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;wBACtB,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,EAAE;qBACxE;oBACD,oBAAoB,EAAE,KAAK;oBAC3B,QAAQ,EAAE,CAAC,IAAI,CAAC;iBACnB;aACJ;SACJ,CAAC,CAAC;QACa,cAAS,GAAG,kBAAkB,CAAC;QAC/B,aAAQ,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC,WAAW;IASjD,CAAC;IAES,KAAK,CAAC,OAAO,CAAC,KAA6D;QACjF,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAC1D,IAAI,KAAK,CAAC,qBAAqB,IAAI,SAAS,EAAE;YAC1C,MAAM,iCAAY,CAAC,qBAAqB,CAAC,IAAI,CAAC,WAAW,EAAE,oBAAoB,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;SAChG;IACL,CAAC;IAEO,KAAK,CAAC,gBAAgB,CAAC,IAAiB;QAC5C,MAAM,eAAe,GAAG,IAAI,CAAC,oBAAoB,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;QAEvE,MAAM,MAAM,GAAqB,EAAE,CAAC;QACpC,MAAM,qBAAqB,GAAgC,EAAE,CAAC;QAC9D,KAAK,MAAM,EAAE,KAAK,EAAE,qBAAqB,EAAE,MAAM,EAAE,IAAI,eAAe,EAAE;YACpE,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACnB,qBAAqB,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,CAAC;SACzC;QAED,OAAO,MAAM,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,MAAM,EAAE,qBAAqB,CAAC,CAAC;IACjF,CAAC;CACJ,CAAA;+BAnDY,oBAAoB;IADhC,IAAA,qBAAU,GAAE;IAyBJ,WAAA,IAAA,iBAAM,EAAC,qCAAiB,CAAC,oBAAoB,CAAC,CAAA;IAE9C,WAAA,IAAA,iBAAM,EAAC,qCAAiB,CAAC,uBAAuB,CAAC,CAAA;qCADvB,2CAAoB;QAEjB,iDAAuB;GA3BhD,oBAAoB,CAmDhC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { IJISEvent } from "../../../../schema-definitions/jis/datasources/interfaces";
|
|
2
|
+
import { ISimpleConfig } from "@golemio/core/dist/helpers/configuration/ISimpleConfig";
|
|
3
|
+
import { AbstractTaskJsonSchema } from "@golemio/core/dist/integration-engine/workers/AbstractTaskJsonSchema";
|
|
4
|
+
import { JSONSchemaValidator } from "@golemio/core/dist/shared/golemio-validator";
|
|
5
|
+
import { UpdateEventWebhookTransformation } from "../../transformations/UpdateEventWebhookTransformation";
|
|
6
|
+
import { RopidGTFSRoutesRepository } from "../../../ropid-gtfs/data-access/RopidGTFSRoutesRepository";
|
|
7
|
+
export declare class UpdateEventWebhookTask extends AbstractTaskJsonSchema<IJISEvent[]> {
|
|
8
|
+
private readonly config;
|
|
9
|
+
private readonly transformation;
|
|
10
|
+
private readonly routesRepository;
|
|
11
|
+
readonly schema: JSONSchemaValidator;
|
|
12
|
+
readonly queueName = "updateEventWebhook";
|
|
13
|
+
readonly queueTtl: number;
|
|
14
|
+
private readonly commonHeaders;
|
|
15
|
+
private readonly targets;
|
|
16
|
+
constructor(config: ISimpleConfig, transformation: UpdateEventWebhookTransformation, routesRepository: RopidGTFSRoutesRepository);
|
|
17
|
+
protected execute(data: IJISEvent[]): Promise<void>;
|
|
18
|
+
private getTargetFetchStrategy;
|
|
19
|
+
private validateResponse;
|
|
20
|
+
private fillMissingDataAndTransform;
|
|
21
|
+
}
|