This compilation is gonna kill me

develop
Jef Roosens 2021-09-05 11:19:18 +02:00
parent a295237863
commit 3d024db2e9
Signed by untrusted user: Jef Roosens
GPG Key ID: B580B976584B5F30
7 changed files with 135 additions and 40 deletions

View File

@ -1,11 +1,19 @@
FROM rust:1.54 FROM rust:1.54
ENV PREFIX="/usr/src/out/prefix" \
CC="musl-gcc -fPIC -pie -static" \
LD_LIBRARY_PATH="$PREFIX" \
PKG_CONFIG_PATH="/usr/local/lib/pkgconfig" \
PATH="/usr/local/bin:/root/.cargo/bin:$PATH"
RUN apt update && \ RUN apt update && \
apt install -y --no-install-recommends \ apt install -y --no-install-recommends \
musl-dev \ musl-dev \
musl-tools \ musl-tools \
libpq-dev \ libpq-dev \
libssl-dev && \ libssl-dev && \
rustup target add x86_64-unknown-linux-musl rustup target add x86_64-unknown-linux-musl && \
mkdir "$PREFIX" && \
echo "$PREFIX/lib" >> /etc/ld-musl-x86_64.path
WORKDIR /usr/src/app WORKDIR /usr/src/app

View File

@ -22,9 +22,9 @@ CORES != nproc
# =====ENVIRONMENT VARIABLES===== # =====ENVIRONMENT VARIABLES=====
export CC=musl-gcc -fPIC -pie -static export CC := musl-gcc -fPIC -pie -static
export LD_LIBRARY_PATH=$(PREFIX) export LD_LIBRARY_PATH := $(PREFIX)
export PKG_CONFIG_PATH=/usr/local/lib/pkgconfig export PKG_CONFIG_PATH := /usr/local/lib/pkgconfig
export PATH := /usr/local/bin:/root/.cargo/bin:$(PATH) export PATH := /usr/local/bin:/root/.cargo/bin:$(PATH)
@ -34,18 +34,23 @@ export PATH := /usr/local/bin:/root/.cargo/bin:$(PATH)
$(shell mkdir -p "$(PREFIX)") $(shell mkdir -p "$(PREFIX)")
# ====RECIPES==== # =====BUILDING THE STATIC BINARY=====
.PHONY: all .PHONY: all
all: build all: build
.PHONY: builder
builder:
docker build \
-t rusty-builder:latest - < docker/Dockerfile.builder
.PHONY: docker .PHONY: docker
docker: docker: builder
docker run \ docker run \
--rm \ --rm \
-v "$$PWD:/usr/src" \ -v "$$PWD:/usr/src" \
--workdir "/usr/src" \ --workdir "/usr/src" \
-it \ -it \
rust:1.54 \ rusty-builder:latest \
bash build.sh bash build.sh
@ -54,10 +59,9 @@ docker:
build: libpq build: libpq
.PHONY: clean .PHONY: clean
clean: clean: clean-openssl clean-libpq clean-di
echo "$$PATH"
@ echo "Note: this only cleans the C dependencies, not the Cargo cache." @ echo "Note: this only cleans the C dependencies, not the Cargo cache."
rm -rf "$(PQ_DIR)" "$(OPENSSL_DIR)" "$(DI_DIR)" "$(PREFIX)" rm -rf "$(PREFIX)"
# This is used inside the Dockerfile # This is used inside the Dockerfile
.PHONY: pathfile .PHONY: pathfile
@ -65,13 +69,13 @@ pathfile:
echo "$(PREFIX)/lib" >> /etc/ld-musl-x86_64.path echo "$(PREFIX)/lib" >> /etc/ld-musl-x86_64.path
# =====OPENSSL===== ## =====OPENSSL=====
# Download the source code & configure the project # Download the source code & configure the project
$(OPENSSL_DIR)/Configure: $(OPENSSL_DIR)/Configure:
curl -sSL "https://www.openssl.org/source/openssl-$(SSL_VER).tar.gz" | \ curl -sSL "https://www.openssl.org/source/openssl-$(SSL_VER).tar.gz" | \
tar -C "$(OUT_DIR)" -xz tar -xzC "$(OUT_DIR)"
cd "$(OPENSSL_DIR)" && \ cd "$(OPENSSL_DIR)" && \
CC="$$CC -idirafter /usr/include -idirafter /usr/include/x86_64-linux-gnu/" ./Configure \ CC="$(CC) -idirafter /usr/include -idirafter /usr/include/x86_64-linux-gnu/" ./Configure \
no-zlib \ no-zlib \
no-shared \ no-shared \
--prefix="$(PREFIX)" \ --prefix="$(PREFIX)" \
@ -81,16 +85,20 @@ $(OPENSSL_DIR)/Configure:
# Build OpenSSL # Build OpenSSL
.PHONY: openssl .PHONY: openssl
openssl: $(OPENSSL_DIR)/Configure openssl: $(OPENSSL_DIR)/Configure
env C_INCLUDE_PATH="$(PREFIX)/include" $(MAKE) -C "$(OPENSSL_DIR)" depend cd "$(OPENSSL_DIR)" && env C_INCLUDE_PATH="$(PREFIX)/include" $(MAKE) depend 2> /dev/null
$(MAKE) -C "$(OPENSSL_DIR)" -j$(CORES) cd "$(OPENSSL_DIR)" && $(MAKE) -j$(CORES)
$(MAKE) -C "$(OPENSSL_DIR)" install_sw cd "$(OPENSSL_DIR)" && $(MAKE) install_sw
.PHONY: clean-openssl
clean-openssl:
rm -rf "$(OPENSSL_DIR)"
# =====LIBPQ===== ## =====LIBPQ=====
# Download the source code & configure the project # Download the source code & configure the project
$(PQ_DIR)/configure: $(PQ_DIR)/configure:
curl -sSL "https://ftp.postgresql.org/pub/source/v$(PQ_VER)/postgresql-$(PQ_VER).tar.gz" | \ curl -sSL "https://ftp.postgresql.org/pub/source/v$(PQ_VER)/postgresql-$(PQ_VER).tar.gz" | \
tar -C "$(OUT_DIR)" -xz tar -xzC "$(OUT_DIR)"
cd "$(PQ_DIR)" && \ cd "$(PQ_DIR)" && \
LDFLAGS="-L$(PREFIX)/lib" CFLAGS="-I$(PREFIX)/include" ./configure \ LDFLAGS="-L$(PREFIX)/lib" CFLAGS="-I$(PREFIX)/include" ./configure \
--without-readline \ --without-readline \
@ -101,10 +109,14 @@ $(PQ_DIR)/configure:
.PHONY: libpq .PHONY: libpq
libpq: openssl $(PQ_DIR)/configure libpq: openssl $(PQ_DIR)/configure
make -C "$(PQ_DIR)/src/interfaces/libpq" -j$(CORES) all-static-lib cd "$(PQ_DIR)/src/interfaces/libpq" && $(MAKE) -j$(CORES) all-static-lib
make -C "$(PQ_DIR)/src/interfaces/libpq" install install-lib-static cd "$(PQ_DIR)/src/interfaces/libpq" && $(MAKE) install install-lib-static
make -C "$(PQ_DIR)/src/bin/pg_config" -j $(CORES) cd "$(PQ_DIR)/src/bin/pg_config" && $(MAKE) -j$(CORES)
make -C "$(PQ_DIR)/src/bin/pg_config" install cd "$(PQ_DIR)/src/bin/pg_config" && $(MAKE) install
.PHONY: clean-libpq
clean-libpq:
rm -rf "$(PQ_DIR)"
# =====DUMB-INIT===== # =====DUMB-INIT=====
@ -113,6 +125,16 @@ $(DI_DIR)/Makefile:
curl -sSL "https://github.com/Yelp/dumb-init/archive/refs/tags/v$(DI_VER).tar.gz" | \ curl -sSL "https://github.com/Yelp/dumb-init/archive/refs/tags/v$(DI_VER).tar.gz" | \
tar -C "$(OUT_DIR)" -xz tar -C "$(OUT_DIR)" -xz
.PHONY: dumb-init .PHONY: di
dumb-init: $(DI_DIR)/Makefile di: $(DI_DIR)/Makefile
make -C "$(DI_DIR)" build make -C "$(DI_DIR)" build
.PHONY: clean-di
clean-di:
rm -rf "$(DI_DIR)"
# ====UTILITIES FOR DEVELOPMENT=====
## The tests require a database, so we run them like this
test:
docker-compose -f docker-compose.test.yml -p rb_test up

12
Rb.yaml
View File

@ -21,3 +21,15 @@ debug:
databases: databases:
postgres_rb: postgres_rb:
url: "postgres://rb:rb@localhost:5432/rb" url: "postgres://rb:rb@localhost:5432/rb"
release:
admin_user: "admin"
admin_pass: "password"
jwt:
key: "secret"
refresh_token_size: 64
refresh_token_expire: 86400
databases:
postgres_rb:
url: "postgres://rb:rb@db:5432/rb"

View File

@ -3,13 +3,12 @@
set -e set -e
# Install build dependencies # Install build dependencies
apt update # apt update
apt install \ # apt install \
-y --no-install-recommends \ # -y --no-install-recommends \
musl-dev \ # musl-dev \
musl-tools \ # musl-tools \
libssl-dev \ # libssl-dev \
libpq-dev # libpq-dev
make pathfile
make make

View File

@ -0,0 +1,27 @@
version: '3'
services:
app:
build:
context: '.'
dockerfile: 'docker/test/Dockerfile'
image: 'rb-builder:1.54'
command: "${CMD}"
working_dir: "/usr/src/app"
volumes:
- '$PWD:/usr/src/app'
- 'cache:/usr/src/app/out'
db:
image: 'postgres:13-alpine'
environment:
- 'POSTGRES_DB=rb'
- 'POSTGRES_USER=rb'
- 'POSTGRES_PASSWORD=rb'
volumes:
cache:

View File

@ -0,0 +1,28 @@
# vim: ft=dockerfile
FROM rust:1.54
ENV PREFIX="/usr/src/out/prefix" \
CC="musl-gcc -fPIC -pie -static" \
LD_LIBRARY_PATH="$PREFIX" \
PKG_CONFIG_PATH="/usr/local/lib/pkgconfig" \
PATH="/usr/local/bin:/root/.cargo/bin:$PATH"
WORKDIR /usr/src/app
RUN groupadd -g 1000 builder && \
useradd -u 1000 -g 1000 builder && \
mkdir -p "$PREFIX" && \
chown -R builder:builder /usr/src/app && \
apt update && \
apt install -y --no-install-recommends \
musl-dev \
musl-tools \
libpq-dev \
libssl-dev && \
rustup target add x86_64-unknown-linux-musl && \
echo "$PREFIX/lib" >> /etc/ld-musl-x86_64.path
USER builder
CMD ["cargo", "test"]

View File

@ -16,7 +16,7 @@ use rocket::{
fairing::AdHoc, fairing::AdHoc,
http::Status, http::Status,
serde::json::{json, Value}, serde::json::{json, Value},
Build, Request, Rocket, Build, Request, Rocket, Orbit,
}; };
use rocket_sync_db_pools::database; use rocket_sync_db_pools::database;
use serde::{Deserialize, Serialize}; use serde::{Deserialize, Serialize};
@ -54,21 +54,20 @@ async fn run_db_migrations(rocket: Rocket<Build>) -> Result<Rocket<Build>, Rocke
.await .await
} }
async fn create_admin_user(rocket: Rocket<Build>) -> Result<Rocket<Build>, Rocket<Build>> async fn create_admin_user<'a>(rocket: &'a Rocket<Orbit>)
{ {
let admin_user = std::env::var("ADMIN_USER").unwrap_or(String::from("admin")); let config = rocket.state::<RbConfig>().expect("RbConfig instance");
let admin_password = std::env::var("ADMIN_PASSWORD").unwrap_or(String::from("password")); let admin_user = config.admin_user.clone();
let admin_pass = config.admin_pass.clone();
let conn = RbDbConn::get_one(&rocket) let conn = RbDbConn::get_one(&rocket)
.await .await
.expect("database connection"); .expect("database connection");
conn.run(move |c| { conn.run(move |c| {
admin::create_admin_user(c, &admin_user, &admin_password) admin::create_admin_user(c, &admin_user, &admin_pass)
.expect("failed to create admin user") .expect("failed to create admin user")
}) })
.await; .await;
Ok(rocket)
} }
#[derive(Debug, Deserialize, Serialize, Clone)] #[derive(Debug, Deserialize, Serialize, Clone)]
@ -100,7 +99,7 @@ fn rocket() -> _
"Run database migrations", "Run database migrations",
run_db_migrations, run_db_migrations,
)) ))
.attach(AdHoc::try_on_ignite("Create admin user", create_admin_user)) // .attach(AdHoc::try_on_ignite("Create admin user", create_admin_user))
.attach(AdHoc::config::<RbConfig>()) .attach(AdHoc::config::<RbConfig>())
.register("/", catchers![default_catcher]) .register("/", catchers![default_catcher])
.mount( .mount(