@golemio/pid 5.7.2-dev.2375920152 → 5.7.2-rc.2378043360
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/const.d.ts +1 -0
- package/dist/const.js +2 -1
- package/dist/const.js.map +1 -1
- package/dist/integration-engine/ropid-gtfs/datasources/StaticDataSourceFactory.d.ts +2 -3
- package/dist/integration-engine/ropid-gtfs/datasources/StaticDataSourceFactory.js +2 -4
- package/dist/integration-engine/ropid-gtfs/datasources/StaticDataSourceFactory.js.map +1 -1
- package/dist/integration-engine/ropid-gtfs/ioc/Di.js +0 -6
- package/dist/integration-engine/ropid-gtfs/ioc/Di.js.map +1 -1
- package/dist/integration-engine/ropid-gtfs/ioc/RopidGtfsContainerToken.d.ts +0 -3
- package/dist/integration-engine/ropid-gtfs/ioc/RopidGtfsContainerToken.js +0 -3
- package/dist/integration-engine/ropid-gtfs/ioc/RopidGtfsContainerToken.js.map +1 -1
- package/dist/integration-engine/ropid-gtfs/workers/timetables/TimetableWorker.js +0 -1
- package/dist/integration-engine/ropid-gtfs/workers/timetables/TimetableWorker.js.map +1 -1
- package/dist/integration-engine/ropid-gtfs/workers/timetables/tasks/SaveStaticDataTask.d.ts +1 -6
- package/dist/integration-engine/ropid-gtfs/workers/timetables/tasks/SaveStaticDataTask.js +10 -39
- package/dist/integration-engine/ropid-gtfs/workers/timetables/tasks/SaveStaticDataTask.js.map +1 -1
- package/dist/integration-engine/vehicle-positions/ioc/Di.js +0 -2
- package/dist/integration-engine/vehicle-positions/ioc/Di.js.map +1 -1
- package/dist/integration-engine/vehicle-positions/ioc/VPContainerToken.d.ts +0 -1
- package/dist/integration-engine/vehicle-positions/ioc/VPContainerToken.js +0 -1
- package/dist/integration-engine/vehicle-positions/ioc/VPContainerToken.js.map +1 -1
- package/dist/integration-engine/vehicle-positions/workers/runs/helpers/BusMessageFilter.d.ts +5 -10
- package/dist/integration-engine/vehicle-positions/workers/runs/helpers/BusMessageFilter.js +11 -37
- package/dist/integration-engine/vehicle-positions/workers/runs/helpers/BusMessageFilter.js.map +1 -1
- package/dist/integration-engine/vehicle-positions/workers/runs/helpers/CommonMessageProcessor.d.ts +1 -4
- package/dist/integration-engine/vehicle-positions/workers/runs/helpers/CommonMessageProcessor.js +9 -22
- package/dist/integration-engine/vehicle-positions/workers/runs/helpers/CommonMessageProcessor.js.map +1 -1
- package/dist/integration-engine/vehicle-positions/workers/runs/helpers/TramMessageFilter.d.ts +3 -7
- package/dist/integration-engine/vehicle-positions/workers/runs/helpers/TramMessageFilter.js +10 -28
- package/dist/integration-engine/vehicle-positions/workers/runs/helpers/TramMessageFilter.js.map +1 -1
- package/dist/integration-engine/vehicle-positions/workers/runs/helpers/interfaces/ICommonMessageFilter.d.ts +1 -1
- package/dist/integration-engine/vehicle-positions/workers/runs/tasks/SaveBusRunsToDBTask.js +1 -1
- package/dist/integration-engine/vehicle-positions/workers/runs/tasks/SaveBusRunsToDBTask.js.map +1 -1
- package/dist/integration-engine/vehicle-positions/workers/runs/tasks/SaveTramRunsToDBTask.js +1 -1
- package/dist/integration-engine/vehicle-positions/workers/runs/tasks/SaveTramRunsToDBTask.js.map +1 -1
- package/dist/integration-engine/vehicle-positions/workers/vehicle-positions/interfaces/IUpdateRunsGtfsTripInput.d.ts +0 -6
- package/dist/integration-engine/vehicle-positions/workers/vehicle-positions/tasks/UpdateRunsGtfsTripIdTask.js +2 -3
- package/dist/integration-engine/vehicle-positions/workers/vehicle-positions/tasks/UpdateRunsGtfsTripIdTask.js.map +1 -1
- package/dist/output-gateway/public/data-access/redis/PublicGtfsDepartureRepository.js +1 -0
- package/dist/output-gateway/public/data-access/redis/PublicGtfsDepartureRepository.js.map +1 -1
- package/dist/output-gateway/public/service/facade/DetailedTripFacade.js +1 -1
- package/dist/output-gateway/public/service/facade/DetailedTripFacade.js.map +1 -1
- package/dist/output-gateway/public/service/helpers/trip-scope/strategy/ShapesTripScopeHandler.js +1 -1
- package/dist/output-gateway/public/service/helpers/trip-scope/strategy/ShapesTripScopeHandler.js.map +1 -1
- package/dist/output-gateway/public/service/helpers/trip-scope/strategy/StopTimesTripScopeHandler.js +1 -1
- package/dist/output-gateway/public/service/helpers/trip-scope/strategy/StopTimesTripScopeHandler.js.map +1 -1
- package/dist/output-gateway/vehicle-positions/data-access/PositionRepository.d.ts +3 -10
- package/dist/output-gateway/vehicle-positions/data-access/PositionRepository.js +7 -30
- package/dist/output-gateway/vehicle-positions/data-access/PositionRepository.js.map +1 -1
- package/dist/output-gateway/vehicle-positions/data-access/TripRepository.d.ts +3 -7
- package/dist/output-gateway/vehicle-positions/data-access/TripRepository.js +7 -30
- package/dist/output-gateway/vehicle-positions/data-access/TripRepository.js.map +1 -1
- package/dist/output-gateway/vehicle-positions/data-access/VehicleDescriptorRepository.d.ts +3 -10
- package/dist/output-gateway/vehicle-positions/data-access/VehicleDescriptorRepository.js +7 -30
- package/dist/output-gateway/vehicle-positions/data-access/VehicleDescriptorRepository.js.map +1 -1
- package/dist/output-gateway/vehicle-positions/data-access/VehicleTypeRepository.d.ts +3 -10
- package/dist/output-gateway/vehicle-positions/data-access/VehicleTypeRepository.js +7 -30
- package/dist/output-gateway/vehicle-positions/data-access/VehicleTypeRepository.js.map +1 -1
- package/dist/output-gateway/vehicle-positions/data-access/index.js +18 -9
- package/dist/output-gateway/vehicle-positions/data-access/index.js.map +1 -1
- package/dist/output-gateway/vehicle-positions/data-access/interfaces/ITripWithPositionRepository.d.ts +2 -3
- package/dist/output-gateway/vehicle-positions/data-access/interfaces/IVPRepositoryInstances.d.ts +6 -6
- package/dist/output-gateway/vehicle-positions/data-access/views/ProcessedPositionRepository.d.ts +3 -7
- package/dist/output-gateway/vehicle-positions/data-access/views/ProcessedPositionRepository.js +7 -30
- package/dist/output-gateway/vehicle-positions/data-access/views/ProcessedPositionRepository.js.map +1 -1
- package/dist/output-gateway/vehicle-positions/data-access/views/TripWithLastPositionRepository.d.ts +7 -17
- package/dist/output-gateway/vehicle-positions/data-access/views/TripWithLastPositionRepository.js +42 -112
- package/dist/output-gateway/vehicle-positions/data-access/views/TripWithLastPositionRepository.js.map +1 -1
- package/dist/schema-definitions/datasources/static-data/index.d.ts +0 -1
- package/dist/schema-definitions/datasources/static-data/index.js +0 -1
- package/dist/schema-definitions/datasources/static-data/index.js.map +1 -1
- package/dist/schema-definitions/datasources/static-data/interfaces/index.d.ts +0 -1
- package/dist/schema-definitions/datasources/static-data/interfaces/index.js +0 -1
- package/dist/schema-definitions/datasources/static-data/interfaces/index.js.map +1 -1
- package/dist/schema-definitions/ropid-gtfs/redis/const.d.ts +0 -2
- package/dist/schema-definitions/ropid-gtfs/redis/const.js +1 -3
- package/dist/schema-definitions/ropid-gtfs/redis/const.js.map +1 -1
- package/dist/schema-definitions/vehicle-positions/models/interfaces/ICommonRunWithMessageDto.d.ts +0 -6
- package/docs/asyncapi.yaml +2 -17
- package/docs/cache/types/redis.md +2 -58
- package/docs/implementation_documentation.md +3 -116
- package/docs/jis/index.md +0 -17
- package/docs/processing/input_realtime_data/http_mpvnet.md +0 -21
- package/docs/processing/state_position_tracking/http_mpvnet.md +0 -1
- package/docs/processing/state_position_tracking/tcp_dpp_common.md +0 -1
- package/package.json +5 -8
- package/dist/integration-engine/ropid-gtfs/data-access/cache/NotPublicVehiclesRedisRepository.d.ts +0 -14
- package/dist/integration-engine/ropid-gtfs/data-access/cache/NotPublicVehiclesRedisRepository.js +0 -47
- package/dist/integration-engine/ropid-gtfs/data-access/cache/NotPublicVehiclesRedisRepository.js.map +0 -1
- package/dist/integration-engine/ropid-gtfs/datasources/static-data/NotPublicVehiclesDataSourceProvider.d.ts +0 -9
- package/dist/integration-engine/ropid-gtfs/datasources/static-data/NotPublicVehiclesDataSourceProvider.js +0 -47
- package/dist/integration-engine/ropid-gtfs/datasources/static-data/NotPublicVehiclesDataSourceProvider.js.map +0 -1
- package/dist/integration-engine/ropid-gtfs/workers/timetables/tasks/EnsureCacheTask.d.ts +0 -9
- package/dist/integration-engine/ropid-gtfs/workers/timetables/tasks/EnsureCacheTask.js +0 -49
- package/dist/integration-engine/ropid-gtfs/workers/timetables/tasks/EnsureCacheTask.js.map +0 -1
- package/dist/output-gateway/vehicle-positions/data-access/cache/NotPublicVehiclesRedisRepository.d.ts +0 -10
- package/dist/output-gateway/vehicle-positions/data-access/cache/NotPublicVehiclesRedisRepository.js +0 -45
- package/dist/output-gateway/vehicle-positions/data-access/cache/NotPublicVehiclesRedisRepository.js.map +0 -1
- package/dist/output-gateway/vehicle-positions/ioc/Di.d.ts +0 -3
- package/dist/output-gateway/vehicle-positions/ioc/Di.js +0 -23
- package/dist/output-gateway/vehicle-positions/ioc/Di.js.map +0 -1
- package/dist/output-gateway/vehicle-positions/ioc/OgVehiclePositionsToken.d.ts +0 -9
- package/dist/output-gateway/vehicle-positions/ioc/OgVehiclePositionsToken.js +0 -15
- package/dist/output-gateway/vehicle-positions/ioc/OgVehiclePositionsToken.js.map +0 -1
- package/dist/schema-definitions/datasources/static-data/NotPublicVehiclesJsonSchema.d.ts +0 -3
- package/dist/schema-definitions/datasources/static-data/NotPublicVehiclesJsonSchema.js +0 -40
- package/dist/schema-definitions/datasources/static-data/NotPublicVehiclesJsonSchema.js.map +0 -1
- package/dist/schema-definitions/datasources/static-data/interfaces/NotPublicVehiclesDataInterface.d.ts +0 -35
- package/dist/schema-definitions/datasources/static-data/interfaces/NotPublicVehiclesDataInterface.js +0 -18
- package/dist/schema-definitions/datasources/static-data/interfaces/NotPublicVehiclesDataInterface.js.map +0 -1
- package/docs/examples/not_public_vehicles.json +0 -9
- package/docs/processing/transferboards_filtering.md +0 -312
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/schema-definitions/datasources/static-data/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,6DAA2C;AAC3C,mEAAiD;AACjD
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/schema-definitions/datasources/static-data/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,6DAA2C;AAC3C,mEAAiD;AACjD,+CAA6B"}
|
|
@@ -16,5 +16,4 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
17
|
__exportStar(require("./MetroRailTrackDataInterface"), exports);
|
|
18
18
|
__exportStar(require("./DeparturesDirectionDataInterface"), exports);
|
|
19
|
-
__exportStar(require("./NotPublicVehiclesDataInterface"), exports);
|
|
20
19
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/schema-definitions/datasources/static-data/interfaces/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,gEAA8C;AAC9C,qEAAmD
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/schema-definitions/datasources/static-data/interfaces/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,gEAA8C;AAC9C,qEAAmD"}
|
|
@@ -1,5 +1,3 @@
|
|
|
1
1
|
export declare const GTFS_RUN_SCHEDULE_NAMESPACE_PREFIX = "gtfsRunSchedule";
|
|
2
2
|
export declare const PUBLIC_DEPARTURE_NAMESPACE_PREFIX = "gtfsPublicDepartureCache";
|
|
3
3
|
export declare const GTFS_STOPS_NAMESPACE_PREFIX = "gtfsStopsCache";
|
|
4
|
-
export declare const CONFIG_NAMESPACE_PREFIX = "config";
|
|
5
|
-
export declare const NOT_PUBLIC_VEHICLES_KEY = "notPublicVehicles";
|
|
@@ -1,9 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.GTFS_STOPS_NAMESPACE_PREFIX = exports.PUBLIC_DEPARTURE_NAMESPACE_PREFIX = exports.GTFS_RUN_SCHEDULE_NAMESPACE_PREFIX = void 0;
|
|
4
4
|
exports.GTFS_RUN_SCHEDULE_NAMESPACE_PREFIX = "gtfsRunSchedule";
|
|
5
5
|
exports.PUBLIC_DEPARTURE_NAMESPACE_PREFIX = "gtfsPublicDepartureCache";
|
|
6
6
|
exports.GTFS_STOPS_NAMESPACE_PREFIX = "gtfsStopsCache";
|
|
7
|
-
exports.CONFIG_NAMESPACE_PREFIX = "config";
|
|
8
|
-
exports.NOT_PUBLIC_VEHICLES_KEY = "notPublicVehicles";
|
|
9
7
|
//# sourceMappingURL=const.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"const.js","sourceRoot":"","sources":["../../../../src/schema-definitions/ropid-gtfs/redis/const.ts"],"names":[],"mappings":";;;AAAa,QAAA,kCAAkC,GAAG,iBAAiB,CAAC;AACvD,QAAA,iCAAiC,GAAG,0BAA0B,CAAC;AAC/D,QAAA,2BAA2B,GAAG,gBAAgB,CAAC
|
|
1
|
+
{"version":3,"file":"const.js","sourceRoot":"","sources":["../../../../src/schema-definitions/ropid-gtfs/redis/const.ts"],"names":[],"mappings":";;;AAAa,QAAA,kCAAkC,GAAG,iBAAiB,CAAC;AACvD,QAAA,iCAAiC,GAAG,0BAA0B,CAAC;AAC/D,QAAA,2BAA2B,GAAG,gBAAgB,CAAC"}
|
package/dist/schema-definitions/vehicle-positions/models/interfaces/ICommonRunWithMessageDto.d.ts
CHANGED
|
@@ -3,10 +3,4 @@ import { ICommonRunsModel } from "./ICommonRunsModel";
|
|
|
3
3
|
export interface ICommonRunWithMessageDto {
|
|
4
4
|
run: ICommonRunsModel;
|
|
5
5
|
run_message: ICommonRunsMessagesModel;
|
|
6
|
-
/**
|
|
7
|
-
* Flag set by message filters to indicate this is a not-public vehicle
|
|
8
|
-
* (replacement bus/tram without schedule)
|
|
9
|
-
* Used by processor to determine if missing timestamp is acceptable
|
|
10
|
-
*/
|
|
11
|
-
isNotPublic?: boolean;
|
|
12
6
|
}
|
package/docs/asyncapi.yaml
CHANGED
|
@@ -105,17 +105,6 @@ channels:
|
|
|
105
105
|
messages:
|
|
106
106
|
empty:
|
|
107
107
|
$ref: "#/components/messages/emptyMessage"
|
|
108
|
-
ropidgtfs.ensureCache:
|
|
109
|
-
address: vehicle-positions.ropidgtfs.ensureCache
|
|
110
|
-
description: Triggers all cache refreshes to ensure caches are populated and up to date
|
|
111
|
-
bindings:
|
|
112
|
-
amqp:
|
|
113
|
-
is: queue
|
|
114
|
-
queue:
|
|
115
|
-
durable: true
|
|
116
|
-
messages:
|
|
117
|
-
empty:
|
|
118
|
-
$ref: "#/components/messages/emptyMessage"
|
|
119
108
|
updateGTFSTripId:
|
|
120
109
|
address: vehicle-positions.vehiclepositions.updateGTFSTripId
|
|
121
110
|
description: some description
|
|
@@ -718,12 +707,8 @@ components:
|
|
|
718
707
|
type: string
|
|
719
708
|
description: The timestamp when the message was last sent.
|
|
720
709
|
wheelchair_accessible:
|
|
721
|
-
type:
|
|
722
|
-
description:
|
|
723
|
-
Raw wheelchair accessibility flag from vehiclepositions_trips.
|
|
724
|
-
Mapped to wheelchairAccessible proto enum in GTFS-RT VehicleDescriptor:
|
|
725
|
-
null → WHEELCHAIR_ACCESSIBLE_UNSPECIFIED (0), true → WHEELCHAIR_ACCESSIBLE (1), false → WHEELCHAIR_INACCESSIBLE (2).
|
|
726
|
-
The OVAPI extension .transit_realtime.ovapiVehicleDescriptor.wheelchairAccessible retains the raw boolean/null value alongside the standard field.
|
|
710
|
+
type: boolean
|
|
711
|
+
description: Indicates if the vehicle is wheelchair accessible.
|
|
727
712
|
ICommonRunsMessagesModel:
|
|
728
713
|
type: object
|
|
729
714
|
properties:
|
|
@@ -275,7 +275,6 @@ flowchart TD
|
|
|
275
275
|
- `vpPublicCache:$setId:canceled-trips-$gtfsTripId` - JSON jako string s informacemi o zrušeném spoji. Využití v public odjezdech
|
|
276
276
|
- TTL 1 minuta
|
|
277
277
|
- Nová datová sada se generuje přibližně jednou za 3 vteřiny a obsahuje všechny RT spoje (aktivní, budoucí a zrušené)
|
|
278
|
-
- Populace `future-trip-*`, `future-vehicle-*` a `canceled-trips-*` sub-klíčů je řízena stavem spoje (před trasou / zrušen) a nesouvisí s logikou deduplikace odjezdů v `/v2/public/departureboards` – ta pracuje nad `gtfsPublicDepartureCache` a tuto cache neovlivňuje
|
|
279
278
|
|
|
280
279
|
### vpPublicStopTimeCache:*
|
|
281
280
|
|
|
@@ -295,29 +294,14 @@ flowchart TD
|
|
|
295
294
|
### gtfsPublicDepartureCache:*
|
|
296
295
|
|
|
297
296
|
- Klíč `gtfsPublicDepartureCache:*`, kde `*` je GTFS id zastávky
|
|
298
|
-
- Hodnota je sorted set, kde score je unix timestamp odjezdu v sekundách a member
|
|
299
|
-
- `stop_id` – GTFS id zastávky
|
|
300
|
-
- `departure_datetime` – plánovaný čas odjezdu (ISO 8601)
|
|
301
|
-
- `arrival_datetime` – plánovaný čas příjezdu (ISO 8601), nebo `null`
|
|
302
|
-
- `route_short_name` – název linky
|
|
303
|
-
- `route_type` – typ dopravy (GTFS route_type)
|
|
304
|
-
- `trip_id` – GTFS id spoje
|
|
305
|
-
- `stop_sequence` – pořadí zastávky v spoji
|
|
306
|
-
- `platform_code` – označení nástupiště, nebo `null`
|
|
307
|
-
- `trip_headsign` – cílová zastávka spoje (nebo `stop_headsign`, pokud je definován)
|
|
308
|
-
- `trip_headsign_icons` – ikony přestupů u cílové zastávky jako řetězec dvouznaková kódů (např. `"MbMcSb"`), nebo `null`
|
|
309
|
-
- `connections` – seznam garantovaných přestupů čekajících na tento spoj, nebo `null`; každý záznam obsahuje:
|
|
310
|
-
- `from_trip_id` – GTFS id spoje, na který se čeká
|
|
311
|
-
- `max_wait_sec` – maximální čekací doba v sekundách
|
|
312
|
-
- Přednačítá se z tabulky `ropidgtfs_precomputed_trip_connections` (původně z `transfers.txt` kde `transfer_type = 1`), JOIN na odjezdy přes `to_trip_id` a `to_stop_id`
|
|
313
|
-
- `wheelchair_accessible` – přístupnost vozidla pro vozíčkáře z GTFS `trips.txt` (`0` = bez informace, `1` = přístupné, `2` = nepřístupné), nebo `null`
|
|
297
|
+
- Hodnota je sorted set, kde score je unix timestamp odjezdu v sekundách a member jsou relevantní informace o odjezdu
|
|
314
298
|
- Existuje záznam pro každou zastávku v GTFS. Pokud v ní ale není žádný odjezd, je vyplněný pouze jeden prázdný member - detekce validní zastávky bez odjezdu
|
|
315
299
|
- TTL 7 hodin
|
|
316
300
|
- Retence dat aktivní, jednou za hodinu se smažou všechny odjezdy starší než 3 hodiny
|
|
317
301
|
- Jednou za hodinu se vygenerují nové odjezdy pro všechny zastávky v intervalu +5 hodin až +7 hodin, po přenačtení JŘ se přegenerují všechny odjezdy v interval -3 hodiny až +7 hodin
|
|
318
302
|
- Ukládá se pomocí `ZADD`, čte se pomocí `ZRANGEBYSCORE` (-inf, now + `minutesAfter`)
|
|
319
303
|
- Využití v public odjezdech
|
|
320
|
-
- Využití v endpointu přestupních tabulí
|
|
304
|
+
- Využití v endpointu přestupních tabulí
|
|
321
305
|
|
|
322
306
|
### Flowchart (refresh)
|
|
323
307
|
|
|
@@ -544,43 +528,3 @@ flowchart LR
|
|
|
544
528
|

|
|
545
529
|
|
|
546
530
|
link na .drawio [soubor](../../assets/V4Transferboards.drawio)
|
|
547
|
-
|
|
548
|
-
## Cache pro konfiguraci
|
|
549
|
-
|
|
550
|
-
### config:notPublicVehicles
|
|
551
|
-
|
|
552
|
-
- Klíč `config:notPublicVehicles` (jednoduchý klíč, žádný wildcard)
|
|
553
|
-
- Hodnota je JSON string struktury `INotPublicVehicles`:
|
|
554
|
-
- `tram.registrationNumbers` – seznam evidenčních čísel tramvají bez platného GTFS spoje
|
|
555
|
-
- `road.registrationNumbers` – seznam evidenčních čísel autobusů a trolejbusů bez platného GTFS spoje (`road` pokrývá obě kategorie, protože sdílejí číselnou řadu)
|
|
556
|
-
- `routeIds` – whitelist čísel linek (např. `"861"` pro náhradní autobus X-C při výluce metra C) zobrazovaných i bez platného JŘ spoje
|
|
557
|
-
- TTL žádné – hodnota se přepíše při každém spuštění `SaveStaticDataTask` (po načtení nových JŘ)
|
|
558
|
-
- Zapisuje `NotPublicVehiclesRedisRepository` (IE), čte `TripsRepository` / `PositionsMapper` (IE) a `UpdateRunsGtfsTripIdTask` (IE) pro povolení průchodu vozidel bez GTFS spoje
|
|
559
|
-
|
|
560
|
-
## Manuální refresh cache (EnsureCacheTask)
|
|
561
|
-
|
|
562
|
-
`EnsureCacheTask` slouží jako manuální spouštěč obnovy všech 4 caches, jejichž data nejsou real-time obnovována. Po přijetí prázdné zprávy na frontě `vehicle-positions.ropidgtfs.ensureCache` odešle paralelně prázdné zprávy do všech 4 cílových front. Dvě z nich míří do různých workerů (cross-worker routing přes RabbitMQ exchange), dvě míří do stejného workeru (TimetableWorker).
|
|
563
|
-
|
|
564
|
-
### Flowchart
|
|
565
|
-
|
|
566
|
-
```mermaid
|
|
567
|
-
flowchart LR
|
|
568
|
-
trigger["`Zpráva do fronty ensureCache`"]
|
|
569
|
-
task["`EnsureCacheTask (TimetableWorker)`"]
|
|
570
|
-
|
|
571
|
-
exchange_vp["`Exchange ${RABBIT_EXCHANGE_NAME}.vehiclepositions (VPWorker)`"]
|
|
572
|
-
exchange_self["`Exchange this.queuePrefix (TimetableWorker)`"]
|
|
573
|
-
exchange_jis["`Exchange ${RABBIT_EXCHANGE_NAME}.jis (JISWorker)`"]
|
|
574
|
-
|
|
575
|
-
q1["`AMQP refreshGTFSTripData`"]
|
|
576
|
-
q2["`AMQP refreshPublicGtfsDepartureCache`"]
|
|
577
|
-
q3["`AMQP refreshGtfsStopsCache`"]
|
|
578
|
-
q4["`AMQP refreshJISInfotextsCache`"]
|
|
579
|
-
|
|
580
|
-
trigger --> task
|
|
581
|
-
task -- cross-worker --> exchange_vp --> q1
|
|
582
|
-
task -- same-worker --> exchange_self --> q2
|
|
583
|
-
exchange_self --> q3
|
|
584
|
-
task -- cross-worker --> exchange_jis --> q4
|
|
585
|
-
```
|
|
586
|
-
|
|
@@ -264,14 +264,12 @@ _:warning: Původním záměrem bylo využití OIS číselníku během zpracová
|
|
|
264
264
|
- baseUrl: module.pid.staticData.baseUrl
|
|
265
265
|
- departure directions url: module.pid.staticData.departuresDirection.path
|
|
266
266
|
- metro rail track url: module.pid.staticData.metroRailTracks.path
|
|
267
|
-
- not public vehicles url: module.pid.staticData.notPublicVehicles.path
|
|
268
267
|
- formát dat
|
|
269
268
|
- protokol: http
|
|
270
|
-
- datový typ: csv
|
|
269
|
+
- datový typ: csv
|
|
271
270
|
- validační schéma:
|
|
272
271
|
- [MetroRailTrack](../src/schema-definitions/datasources/static-data/MetroRailTrackJsonSchema.ts)
|
|
273
272
|
- [DeparturesDirection](../src/schema-definitions/datasources/static-data/DeparturesDirectionsJsonSchema.ts)
|
|
274
|
-
- [NotPublicVehicles](../src/schema-definitions/datasources/static-data/interfaces/NotPublicVehiclesDataInterface.ts) – interface `INotPublicVehicles`
|
|
275
273
|
- příklad vstupnich dat: viz zdroj data
|
|
276
274
|
- frekvence stahování
|
|
277
275
|
- Po nacteni jizdnich radu (fronta: vehicle-positions.ropidgtfs.checkForNewData)
|
|
@@ -514,9 +512,6 @@ Všechny tabulky se nachází ve schématu `pid`
|
|
|
514
512
|
- [RopidGTFSRunNumbersTransformation](https://gitlab.com/operator-ict/golemio/code/modules/pid/-/blob/development/src/integration-engine/ropid-gtfs/transformations/RopidGTFSRunNumbersTransformation.ts)
|
|
515
513
|
- [RopidGtfsRouteSubAgencyTransformation](https://gitlab.com/operator-ict/golemio/code/modules/pid/-/blob/development/src/integration-engine/ropid-gtfs/transformations/RopidGtfsRouteSubAgencyTransformation.ts)
|
|
516
514
|
- on top of transformation functionality it also removes duplicates. Rule: If there are multiple rows with same `route_id` and `sub_agency_id` only the first with filled licence number is kept.
|
|
517
|
-
- rozšířené sloupce GTFS souborů (nestandardní rozšíření ROPID)
|
|
518
|
-
- `trips.txt` – sloupec `headsign_icons`: řetězec dvouznakových kódů ikon (např. `"MbSb"`), uložen do `ropidgtfs_trips.headsign_icons`
|
|
519
|
-
- `stop_times.txt` – sloupec `headsign_icons`: přepis na úrovni zastávky, uložen do `ropidgtfs_stop_times.headsign_icons`; má přednost před hodnotou z `trips.txt` pokud je zároveň vyplněn `stop_headsign`
|
|
520
515
|
- data modely
|
|
521
516
|
- RopidGTFSMetadataModel `ropidgtfs_metadata`
|
|
522
517
|
- RopidGTFSAgencyModel `ropidgtfs_agency`
|
|
@@ -567,7 +562,6 @@ Všechny tabulky se nachází ve schématu `pid`
|
|
|
567
562
|
- RopidGTFSPrecomputedMinMaxStopSequencesModel `ropidgtfs_precomputed_minmax_stop_sequences`
|
|
568
563
|
- RopidGTFSPrecomputedDeparturesModel `ropidgtfs_precomputed_departures`
|
|
569
564
|
- RopidGTFSPrecomputedTripScheduleModel `ropidgtfs_precomputed_trip_schedule`
|
|
570
|
-
- RopidGTFSPrecomputedTripConnectionsModel `ropidgtfs_precomputed_trip_connections`
|
|
571
565
|
|
|
572
566
|
#### task _RefreshPrecomputedTables_
|
|
573
567
|
|
|
@@ -587,7 +581,6 @@ Všechny tabulky se nachází ve schématu `pid`
|
|
|
587
581
|
- RopidGTFSPrecomputedMinMaxStopSequencesModel `ropidgtfs_precomputed_minmax_stop_sequences`
|
|
588
582
|
- RopidGTFSPrecomputedDeparturesModel `ropidgtfs_precomputed_departures`
|
|
589
583
|
- RopidGTFSPrecomputedTripScheduleModel `ropidgtfs_precomputed_trip_schedule`
|
|
590
|
-
- RopidGTFSPrecomputedTripConnectionsModel `ropidgtfs_precomputed_trip_connections`
|
|
591
584
|
|
|
592
585
|
#### task _RefreshPublicGtfsDepartureCacheTask_
|
|
593
586
|
|
|
@@ -603,10 +596,8 @@ Task se stará o aktualizaci cache pro public odjezdy. Pouští se pravidelně c
|
|
|
603
596
|
- ROPID FTP
|
|
604
597
|
- transformace
|
|
605
598
|
- [PublicDepartureCacheTransformation](../src/integration-engine/ropid-gtfs/transformations/PublicDepartureCacheTransformation.ts)
|
|
606
|
-
- výsledný cache záznam obsahuje pole `connections` (garantované přestupy – přednačtené z `ropidgtfs_precomputed_trip_connections`, původně z `transfers.txt` kde `transfer_type = 1`) a pole `wheelchair_accessible` (přístupnost vozidla pro vozíčkáře z GTFS `trips.txt`)
|
|
607
|
-
- pole `trip_headsign_icons`: pokud je pro danou zastávku spoje vyplněn `stop_headsign`, použije se `stop_headsign_icons` z `ropidgtfs_stop_times`; jinak se použije `headsign_icons` z `ropidgtfs_trips`; výsledek je řetězec dvouznakových kódů (např. `"MbMcSb"`) nebo `null`
|
|
608
599
|
- data modely
|
|
609
|
-
- RopidGTFSPrecomputedDeparturesModel `ropidgtfs_precomputed_departures`
|
|
600
|
+
- RopidGTFSPrecomputedDeparturesModel `ropidgtfs_precomputed_departures`
|
|
610
601
|
|
|
611
602
|
#### task _SaveStaticData_
|
|
612
603
|
|
|
@@ -622,39 +613,9 @@ Task se stará o aktualizaci statickych dat. Pouští se po dokončení načten
|
|
|
622
613
|
- transformace
|
|
623
614
|
- [DeparturesDirectionTransformation](../src/integration-engine/ropid-gtfs/workers/timetables/tasks/transformations/DeparturesDirectionTransformation.ts)
|
|
624
615
|
- [MetroRailtrackDataTransformation](../src/integration-engine/ropid-gtfs/workers/timetables/tasks/transformations/MetroRailtrackDataTransformation.ts)
|
|
625
|
-
- `NotPublicVehicles` – data se ukládají přímo do cache klíče `config:notPublicVehicles` přes `NotPublicVehiclesRedisRepository` (žádná DB tabulka)
|
|
626
616
|
- data modely
|
|
627
617
|
- RopidDeparturesDirections `ropid_departures_directions`
|
|
628
618
|
- RopidGtfsMetroRailtrackGps `ropidgtfs_metro_railtrack_gps`
|
|
629
|
-
- Cache `config:notPublicVehicles` – JSON blob struktury `INotPublicVehicles`:
|
|
630
|
-
```json
|
|
631
|
-
{
|
|
632
|
-
"tram": { "registrationNumbers": ["string"] },
|
|
633
|
-
"road": { "registrationNumbers": ["string"] },
|
|
634
|
-
"routeIds": ["string"]
|
|
635
|
-
}
|
|
636
|
-
```
|
|
637
|
-
`road` pokrývá autobusy i trolejbusy (evidenční čísla se mohou překrývat s tramvajemi, proto jsou oddělena). `routeIds` je whitelist číselných identifikátorů náhradních nebo dočasných linek (např. náhradní autobus za metro při výluce nebo mimořádné události), které se mají zobrazovat i bez platného JŘ spoje.
|
|
638
|
-
|
|
639
|
-
#### task _EnsureCacheTask_
|
|
640
|
-
|
|
641
|
-
Task slouží jako ruční spouštěč obnovení všech cache. Nespouští se automaticky – pouze manuálním odesláním zprávy do fronty.
|
|
642
|
-
|
|
643
|
-
- vstupní rabbitmq fronta
|
|
644
|
-
- název: vehicle-positions.ropidgtfs.ensureCache
|
|
645
|
-
- TTL: 5 minut
|
|
646
|
-
- parametry: žádné
|
|
647
|
-
- závislé fronty (do kterých jsou odesílány zprávy z metody workeru)
|
|
648
|
-
- název: vehicle-positions.vehiclepositions.refreshGTFSTripData
|
|
649
|
-
- název: vehicle-positions.ropidgtfs.refreshPublicGtfsDepartureCache
|
|
650
|
-
- název: vehicle-positions.ropidgtfs.refreshGtfsStopsCache
|
|
651
|
-
- název: vehicle-positions.jis.refreshJISInfotextsCache
|
|
652
|
-
- datové zdroje
|
|
653
|
-
- žádné
|
|
654
|
-
- transformace
|
|
655
|
-
- žádné
|
|
656
|
-
- data modely
|
|
657
|
-
- žádné
|
|
658
619
|
|
|
659
620
|
|
|
660
621
|
|
|
@@ -1101,18 +1062,6 @@ Worker má na starost generování souborů s realtime daty pro `gtfsrt` endpoin
|
|
|
1101
1062
|
- VPTripsModel `vehiclepositions_trips`
|
|
1102
1063
|
- VPPositionsModel `vehiclepositions_positions`
|
|
1103
1064
|
|
|
1104
|
-
**`wheelchairAccessible` ve VehicleDescriptor**
|
|
1105
|
-
|
|
1106
|
-
Pole `wheelchairAccessible` je součástí standardního `VehicleDescriptor` ve feedech `vehicle_positions.pb` a `pid_feed.pb`:
|
|
1107
|
-
|
|
1108
|
-
| Interní hodnota | Proto enum |
|
|
1109
|
-
|---|---|
|
|
1110
|
-
| `null` | `WHEELCHAIR_ACCESSIBLE_UNSPECIFIED = 0` |
|
|
1111
|
-
| `true` | `WHEELCHAIR_ACCESSIBLE = 1` |
|
|
1112
|
-
| `false` | `WHEELCHAIR_INACCESSIBLE = 2` |
|
|
1113
|
-
|
|
1114
|
-
Zdrojem je pole `wheelchair_accessible` z tabulky `vehiclepositions_trips` (přenášené přes `IGtfsRtTripDto`). Vedle standardního pole zůstává zachováno rozšíření `.transit_realtime.ovapiVehicleDescriptor.wheelchairAccessible` s původní boolean/null hodnotou.
|
|
1115
|
-
|
|
1116
1065
|
**Určení zpoždění v trip_updates.pb**
|
|
1117
1066
|
|
|
1118
1067
|
Predikce odjezdů probíhá podle vzorce:
|
|
@@ -1218,10 +1167,6 @@ Worker má na starost stahování VYMI (JIS) událostí a infotextů, jejich tra
|
|
|
1218
1167
|
- data modely
|
|
1219
1168
|
- JISEventsModel `jis_events`
|
|
1220
1169
|
- JISEventsRopidGTFSRoutesModel `jis_events_ropidgtfs_routes`
|
|
1221
|
-
- poznámky k datovému modelu
|
|
1222
|
-
- pole `effects` je pole až 3 unikátních řetězců; v GTFS-RT `Alert.effect` se použije pouze `effects[0]`, zbývající hodnoty jsou dostupné pouze v custom-format exportu
|
|
1223
|
-
- pole `cause_detail` je volný text zpřesňující příčinu události; může být `null`
|
|
1224
|
-
- pole `cause` obsahuje překlady do češtiny i angličtiny; anglické hodnoty jsou zahrnuty i ve výstupu GTFS-RT alert feedu
|
|
1225
1170
|
|
|
1226
1171
|
#### _task: RefreshJISInfotextsTask_
|
|
1227
1172
|
|
|
@@ -1316,7 +1261,7 @@ Worker má na starost stahování VYMI (JIS) událostí a infotextů, jejich tra
|
|
|
1316
1261
|
- retence dat
|
|
1317
1262
|
- jízdní řády se generují 1-2x denně na 14 dní dopředu
|
|
1318
1263
|
- polohová data si uchováváme 24 hodin (30 minut od poslední aktualizace, poté v historických tabulkách)
|
|
1319
|
-
- popis vozidel
|
|
1264
|
+
- popis vozidel si uchováváme 24 hodin
|
|
1320
1265
|
- preset logy si uchováváme 8 hodin
|
|
1321
1266
|
- JIS události a infotexty si uchováváme neomezeně
|
|
1322
1267
|
|
|
@@ -1459,12 +1404,6 @@ Worker má na starost stahování VYMI (JIS) událostí a infotextů, jejich tra
|
|
|
1459
1404
|
|
|
1460
1405
|
- zdrojové tabulky
|
|
1461
1406
|
- `ropidgtfs_precomputed_departures`, `ropidgtfs_stops`, `ropidgtfs_cis_stops`, `jis_infotexts`, `jis_infotexts_ropidgtfs_stops`, `ropid_departures_directions`, `vehiclepositions_positions`, `vehiclepositions_trips`
|
|
1462
|
-
- odpověď obsahuje hlavičku `X-Golemio-Preset-Metadata: airConditionPossible=0|1`
|
|
1463
|
-
- `1` pokud byl zadán query parametr `airCondition` s pravdivou hodnotou, `0` jinak
|
|
1464
|
-
- slouží monitorovacím systémům (preset systémy monitorovacího centra ROPID) k detekci aktivního filtrování dle klimatizace
|
|
1465
|
-
- kód nástupiště (`platform_code`)
|
|
1466
|
-
- **vlaky**: preferuje se CIS hodnota `cis_stop_platform_code` uložená z MPVNet zpráv (`PlatformCodeResolver`); MPVNet atribut `$.stan` je před uložením oříznut na první platný segment (viz [parsování `stan` u vlaků](../processing/input_realtime_data/http_mpvnet.md#parsování-stanoviště-stan-u-vlaků))
|
|
1467
|
-
- **ostatní typy**: používá se GTFS `platform_code` ze `stop_times.txt`
|
|
1468
1407
|
|
|
1469
1408
|
### PID Departure Boards v3
|
|
1470
1409
|
|
|
@@ -1472,42 +1411,6 @@ Worker má na starost stahování VYMI (JIS) událostí a infotextů, jejich tra
|
|
|
1472
1411
|
|
|
1473
1412
|
- načte odjezdy pro přestupní tabule ve vozidlech a aktivní infotexty exportované z aplikace VYMI (JIS) Infotexty
|
|
1474
1413
|
|
|
1475
|
-
### PID Departure Boards v4
|
|
1476
|
-
|
|
1477
|
-
#### _/v4/pid/transferboards_
|
|
1478
|
-
|
|
1479
|
-
- načte odjezdy pro přestupní tabule ve vozidlech na základě aktuální polohy vozidla a aktivní infotexty exportované z aplikace VYMI (JIS) Infotexty
|
|
1480
|
-
- parametry
|
|
1481
|
-
- `aswId` + `vehicleRegistrationNumber` + `routeType` – identifikace zastávky a vozidla přes ASW číselník (vzájemně se vylučuje s `cisId`+`tripNumber`)
|
|
1482
|
-
- `cisId` + `tripNumber` – identifikace zastávky a spoje přes CIS číselník (zatím neimplementováno, vrací 501)
|
|
1483
|
-
- `timeFrom` – volitelný ISO8601 čas příjezdu (pokud není zadán, použije se reálný čas příjezdu z RT dat)
|
|
1484
|
-
- `limit` – volitelný počet odjezdů (výchozí 8, max 30)
|
|
1485
|
-
- cachováno na 5 sekund (stale-while-revalidate 5 sekund)
|
|
1486
|
-
- zdrojové cache záznamy
|
|
1487
|
-
- `gtfsStopsCache:*` – převod ASW node ID na GTFS stop_id
|
|
1488
|
-
- `gtfsDelayComputation:*` – zjištění zastávek spoje a predikovaného času příjezdu
|
|
1489
|
-
- `vpPublicCache:*` – aktuální poloha a zpoždění vozidla
|
|
1490
|
-
- `gtfsPublicDepartureCache:*` – statické odjezdy ze zastávek (vč. `connections` a `wheelchair_accessible`)
|
|
1491
|
-
- `vpPublicStopTimeCache:*` – live zastávkové časy pro spoje se známou polohou
|
|
1492
|
-
- `jisCache:*` – aktivní infotexty pro dané zastávky
|
|
1493
|
-
- načítání odjezdů z cache (`gtfsPublicDepartureCache`)
|
|
1494
|
-
- z každé zastávky se načte `max(80, min(120, limit × 10))` položek v časovém okně `[plannedTimeFrom − 61 min, plannedTimeFrom + 60 min + delay]`; lookback 61 minut zajišťuje, že se zachytí i navazující spoj, jehož plánovaný odjezd je v minulosti, ale díky vlastnímu zpoždění (až 60 minut) dorazí na zastávku až po příjezdu aktuálního vozidla
|
|
1495
|
-
- ihned po načtení se aplikuje pre-filter: odjezdy autobusů, tramvají a trolejbusů ze zastávek s jiným názvem než aktuální zastávka jsou zahozeny; metro/vlak/přívoz/lanovka procházejí vždy; odjezdy s neprázdným polem `connections[]` jsou zachovány bez ohledu na název zastávky (potenciální garantovaný přestup)
|
|
1496
|
-
- garantované přestupy (`is_guaranteed_transfer`)
|
|
1497
|
-
- označují odjezdy, které na příjezd aktuálního spoje čekají – detekováno z pole `connections` v `gtfsPublicDepartureCache`, kde `from_trip_id` odpovídá aktuálnímu spoji a `arrivalTime < departure_datetime + max_wait_sec`
|
|
1498
|
-
- zobrazované minuty u garantovaného přestupu jsou nastaveny na čas příjezdu aktuálního spoje (ne na plánovaný odjezd navazujícího spoje)
|
|
1499
|
-
- garantované přestupy jsou vyjmuty z filtru opačného směru a filtru podskupiny linky – jsou přidány do `tripIdsToKeep` před spuštěním `findRelevantTripIdsFromLines`, takže projdou bez ohledu na zastávkovou sekvenci
|
|
1500
|
-
- typy "vždy zobrazit" (metro, vlak, přívoz, lanovka) filtr `findRelevantTripIdsFromLines` zcela přeskakují
|
|
1501
|
-
- dostupnost pro vozíčkáře (`is_wheelchair_accessible`)
|
|
1502
|
-
- **metro**: určeno výhradně podle `wheelchair_boarding` zastávky (hodnota `1` = přístupná)
|
|
1503
|
-
- **ostatní typy dopravy**: primárně z RT dat vozidla (`detailed_info.is_wheelchair_accessible`); pokud RT data nejsou k dispozici, použije se GTFS příznak `wheelchair_accessible` z `trips.txt` (`1` = přístupné vozidlo)
|
|
1504
|
-
- seskupování a omezení výstupu (`TransferDepartureCacheTransformation`)
|
|
1505
|
-
- **metro**: seskupuje se podle `route_short_name + stop_id`; na jeden záznam výstupu připadají až 2 hodnoty v poli `departure_timestamp.minutes[]`
|
|
1506
|
-
- **ostatní typy**: seskupuje se podle `route_short_name + direction_id`; na skupinu připadají nejvýše 2 samostatné záznamy odjezdů; `direction_id` se získává z cache poloh vozidel (klíč `route_short_name + trip_headsign`), výchozí hodnota je `0`
|
|
1507
|
-
- konfigurace filtrování opačného směru (backtracking)
|
|
1508
|
-
- `module.pid.vehicle-positions.transferboards.isOppositeDirectionFilterStopNameStrict` (boolean, výchozí `true`) – pokud `true`, zastávka je považována za "zpětnou" pouze pokud se shoduje `stop_id` i `stop_name`; pokud `false`, stačí shoda `stop_id`
|
|
1509
|
-
- `module.pid.vehicle-positions.transferboards.countPreviousStopsToAllow` (integer, výchozí `0`) – kolik předchozích zastávek aktuálního spoje smí kandidátní spoj sdílet ve svých nadcházejících zastávkách, než je považován za zpětný směr a odfiltrován; `0` znamená žádná shoda není povolena
|
|
1510
|
-
|
|
1511
1414
|
#### _/v3/pid/infotexts_
|
|
1512
1415
|
|
|
1513
1416
|
- načte aktivní infotexty exportované z aplikace VYMI (JIS) Infotexty
|
|
@@ -1555,20 +1458,4 @@ Worker má na starost stahování VYMI (JIS) událostí a infotextů, jejich tra
|
|
|
1555
1458
|
- podle názvů linek a jak daleko do budoucnosti se mají odjezdy navracet
|
|
1556
1459
|
- limitování počtu odjezdů v každé skupině
|
|
1557
1460
|
- EP je optimalizován pro vyšší zátěž z mobilní aplikace PID lítačka - požadavek do databáze z OG pouze v případě nutnosti obnovit cache s vehicle descriptory (klimatizace, usb nabíječky), jinak je vše z Redisu
|
|
1558
|
-
- deduplikace odjezdů (pro seskupení "jeden za linka+směr") se provádí podle klíče `route_id + trip_headsign + platform_code`; toto se liší od původního přístupu deduplikace podle `stop_id` a správně pokrývá situace, kdy jeden ASW uzel odpovídá více GTFS `stop_id`
|
|
1559
|
-
- dostupnost pro vozíčkáře (`is_wheelchair_accessible`) se určuje v pořadí priority:
|
|
1560
|
-
1. RT descriptor vozidla (`detailed_info.is_wheelchair_accessible` z vehicle positions)
|
|
1561
|
-
2. GTFS statický příznak `wheelchair_accessible` z `trips.txt` (`1` = přístupné), pokud RT data nejsou k dispozici
|
|
1562
1461
|
- je použit `CompressionByDefaultMiddleware` a odpovědi jsou tak na output gateway komprimovány i pokud klient explicitně nepovolí komprimaci vhodnou hodnotou hlavičky `Accept-Encoding` (lze však komprimaci explicitně zakázat hodnotou `identity`)
|
|
1563
|
-
|
|
1564
|
-
### JIS v1
|
|
1565
|
-
|
|
1566
|
-
#### _/v1/jis/events/custom-format_
|
|
1567
|
-
|
|
1568
|
-
- vrátí seznam publikovaných událostí ve vlastním formátu pro externí konzumenty (fallback endpoint pro webhooky)
|
|
1569
|
-
- parametry
|
|
1570
|
-
- `displayPeriodStart` / `displayPeriodEnd` – filtrování podle překryvu zobrazovacího okna události s požadovaným rozsahem (ISO 8601)
|
|
1571
|
-
- `organizationNames` – filtrování podle organizace (pole řetězců)
|
|
1572
|
-
- `type` – filtrování podle typu události (`INCIDENT`, `DISRUPTION`, `SERVICE_CHANGE`)
|
|
1573
|
-
- zdrojové tabulky: `jis_events`, `jis_events_ropidgtfs_routes`
|
|
1574
|
-
- formát odpovědi: viz schéma `EventCustomFormat` v [openapi-output.yaml](./openapi-output.yaml)
|
package/docs/jis/index.md
CHANGED
|
@@ -246,20 +246,3 @@ flowchart TB
|
|
|
246
246
|
```
|
|
247
247
|
|
|
248
248
|
Zdroj a formát dat pro aktivní stahování jsou dále více popsány v implementační dokumentaci ([události](../implementation_documentation.md#jis-events), [infotexty](../implementation_documentation.md#jis-infotexts)), stejně tak jako [worker a tasky](../implementation_documentation.md#jisworker) a popis [uložení dat](../implementation_documentation.md#uložení-dat) včetně databázového schema a popisu retence.
|
|
249
|
-
|
|
250
|
-
## Datový model událostí — vybraná pole
|
|
251
|
-
|
|
252
|
-
### `cause_detail`
|
|
253
|
-
|
|
254
|
-
Volitelné textové upřesnění příčiny události (`cause_detail`). Může být `null`. Dostupné v custom-format exportu (`/v1/jis/events/custom-format`) i v GTFS-RT alert feedu jako rozšíření. Struktura:
|
|
255
|
-
```json
|
|
256
|
-
{ "cs": "Nehoda na křižovatce", "en": null }
|
|
257
|
-
```
|
|
258
|
-
|
|
259
|
-
### `cause` — anglický překlad
|
|
260
|
-
|
|
261
|
-
Pole `cause` obsahuje překlad příčiny události do češtiny i do angličtiny. Anglická hodnota je zahrnuta i ve výstupu GTFS-RT alert feedu (pole `Alert.cause` v `pid_feed.pb` i `alerts.pb`).
|
|
262
|
-
|
|
263
|
-
### `effects` (pole příčin dopadu)
|
|
264
|
-
|
|
265
|
-
Pole `effects` může obsahovat 1–3 unikátní řetězcové hodnoty. Pouze `effects[0]` se mapuje na standardní GTFS-RT `Alert.effect`; zbývající hodnoty jsou dostupné výhradně v custom-format exportu.
|
|
@@ -92,27 +92,6 @@
|
|
|
92
92
|
```
|
|
93
93
|
|
|
94
94
|
## Vlaky
|
|
95
|
-
|
|
96
|
-
### Parsování stanoviště (`stan`) u vlaků
|
|
97
|
-
|
|
98
|
-
Atribut `stan` v elementu `<zast>` u vlaků může obsahovat složený řetězec ve formátu `část1/část2` nebo `část1 část2` (např. `5S/22S`, `-/6`, `2/3`). Jako kanonický kód nástupiště se použije **první platný segment** – první token oddělený lomítkem nebo mezerou, pokud není prázdný nebo `-`.
|
|
99
|
-
|
|
100
|
-
Příklady výsledků po parsování:
|
|
101
|
-
|
|
102
|
-
| Vstup (`stan`) | Výsledný `platform_code` |
|
|
103
|
-
|---|---|
|
|
104
|
-
| `1/3` | `1` |
|
|
105
|
-
| `-/BUS` | `BUS` |
|
|
106
|
-
| `2/100V` | `2` |
|
|
107
|
-
| `5A/- A C` | `5A` |
|
|
108
|
-
| `5S/22S` | `5S` |
|
|
109
|
-
|
|
110
|
-
Parsování provádí `MpvStopParser.parsePlatformCode()`. Výsledný kód je uložen jako `cis_stop_platform_code` v tabulce `vehiclepositions_positions` a na výstupu se pro vlaky preferuje před GTFS `platform_code` (viz `PlatformCodeResolver`).
|
|
111
|
-
|
|
112
|
-
### Zprávy s informací o nástupišti jako syntetická poloha
|
|
113
|
-
|
|
114
|
-
Pokud MPVNet zpráva vlaku obsahuje informaci o nástupišti (`$.stan`) pro budoucí zastávku a vlak ještě nemá žádnou aktivní RT polohu, vytvoří se syntetická poloha ve stavu `before_track` na základě dat z této zastávky. Díky tomu lze zobrazit kód nástupiště ještě před fyzickým příjezdem vlaku na stanoviště. Kód nástupiště se parsuje stejným způsobem jako výše (`MpvStopParser.parsePlatformCode()`).
|
|
115
|
-
|
|
116
95
|
```xml
|
|
117
96
|
<?xml version="1.0" encoding="utf-8"?>
|
|
118
97
|
|
|
@@ -13,7 +13,6 @@
|
|
|
13
13
|
- duplikace vlakových spojů a pozic podle block id (určení tracking podle cis stop id)
|
|
14
14
|
- obohacení spojů GTFS daty (včetně oběhu a kmenové linky)
|
|
15
15
|
- upsert asociovaných pozic
|
|
16
|
-
- **syntetická poloha z informace o nástupišti**: pokud zpráva obsahuje atribut `$.stan` pro budoucí zastávku a vlak ještě nemá aktivní RT polohu, vytvoří se syntetická pozice ve stavu `before_track` pro tuto zastávku – umožňuje zobrazit kód nástupiště před fyzickým příjezdem vlaku
|
|
17
16
|
- spoje se pošlou do fronty `updateDelay`
|
|
18
17
|
- updateDelay
|
|
19
18
|
- opět duplikace vlakových spojů, upsert asociovaných pozic
|
|
@@ -33,7 +33,6 @@
|
|
|
33
33
|
- pokud je pozice duplicitní (existuje pozice se stejným `origin_timestamp`), stav je `duplicate`
|
|
34
34
|
- pokud vozidlo jede do garáže, je stav `invisible`
|
|
35
35
|
- jinak je stav `after_track`
|
|
36
|
-
- **zvláštní případ**: pokud má pozice `cis_last_stop_id = null`, stav se znovu nevyhodnocuje – pozice si zachovává poslední známý stav (zmrazení stavu); to zabraňuje nežádoucímu cyklování zpět do `untracked` pouze kvůli chybějící CIS zastávce
|
|
37
36
|
- Tracking (`tracking` je `2`)
|
|
38
37
|
- pokud je vozidlo 200 metrů od nejblizšího bodu na trase, stav je `off_track`
|
|
39
38
|
- pokud je vozidlo v zastávce, je stav `at_stop`
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@golemio/pid",
|
|
3
|
-
"version": "5.7.2-
|
|
3
|
+
"version": "5.7.2-rc.2378043360",
|
|
4
4
|
"description": "Golemio PID Module",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"types": "dist/index.d.ts",
|
|
@@ -9,16 +9,13 @@
|
|
|
9
9
|
"build-minimal": "run-s 'build -- --sourceMap false --declaration false'",
|
|
10
10
|
"build-watch": "run-s 'build -- --watch --preserveWatchOutput'",
|
|
11
11
|
"refresh-precomputed-tables": "cross-env NODE_ENV='test' TZ='UTC' ts-node -r tsconfig-paths/register -r dotenv/config test/scripts/refresh-precomputed-tables.ts",
|
|
12
|
-
"
|
|
13
|
-
"test
|
|
14
|
-
"test
|
|
15
|
-
"test": "run-s prepare-db test:only",
|
|
12
|
+
"pretest": "golemio import-db-data && run-s \"refresh-precomputed-tables\"",
|
|
13
|
+
"test": "cross-env NODE_ENV='test' TZ='UTC' mocha --exit --check-leaks --timeout 120000 --reporter-option maxDiffSize=0 -r ts-node/register -r tsconfig-paths/register --file 'test/setup.ts' -r dotenv/config 'test/**/*.test.ts'",
|
|
14
|
+
"test-debug": "run-s 'test -- --inspect-brk=9230'",
|
|
16
15
|
"apidocs-test": "npm run apidocs-test-output",
|
|
17
16
|
"apidocs-test-input": "cross-env NODE_ENV=test golemio swagger api-test --oas docs/openapi-input.yaml --script test/api-docs/input-gateway/server.js --filter test/api-docs/input-gateway/portman-filter.json",
|
|
18
17
|
"apidocs-test-output": "cross-env NODE_ENV=test golemio swagger api-test --oas docs/openapi-output.yaml --script test/api-docs/output-gateway/server.js --config test/api-docs/output-gateway/portman-config.json",
|
|
19
|
-
"coverage
|
|
20
|
-
"code-coverage": "run-s prepare-db coverage:only",
|
|
21
|
-
"format:check-staged": "pretty-quick --staged --pattern '**/*.ts'",
|
|
18
|
+
"code-coverage": "nyc run-s 'test -- -r source-map-support/register'",
|
|
22
19
|
"generate-docs": "typedoc --out docs/typedoc src",
|
|
23
20
|
"lint": "eslint --cache \"{src,test}/**/*.ts\"",
|
|
24
21
|
"validate-dependencies": "dependency-cruiser --config .dependency-cruiser.js src"
|
package/dist/integration-engine/ropid-gtfs/data-access/cache/NotPublicVehiclesRedisRepository.d.ts
DELETED
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { INotPublicVehicles } from "../../../../schema-definitions/datasources/static-data";
|
|
2
|
-
import { RedisModel } from "@golemio/core/dist/integration-engine/models/RedisModel";
|
|
3
|
-
export declare class NotPublicVehiclesRedisRepository extends RedisModel {
|
|
4
|
-
static NAMESPACE_PREFIX: string;
|
|
5
|
-
constructor();
|
|
6
|
-
/**
|
|
7
|
-
* Save the not-public vehicles configuration to Redis
|
|
8
|
-
*/
|
|
9
|
-
saveConfig(config: INotPublicVehicles): Promise<void>;
|
|
10
|
-
/**
|
|
11
|
-
* Get the current not-public vehicles configuration from Redis
|
|
12
|
-
*/
|
|
13
|
-
getConfig(): Promise<INotPublicVehicles>;
|
|
14
|
-
}
|
package/dist/integration-engine/ropid-gtfs/data-access/cache/NotPublicVehiclesRedisRepository.js
DELETED
|
@@ -1,47 +0,0 @@
|
|
|
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
|
-
var NotPublicVehiclesRedisRepository_1;
|
|
12
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
-
exports.NotPublicVehiclesRedisRepository = void 0;
|
|
14
|
-
const const_1 = require("../../../../schema-definitions/ropid-gtfs/redis/const");
|
|
15
|
-
const RedisModel_1 = require("@golemio/core/dist/integration-engine/models/RedisModel");
|
|
16
|
-
const tsyringe_1 = require("@golemio/core/dist/shared/tsyringe");
|
|
17
|
-
let NotPublicVehiclesRedisRepository = NotPublicVehiclesRedisRepository_1 = class NotPublicVehiclesRedisRepository extends RedisModel_1.RedisModel {
|
|
18
|
-
constructor() {
|
|
19
|
-
super("NotPublicVehiclesRedisRepository", {
|
|
20
|
-
isKeyConstructedFromData: false,
|
|
21
|
-
prefix: NotPublicVehiclesRedisRepository_1.NAMESPACE_PREFIX,
|
|
22
|
-
});
|
|
23
|
-
}
|
|
24
|
-
/**
|
|
25
|
-
* Save the not-public vehicles configuration to Redis
|
|
26
|
-
*/
|
|
27
|
-
async saveConfig(config) {
|
|
28
|
-
await this.set(const_1.NOT_PUBLIC_VEHICLES_KEY, JSON.stringify(config));
|
|
29
|
-
}
|
|
30
|
-
/**
|
|
31
|
-
* Get the current not-public vehicles configuration from Redis
|
|
32
|
-
*/
|
|
33
|
-
async getConfig() {
|
|
34
|
-
const value = await this.get(const_1.NOT_PUBLIC_VEHICLES_KEY);
|
|
35
|
-
if (!value) {
|
|
36
|
-
return { road: { registrationNumbers: [] }, tram: { registrationNumbers: [] }, routeIds: [] };
|
|
37
|
-
}
|
|
38
|
-
return JSON.parse(value);
|
|
39
|
-
}
|
|
40
|
-
};
|
|
41
|
-
exports.NotPublicVehiclesRedisRepository = NotPublicVehiclesRedisRepository;
|
|
42
|
-
NotPublicVehiclesRedisRepository.NAMESPACE_PREFIX = const_1.CONFIG_NAMESPACE_PREFIX;
|
|
43
|
-
exports.NotPublicVehiclesRedisRepository = NotPublicVehiclesRedisRepository = NotPublicVehiclesRedisRepository_1 = __decorate([
|
|
44
|
-
(0, tsyringe_1.injectable)(),
|
|
45
|
-
__metadata("design:paramtypes", [])
|
|
46
|
-
], NotPublicVehiclesRedisRepository);
|
|
47
|
-
//# sourceMappingURL=NotPublicVehiclesRedisRepository.js.map
|
package/dist/integration-engine/ropid-gtfs/data-access/cache/NotPublicVehiclesRedisRepository.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"NotPublicVehiclesRedisRepository.js","sourceRoot":"","sources":["../../../../../src/integration-engine/ropid-gtfs/data-access/cache/NotPublicVehiclesRedisRepository.ts"],"names":[],"mappings":";;;;;;;;;;;;;AACA,iFAA+F;AAC/F,wFAAqF;AACrF,iEAAgE;AAGzD,IAAM,gCAAgC,wCAAtC,MAAM,gCAAiC,SAAQ,uBAAU;IAG5D;QACI,KAAK,CAAC,kCAAkC,EAAE;YACtC,wBAAwB,EAAE,KAAK;YAC/B,MAAM,EAAE,kCAAgC,CAAC,gBAAgB;SAC5D,CAAC,CAAC;IACP,CAAC;IAED;;OAEG;IACI,KAAK,CAAC,UAAU,CAAC,MAA0B;QAC9C,MAAM,IAAI,CAAC,GAAG,CAAC,+BAAuB,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC;IACpE,CAAC;IAED;;OAEG;IACI,KAAK,CAAC,SAAS;QAClB,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,+BAAuB,CAAC,CAAC;QACtD,IAAI,CAAC,KAAK,EAAE,CAAC;YACT,OAAO,EAAE,IAAI,EAAE,EAAE,mBAAmB,EAAE,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,mBAAmB,EAAE,EAAE,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC;QAClG,CAAC;QACD,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,CAAuB,CAAC;IACnD,CAAC;;AA1BQ,4EAAgC;AAC3B,iDAAgB,GAAG,+BAAuB,AAA1B,CAA2B;2CADhD,gCAAgC;IAD5C,IAAA,qBAAU,GAAE;;GACA,gCAAgC,CA2B5C"}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import { IDataSourceProvider } from "../../../shared/datasources/IDataSourceProvider";
|
|
2
|
-
import { INotPublicVehicles } from "../../../../schema-definitions/datasources/static-data";
|
|
3
|
-
import { ISimpleConfig } from "@golemio/core/dist/helpers/configuration/ISimpleConfig";
|
|
4
|
-
import { IDataSource } from "@golemio/core/dist/integration-engine";
|
|
5
|
-
export declare class NotPublicVehiclesDataSourceProvider implements IDataSourceProvider<INotPublicVehicles> {
|
|
6
|
-
private config;
|
|
7
|
-
constructor(config: ISimpleConfig);
|
|
8
|
-
getDataSource(): IDataSource;
|
|
9
|
-
}
|
|
@@ -1,47 +0,0 @@
|
|
|
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
|
-
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
-
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
-
};
|
|
14
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
-
exports.NotPublicVehiclesDataSourceProvider = void 0;
|
|
16
|
-
const static_data_1 = require("../../../../schema-definitions/datasources/static-data");
|
|
17
|
-
const CoreToken_1 = require("@golemio/core/dist/helpers/ioc/CoreToken");
|
|
18
|
-
const integration_engine_1 = require("@golemio/core/dist/integration-engine");
|
|
19
|
-
const HTTPFetchProtocolStrategy_1 = require("@golemio/core/dist/integration-engine/datasources/protocol-strategy/HTTPFetchProtocolStrategy");
|
|
20
|
-
const golemio_validator_1 = require("@golemio/core/dist/shared/golemio-validator");
|
|
21
|
-
const tsyringe_1 = require("@golemio/core/dist/shared/tsyringe");
|
|
22
|
-
let NotPublicVehiclesDataSourceProvider = class NotPublicVehiclesDataSourceProvider {
|
|
23
|
-
constructor(config) {
|
|
24
|
-
this.config = config;
|
|
25
|
-
}
|
|
26
|
-
getDataSource() {
|
|
27
|
-
const baseUrl = this.config.getValue("module.pid.staticData.baseUrl");
|
|
28
|
-
const urlPath = this.config.getValue("module.pid.staticData.notPublicVehicles.path");
|
|
29
|
-
const url = new URL(urlPath, baseUrl);
|
|
30
|
-
return new integration_engine_1.DataSource("notPublicVehiclesDataSource", new HTTPFetchProtocolStrategy_1.HTTPFetchProtocolStrategy({
|
|
31
|
-
headers: {
|
|
32
|
-
Accept: "application/json",
|
|
33
|
-
},
|
|
34
|
-
method: "GET",
|
|
35
|
-
timeoutInSeconds: 20,
|
|
36
|
-
url: url.toString(),
|
|
37
|
-
responseType: "json",
|
|
38
|
-
}), new integration_engine_1.JSONDataTypeStrategy({ resultsPath: "" }), new golemio_validator_1.JSONSchemaValidator("notPublicVehiclesDataSourceValidator", static_data_1.notPublicVehiclesJsonSchema));
|
|
39
|
-
}
|
|
40
|
-
};
|
|
41
|
-
exports.NotPublicVehiclesDataSourceProvider = NotPublicVehiclesDataSourceProvider;
|
|
42
|
-
exports.NotPublicVehiclesDataSourceProvider = NotPublicVehiclesDataSourceProvider = __decorate([
|
|
43
|
-
(0, tsyringe_1.injectable)(),
|
|
44
|
-
__param(0, (0, tsyringe_1.inject)(CoreToken_1.CoreToken.SimpleConfig)),
|
|
45
|
-
__metadata("design:paramtypes", [Object])
|
|
46
|
-
], NotPublicVehiclesDataSourceProvider);
|
|
47
|
-
//# sourceMappingURL=NotPublicVehiclesDataSourceProvider.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"NotPublicVehiclesDataSourceProvider.js","sourceRoot":"","sources":["../../../../../src/integration-engine/ropid-gtfs/datasources/static-data/NotPublicVehiclesDataSourceProvider.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AACA,wFAA+F;AAE/F,wEAAqE;AACrE,8EAAsG;AACtG,6IAA0I;AAC1I,mFAAkF;AAClF,iEAAwE;AAGjE,IAAM,mCAAmC,GAAzC,MAAM,mCAAmC;IAC5C,YAAoD,MAAqB;QAArB,WAAM,GAAN,MAAM,CAAe;IAAG,CAAC;IAEtE,aAAa;QAChB,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAS,+BAA+B,CAAC,CAAC;QAC9E,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAS,8CAA8C,CAAC,CAAC;QAC7F,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;QAEtC,OAAO,IAAI,+BAAU,CACjB,6BAA6B,EAC7B,IAAI,qDAAyB,CAAC;YAC1B,OAAO,EAAE;gBACL,MAAM,EAAE,kBAAkB;aAC7B;YACD,MAAM,EAAE,KAAK;YACb,gBAAgB,EAAE,EAAE;YACpB,GAAG,EAAE,GAAG,CAAC,QAAQ,EAAE;YACnB,YAAY,EAAE,MAAM;SACvB,CAAC,EACF,IAAI,yCAAoB,CAAC,EAAE,WAAW,EAAE,EAAE,EAAE,CAAC,EAC7C,IAAI,uCAAmB,CAAC,sCAAsC,EAAE,yCAA2B,CAAC,CAC/F,CAAC;IACN,CAAC;CACJ,CAAA;AAvBY,kFAAmC;8CAAnC,mCAAmC;IAD/C,IAAA,qBAAU,GAAE;IAEI,WAAA,IAAA,iBAAM,EAAC,qBAAS,CAAC,YAAY,CAAC,CAAA;;GADlC,mCAAmC,CAuB/C"}
|