Code for "Zero To Production In Rust", a book on API development using Rust.
Find a file
2022-09-23 11:53:54 +01:00
.cargo Add linker configuration 2022-03-11 22:45:22 +00:00
.github/workflows Update CI and README. 2022-03-14 11:15:41 +00:00
configuration Last part of chapter 10 - sessions, seed users and change password form 2022-03-12 19:05:53 +00:00
migrations Chapter 11: fault tolerant workflows. 2022-03-13 19:41:50 +00:00
scripts Update all dependencies 2022-07-05 18:48:09 +01:00
src Update all dependencies 2022-07-05 18:48:09 +01:00
tests/api Update all dependencies 2022-07-05 18:48:09 +01:00
.dockerignore Refactor structure to use one root branch per chapter. 2020-12-05 17:19:11 +00:00
.env Refactor structure to use one root branch per chapter. 2020-12-05 17:19:11 +00:00
.gitignore Scaffolding 2020-08-23 11:34:29 +01:00
Cargo.lock Update all dependencies 2022-07-05 18:48:09 +01:00
Cargo.toml Update all dependencies 2022-07-05 18:48:09 +01:00
Dockerfile Install ca-certificates in the runtime layer 2022-03-14 11:44:01 +00:00
LICENSE-APACHE Add licensing information. 2021-06-06 14:11:19 +01:00
LICENSE-MIT Add licensing information. 2021-06-06 14:11:19 +01:00
README.md Update README.md 2022-09-23 11:53:54 +01:00
spec.yaml Fix environment variable for application URL on DO. 2021-07-14 09:32:16 +01:00
sqlx-data.json Fix CI. 2022-03-13 19:47:04 +00:00

Zero To Production In Rust

Zero To Production In Rust is an opinionated introduction to backend development using Rust.

This repository serves as supplementary material for the book: it hosts several snapshots of the codebase for our email newsletter project as it evolves throughout the book.

Chapter snapshots

The main branch shows the project at the end of the book.

You can browse the project at the end of previous chapters by switching to their dedicated branches:

Pre-requisites

You'll need to install:

There are also some OS-specific requirements.

Windows

cargo install -f cargo-binutils
rustup component add llvm-tools-preview
cargo install --version=0.6.0 sqlx-cli --no-default-features --features rustls,postgres

Linux

# Ubuntu 
sudo apt-get install lld clang libssl-dev postgresql-client
# Arch 
sudo pacman -S lld clang postgresql
cargo install --version=0.6.0 sqlx-cli --no-default-features --features rustls,postgres

MacOS

brew install michaeleisel/zld/zld
cargo install --version=0.6.0 sqlx-cli --no-default-features --features rustls,postgres

How to build

Launch a (migrated) Postgres database via Docker:

./scripts/init_db.sh

Launch a Redis instance via Docker:

./scripts/init_redis.sh

Launch cargo:

cargo build

You can now try with opening a browser on http://127.0.0.1:8000/login after having launch the web server with cargo run.

There is a default admin account with password everythinghastostartsomewhere. The available entrypoints are listed in src/startup.rs

How to test

Launch a (migrated) Postgres database via Docker:

./scripts/init_db.sh

Launch a Redis instance via Docker:

./scripts/init_redis.sh

Launch cargo:

cargo test