Commit graph

12 commits

Author SHA1 Message Date
Yvan Janssens
3b3b858f4e Update README.md to document logging config. 2024-09-24 13:56:36 +02:00
Thomas Vogt
a877ff2d4b
Systemd service file (#22)
* Add example systemd service file

* Mention systemd service file in README
2024-09-22 18:43:22 +02:00
Émilien (perso)
cfe85d34bb
improve warning about untrusted code + link to official doc for production 2024-08-15 01:54:31 +02:00
Émilien (perso)
bf22ef0462
improve README and add warnings 2024-08-14 13:08:22 +02:00
perennial
4d3cff6a16
Add Docker support and update README (#13)
* add compose.yaml

* add Dockerfile

* update README

* Dockerfile: uncomment CMD instruction

* add .dockerignore

* Dockerfile: use scratch image for second stage

* Dockerfile: use newer OpenSSL version (3.0.9)

* Dockerfile: use Alpine-based Rust image to skip building OpenSSL

* Dockerfile: expose to localhost only by default

* Dockerfile: allow building for different architectures (AMD64 and ARM64)

Dockerfile now detects the architecture being used during the build process and templates in the correct Rust target architecture

* compose.yaml: include command line

* compose.yaml: listen on 127.0.0.1 only

* compose.yaml: remove healthcheck due to using scratch image

* README.md: restore old table format

* rename compose.yaml to docker-compose.yml

* docker-compose.yml: include version line

* update .dockerignore

* README.md: update Docker instructions to expose only on localhost

* add workflow to build and push container images to quay.io

* docker-compose.yml: harden configuration

* docker workflow: add paths-ignore section

* Dockerfile: let Rustup handle architecture detection

More flexible as the build process will now automatically adapt to whatever architecture the container is being built on, without needing to explicitly list out each supported architecture

* Docker: further security hardening

- Run as a non-privileged user within the scratch container
- Add security_opt: - no-new-privileges:true to docker-compose.yml

* Dockerfile: Switch to Debian-based images and simplify build command

- rust:1.80-alpine replaced with rust:1.80 for the builder stage
- alpine:3.20 replaced with debian:12.6-slim for the user-stage
- Build command simplified to use default target architecture

* Cargo.toml: correct note on optimisations

* docker-compose.yml: use quay.io image by default

* rename docker-compose.yml to docker-compose.yaml

* compose: build image from local repo by default

* Revert "Dockerfile: Switch to Debian-based images and simplify build command"

This reverts commit ff9a37856463062f31af2d1aa00a87dc23bedb6c.

Reasons for reverting:
1. Compiling via musl is necessary to statically link dependencies and create a truly standalone Rust binary. [1]
2. Alpine-based Rust images are required for the build stage because such systems support dynamic linking, which is also needed for statically-linked binaries. [2]
3. Determining the target architecture and templating the correct value for the --target flag is necessary for the statically-linked binary to be built correctly. [2]

[1]: https://doc.rust-lang.org/1.13.0/book/advanced-linking.html#linux
[2]: https://github.com/rust-lang/rust/issues/40174#issuecomment-538791091
2024-08-14 12:58:44 +02:00
techmetx11
115c690416
New opcode: PLAYER_UPDATE_TIMESTAMP 2024-07-21 13:37:34 +01:00
techmetx11
f70c60441a
Fix punctuation 2024-06-26 21:58:32 +01:00
techmetx11
9f491c0e7c
Added new opcode: PLAYER_STATUS 2024-06-26 21:57:03 +01:00
techmetx11
32aeb2f2f7
Wrong size for FORCE_UPDATE response in the documentation 2024-06-25 19:04:45 +01:00
techmetx11
9784fdbafe
Added size in response for convenience 2024-06-25 18:59:19 +01:00
techmetx11
5364ea9f9c
Updated documentation 2024-04-30 16:41:40 +01:00
techmetx11
a124a26d36
Improve the program a bit, and include a protocol documentation 2024-04-29 19:14:08 +01:00