Ruby 3.3.5
Rails 7.2.2.1
Found a bug? Please open an Issue.
Have a feature request? Let's discuss it on Slack.
If you want to help me fix a bug or implement a new requested feature:
- Make sure an Issue exists for it
- Ask me questions
- Fork the project
- Code the changes on your fork
- Create a Pull Request here from your fork
Upon Pull Request actions (open, push), CI scripts are automatically run tests, linters and security tools. All the checks shall pass for your PR to be reviewed.
- Run
bin/setup
to install dependencies, create and seed the database - Ask me for the credentials key on Slack and add it to
config/master.key
(required for Kitt OAuth) - Create a
.env
root file and add these keys with their appropriate values:AOC_ROOMS
,SESSION_COOKIE
- Run
bin/dev
Caution
The .env
file is used for development purposes only. It is not versioned and never should.
POSTGRES_USER
andPOSTGRES_PASSWORD
should be set accordingly to your db config. If you're using the Docker dev env you can omit those.AOC_ROOMS
is a comma-separated list of private leaderboard IDs that you belong to (e.g.9999999-a0b1c2d3,7777777-e4f56789
)SESSION_COOKIE
is your own Advent of Code session cookie (valid ~ 1 month). You need to log in to the platform, then retrieve the value of thesession
cookie (e.g.436088a9...9ffb6476
)
You can also run the app in a Docker container. A docker-compose.yml
file is provided for this purpose. The ENV variables are still required and should be added to the .env
file.
A small CLI is provided for common use-cases: bin/ddev
(see usage for more details).
Note
Foreman is the default process manager through the bin/dev
command. Overmind is an optional alternative.
Overmind is a process manager for Procfile-based applications like ours, based on tmux
. You can install the tool on your machine following these instructions.
Add these lines to your local .env
file:
OVERMIND_PORT=3000
OVERMIND_PROCFILE=Procfile.dev
Then, instead of the usual bin/dev
, you have to run overmind s
.
In short: create an SSL certificate for your localhost, store it in your keychain and run the server using that certificate.
On macOS:
mkcert localhost
sudo security add-trusted-cert -d -r trustRoot -k /Library/Keychains/System.keychain ./localhost.pem
On Ubuntu:
sudo apt install openssl
openssl req -x509 -newkey rsa:2048 -nodes -keyout localhost-key.pem -out localhost.pem -days 365 -subj "/C=FR/ST=State/L=Locality/O=Organization/CN=localhost"
Finally, move the generated files to the tmp
folder in the project root and start the server with bin/dev ssl
.
mv localhost* tmp/
bin/dev ssl
Because the OAuth will not work on your local IP, you have to bypass authentication. For example, you could temporarily add this line in the welcome
controller method:
sign_in(User.find_by(github_username: "your_username"))
Then, find the local IP address of the computer you launch the server from (ex: 192.168.1.14
) and open the app on your mobile browser from that IP (ex: http://192.168.1.14:3000
)
Caution
Bypassing authentication, even temporarily, can pose significant security risks. Only use this method in a controlled development environment and never in production.
On adventofcode.com
, a user can create one (and only one) private leaderboard. Up to 200 users can join it using a unique generated code.
A JSON object containing scores can be fetched from a GET
request that needs a session cookie to succeed. We store this session cookie in the SESSION_COOKIE
environment variable (valid ~ 1 month).
We use multiple private leaderboards to run the platform with more than 200 participants. We store their IDs in the AOC_ROOMS
environment variable, comma-separated. One account joins all of them, and we use this account's SESSION_COOKIE
.