Skip to content

jclgoodwin/bustimes.org

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Test Coverage badge

What's this?

Source code for the website bustimes.org. (The "the" is important – running your own "instance" is not recommended or supported.)

It's a magnificent monolithic Django app that's evolved over time (since 2015). The structure doesn't make complete sense:

app concern
accounts user accounts
api the Django Rest Framework–powered API
buses contains the site settings.py
busstops bus stops - but also operating companies, places, and routes 🤯 and the site's static file assets
bustimes getting timetable data out of various formats (GTFS, TransXChange, ATCO-CIF) and into a database and doing stuff therewith
config Kamal and Supervisor configuration
departures listing the "next departures" at a bus stop – from a timetable and/or predicted by an API
disruptions information about like roadworks, diversions and stuff
fares fares
fixtures some YAML files containing overrides/corrections to the operator (NOC) and bus stop (NaPTAN) datasets. Also recorded HTTP responses used in tests
frontend TypeScript and Sass bits
transxchange code for parsing TransXChange XML files. Could be published as a separate package
vehicles tracking buses' locations and showing them on a map, and pointless details about vehicles' colours and features
vosa the Great Britain Traffic Commissioners' bus service registration data. VOSA is the name of a defunct UK government agency.

I try to document things for "future me", but invariably this documentation will be incomplete and out of date in parts.

License note

Some of the test data in this repository is public sector information licensed under the Open Government Licence v3.0.

This repository also contains some font files which are copyrighted and not covered by the main licence.

Installing

Using Docker

I don't know. These days, I only use Docker for running the production site (see below).

Using local install

These need to be available:

  • Python 3.12+
  • uv to install necessary Python packages (Django, etc)
  • PostgreSQL with PostGIS
  • npm to install some front end JavaScript things
  • Redis 6.2+
  • GDAL

Useful commands that you might need to run from time to time:

npm install  # install JavaScript dependencies
npm run build  # build the front-end CSS and JavaScript
npm run watch  # build the front-end CSS and JavaScript in development mode, and "watch" and rebuild when the source changes
uv sync --group dev --group test  # install Python dependencies including special ones for development and testing
uv run ./manage.py collectstatic
uv run ./manage.py migrate  # create database tables
uv run ./manage.py runserver 0.0.0.0:8000  # run the Django development server (not suitable for production, use gunicorn for that!)

Some environment variables need to be set. Many of them control settings in buses/settings.py.

DEBUG=1
SECRET_KEY=something
DATABASE_URL=postgis://user:password@host/database-name

.github/workflows/test.yml sort of documents the process of installing dependencies and running tests.

Importing data

Static data (stops, timetables, etc)

import.sh will download some data from various sources and run the necessary Django management commands to import it, in a sensible order (place names, then stops, then timetables). When run repeatedly, it will only download and import the stuff that's changed. It needs a username and password for the Traveline National Dataset step.

But then there are further management commands for getting further data from further places like the Bus Open Data Service.

Live data

Some "live" data – departure times at stops, and vehicle locations – is/are fetched as and when a user accesses a page.

For the rest, there are some Django management commands that need to be run indefinitely in the background. These update the big map of bus locations, etc. I use supervisord (see config/supervisor.conf).

Deploying

Uses Kamal (see config/deploy.yml)

About

Every bus stop, route and timetable, using (Geo)Django and things

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors 14