This is the main website for OpenTTD, as can be seen on https://www.openttd.org/. 'master' is always deployed on staging.
This is a Jekyll website, and is served by nginx as a static site.
By default _downloads
is empty, so when building the website locally there is no latest stable/nightly.
This can be resolved by running fetch_downloads
.
This script will download the latest available binaries, and populate _downloads
.
python3 -m venv .env
.env/bin/pip install -r requirements.txt
.env/bin/python -m fetch_downloads
If you do not want to run a server, but just build the current site, replace serve
with build
in the examples below.
Under _site
Jekyll will put the compiled result in both serve
and build
.
- Follow jekyll installation
- Run
bundle install
- Run
JEKYLL_ENV=production jekyll serve
docker run --rm -v "$(pwd)":/srv/jekyll -it -p 127.0.0.1:4000:4000 -e JEKYLL_ENV=production jekyll/jekyll jekyll serve
This repository in the end produces a Docker image which is started in production. The Dockerfile is a multistage Dockerfile to get to this result.
- Fetch the downloads.
- Create the HTML website via Jekyll.
- Prepare nginx with static files.
The result is a very small image (~50 MiB) with only static HTML sites.
After merging into master
, Azure Pipelines automatically publishes a new image on Docker Hub, and automatically deploys it on staging.
To test locally if the Docker will build, you can use:
docker build --no-cache --pull -t website:test .
Create a new file in _posts. Follow the existing format. Make a Pull Request, have it approved, and merge. It will automatically show up on staging. After tagging, it will move to production.
No problem. Add yourself to _people, and follow the same as the above 'new blog post' section.
Please set JEKYLL_ENV
to production
.
Without this, the symlink ua-parser.js
is copied, instead of following it.
With production
it does the right thing.
To recover, remove _site/static/js/ua-parser.js
manually.
On download pages, you notice that every binary has a human readable description.
windows-win64.exe
is for most people to cryptic.
Windows XP / Vista / 7 / 8 / 10 (64bit) (installer)
is much more clear.
This file takes care of that mapping, based on the postfix of the file.
Because this is a static website, but we do want to show in the header what the latest version is, we need to find a solution. We picked a solution where we fetch some files to know what the latest version is, and create a static version out of it. This means that every time the latest version changes, the website has to be recreated. As new versions are rare (once or sometimes twice a day at most), it is very cheaper to do it this way. It avoids any dynamic component in production.
We used to have a very dynamic website, with tons of URLs. Because many people have them bookmarked or made automation around them, we set out to not have any regression during migration. In result, many URLs are being redirected to their new URL, and we should have not a single regression.
Yes. By lack of better, we are doing this.