aboutsummaryrefslogtreecommitdiff
path: root/lib/Server (follow)
Commit message (Collapse)AuthorAgeFilesLines
* Server.GtfsRealtime: bugfixstuebinm2024-05-151-1/+1
| | | | | | | | | can't believe it was this simple … but seems to be all that was wrong. Tracktrain should now automatically remove tripUpdates for tickets whose trip has ended more than five minutes ago (taking delay into account). Nothing in the gtfs-rt spec says you should do this, but google likes to complain if one doesn't do this.
* Server.Frontend.SpaceTime: fix lots of bugsstuebinm2024-05-151-49/+54
| | | | | also make the code generally look nicer. Turns out I made a lot more fragile assumptions than I thought I did.
* Server.Ingest: new handling of unassigned trackersstuebinm2024-05-151-71/+135
| | | | | | | | now takes all potential stops along each trip into account when guessing tickets; also checks if a ticket is still likely in case the tracker switched its direction. This should solve many cases where a tracker is accidentally turned off or falls asleep halfway before the last station of one trip, then wakes up in the middle of the next.
* space time diagrams: real time & time zonesstuebinm2024-05-103-86/+178
|
* rough initial work on space-time diagramsstuebinm2024-05-093-0/+107
| | | | | | this does svg templating with hamlet. It might be better to use a javascript library instead (templating svgs is a little confusing tbh), but for now i'll see how far i get with this.
* restructure: split web frontend into several modulesstuebinm2024-05-095-300/+477
|
* restructure: split up the server modulestuebinm2024-05-084-26/+321
|
* fix: tripupdates should not contain old tripsstuebinm2024-05-031-2/+2
| | | | apparently i forgot an if here?
* restructure: get the tracker to work againstuebinm2024-05-023-24/+79
| | | | | | | | | | | | | | | This should hopefully be the final (major) part of the restructuring: a tracker no longer has to know which trip it is on (and indeed it has no idea for now), instead the server keeps state about which trips are currently running and will insert incoming pings in a hopefully reasonable manner, based on their geoposition & time. There's lots of associated TODO items here (especially there should be manual overrides for all this logic in the web ui), but that's work for a future me. (incidentally, this also adds support for sending all log messages out via ntfy-sh)
* correct styling on mobile devicesstuebinm2024-04-241-1/+4
|
* restructure: save a ticket's stop in the databasestuebinm2024-04-242-155/+234
| | | | now mostly independent of the gtfs, but still no live-reloading of it.
* restructure: have "tickets" independent of gtfsstuebinm2024-04-202-92/+181
| | | | | | this is mostly meant to guard against the gtfs changing under tracktrain, and not yet complete (e.g. a ticket does not yet save its expected stops, which it probably should).
* general housekeepingstuebinm2024-04-173-13/+1
| | | | | jumps to GHC2021 as default language, adds in some fields, moves the old org mode glossary to markdown, etc.
* replace protocol-buffers with proto-lensstuebinm2024-04-172-275/+172
| | | | | | I do not really like either option, but at least the second one seems more likely to be maintained (and a little less clunky to use, too, for what it's worth).
* gtfs-rt: discard old trips from tripupdates feedstuebinm2023-05-231-7/+12
| | | | google maps complains about it otherwise
* expose the gtfs.zip used in the APIstuebinm2023-05-202-4/+5
|
* don't hardcode cssstuebinm2023-02-231-63/+1
|
* better web interface & cssstuebinm2023-01-282-28/+72
|
* switch to ghc 9.0.2stuebinm2023-01-221-27/+1
| | | | this makes the nix builds /much/ nicer
* oauth2 via uffdstuebinm2023-01-221-37/+103
| | | | | | this is unfortunately uffd-specific, since oauth2 is apparently sort of a vague standard. But since it doesn't actually do much it should probably be possible to make it fully configurable & generic if needed.
* simple realtime position mapstuebinm2022-12-131-0/+48
| | | | | (what was that about doing the realtime stuff somewhere else and /not/ in this monolithic server thingie? oh well …)
* stylish-haskell runstuebinm2022-12-122-5/+6
|
* gtfs-rt: set trip_descriptor.schedule_relationshipstuebinm2022-12-031-1/+2
| | | | (hardcoded for now, since we don't have new trips)
* unreasonably stupid and probably unnecessary codestuebinm2022-12-031-5/+12
| | | | (but maybe google will like it)
* set uncertainty in gtfs-rtstuebinm2022-12-031-2/+2
|
* this is almost certainly bullshitstuebinm2022-12-031-6/+6
|
* let's try something else as wellstuebinm2022-12-031-1/+2
|
* another gtfs rt thingie?stuebinm2022-12-031-1/+2
|
* fix google warningstuebinm2022-12-031-1/+1
|
* controlroom: show tripShortName instead of tripIdstuebinm2022-11-291-8/+15
| | | | | since the ids really should be internal to the gtfs, and not needed in "normal" contexts.
* fix gtfs tripupdatesstuebinm2022-10-161-83/+92
|
* simple prometheus metricsstuebinm2022-10-161-1/+8
|
* remove some extrapolation bugsstuebinm2022-09-142-6/+6
|
* gtfs realtime: add tripUpdate feedstuebinm2022-09-103-18/+96
|
* init onboard-unitstuebinm2022-09-031-0/+21
|
* reasonable delay forecastsstuebinm2022-09-021-10/+20
|
* guess at future delays (horrible, incorrect, and unfinished)stuebinm2022-08-311-1/+15
|
* some config thingyesodstuebinm2022-08-281-2/+2
| | | | | works kinda well, but doesn't complain about unknown config values in json, which is kinda hmpf tbh
* this does way too much tbh (also functioning delays)stuebinm2022-08-281-0/+2
| | | | most of it deals with timezones, and all the weird implications that has
* controlroom: lots of pretty little knobsstuebinm2022-08-273-32/+85
| | | | (also some database schema changes, for good measure)
* controlroom: some stylingstuebinm2022-08-261-37/+84
|
* ControlRoom: default layoutstuebinm2022-08-141-18/+30
|
* control room: translations & form inputstuebinm2022-08-142-196/+157
| | | | still basic, but works pretty well overall
* controlroom: replace servant/lucid with yesodstuebinm2022-08-141-149/+205
| | | | aka use something meant for webapps to write the webapp
* a little more control room workstuebinm2022-07-201-7/+31
|
* some work on the control roomstuebinm2022-07-172-31/+79
| | | | (it can do useful stuff! but it also still breaks on some things!)
* somewhat functioning control roomstuebinm2022-07-112-22/+91
| | | | | | tbh i've kinda lost track at what has all been changed in this, but the control room form handling now works, and i can write announcements into the database. Now on to making it do useful things!
* generic html forms for ADTsstuebinm2022-07-071-88/+17
| | | | this does some GHC generics witchery, now in its own module!
* don't have the ControlRoom API in Swaggerstuebinm2022-07-071-6/+0
| | | | | | just causes pain and isn't really useful for anything since it's a webform API meant to be used by the web frontend, not by other applications.
* wrote some generic html form codestuebinm2022-07-061-12/+97
| | | | | this automatically derives lucid html versions of ADTs which are hopefully compatible with the FormUrlEncoded type class