TCal
A calendar of planned service disruptions on MBTA rapid transit, provided as a web page and an iCal feed. See the live site at: https://tcal.digitalcora.net
Setup
- Install Crystal
- shards install
asdf install may also be used, but is not
recommended, since this doesn't install any of the system-level packages Crystal
depends on.
Development
- Run the server: crystal src/main.cr
- Generate docs: crystal docs(then opendocs/index.html)
- Lint the code: bin/ameba
Production
To build a standalone binary bin/server:
- shards build --production --release --static
The current production instance runs on Fly, using the
fly.toml included in the repo.
Configuration
The server supports these environment variables:
- 
HOST— The network address to listen on. Default value is127.0.0.1, meaning the server will only be accessible from localhost. Use0.0.0.0to listen on all addresses.
- 
PORT— The TCP port to listen on. Default value is8080.
- 
ORIGIN— The canonical origin (scheme + host + optional port) of the site. When a request includes aHostand it is not the canonical origin's host, it will be redirected to the same path at the canonical origin. Default value ishttp://localhostplus the configuredPORT.
- 
LOG_LEVEL— The log level. Default value isinfo. See theLogdocumentation for valid log levels.
- 
SENTRY_DSN— If set, unhandled exceptions will be reported to Sentry.
- 
SENTRY_ENVIRONMENT— The environment string used for Sentry reports, if enabled. Default value isdefault.