Skip to content

Latest commit

 

History

History
58 lines (45 loc) · 1.59 KB

README.md

File metadata and controls

58 lines (45 loc) · 1.59 KB

GTFS Server

A General Transit Feed Specification (GTFS) server to expose some REST APIs.

Requirements

  • Rust (Nightly, preferably)
  • PostgreSQL with GIS (PostGIS)
  • (Docker)

Data Visualization (not required)

  • QGIS

Instructions

Download & Extract a feed

mkdir resources/gtfs/sbb/
wget https://opentransportdata.swiss/en/dataset/timetable-2018-gtfs/permalink -O resources/gtfs/sbb/gtfs.zip
cd resources/gtfs/sbb/
unzip gtfs.zip

Deploy with Docker

PostGIS

docker network create --subnet=172.18.0.0/16 gtfs-server-net
docker run --name gtfs-server-db --net gtfs-server-net --ip 172.18.0.2 -e POSTGRES_PASSWORD=mysecretpassword -d mdillon/postgis

Run the server

cargo run

Check if the data was imported

http://127.0.0.1:8080/api/stops

Data import

feed-id is your feed unique identifier. It will be used across the DB to generate the stop IDs. This will allow us to filter out the feeds that are no longer actives once the DB is populated.

Stops

http://127.0.0.1:8080/api/import/stops/feed-id

Trips

http://127.0.0.1:8080/api/import/stops/feed-id

Endpoints & Objects

Check the Documentation for more info about the endpoints and the objects.

Screenshots

/api/trips/<stop_id>

/api/trips/<stop_id>

/api/stops/

/api/stops/

/api/stops/near/<latitude>/<longitude>/<range>

/api/stops/near/<latitude>/<longitude>/<range>