chore: add Dockerfile
							parent
							
								
									adef5c1fd5
								
							
						
					
					
						commit
						03b3f692e1
					
				|  | @ -0,0 +1,5 @@ | ||||||
|  | * | ||||||
|  | 
 | ||||||
|  | !Cargo.toml | ||||||
|  | !Cargo.lock | ||||||
|  | !src/** | ||||||
|  | @ -703,6 +703,7 @@ version = "0.30.1" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "2e99fb7a497b1e3339bc746195567ed8d3e24945ecd636e3619d20b9de9e9149" | checksum = "2e99fb7a497b1e3339bc746195567ed8d3e24945ecd636e3619d20b9de9e9149" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  |  "cc", | ||||||
|  "pkg-config", |  "pkg-config", | ||||||
|  "vcpkg", |  "vcpkg", | ||||||
| ] | ] | ||||||
|  |  | ||||||
|  | @ -3,6 +3,10 @@ name = "calathea" | ||||||
| version = "0.1.0" | version = "0.1.0" | ||||||
| edition = "2021" | edition = "2021" | ||||||
| 
 | 
 | ||||||
|  | [[bin]] | ||||||
|  | path = "src/main.rs" | ||||||
|  | name = "calathea" | ||||||
|  | 
 | ||||||
| [dependencies] | [dependencies] | ||||||
| axum = { version = "0.7.9", features = ["macros"] } | axum = { version = "0.7.9", features = ["macros"] } | ||||||
| chrono = { version = "0.4.39", features = ["serde"] } | chrono = { version = "0.4.39", features = ["serde"] } | ||||||
|  | @ -10,7 +14,7 @@ r2d2 = "0.8.10" | ||||||
| r2d2_sqlite = "0.25.0" | r2d2_sqlite = "0.25.0" | ||||||
| # this dependency is needed soly because the r2d2_sqlite crate doesn't export | # this dependency is needed soly because the r2d2_sqlite crate doesn't export | ||||||
| # the 'chrono' feature flag | # the 'chrono' feature flag | ||||||
| rusqlite = { version = "0.32.1", features = ["chrono"] } | rusqlite = { version = "0.32.1", features = ["chrono", "bundled"] } | ||||||
| serde = { version = "1.0.217", features = ["derive"] } | serde = { version = "1.0.217", features = ["derive"] } | ||||||
| tera = "1.20.0" | tera = "1.20.0" | ||||||
| tokio = { version = "1.42.0", features = ["full"] } | tokio = { version = "1.42.0", features = ["full"] } | ||||||
|  |  | ||||||
|  | @ -0,0 +1,43 @@ | ||||||
|  | FROM rust:1.83-alpine3.21 AS builder | ||||||
|  | 
 | ||||||
|  | ARG DI_VER=1.2.5 | ||||||
|  | 
 | ||||||
|  | WORKDIR /app | ||||||
|  | 
 | ||||||
|  | RUN apk update && apk add --no-cache build-base | ||||||
|  | 
 | ||||||
|  | # Build dumb-init | ||||||
|  | RUN wget -O - "https://github.com/Yelp/dumb-init/archive/refs/tags/v${DI_VER}.tar.gz" | tar -xzf - && \ | ||||||
|  |     cd "dumb-init-${DI_VER}" && \ | ||||||
|  |     make SHELL=/bin/sh && \ | ||||||
|  |     mv dumb-init .. && \ | ||||||
|  |     cd .. | ||||||
|  | 
 | ||||||
|  | COPY Cargo.toml Cargo.lock ./ | ||||||
|  | 
 | ||||||
|  | RUN cargo fetch --locked | ||||||
|  | 
 | ||||||
|  | COPY . ./ | ||||||
|  | 
 | ||||||
|  | RUN cargo build --release --frozen | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | FROM alpine:3.21 | ||||||
|  | 
 | ||||||
|  | COPY --from=builder /app/target/release/calathea /bin/calathea | ||||||
|  | COPY --from=builder /app/dumb-init /bin/dumb-init | ||||||
|  | 
 | ||||||
|  | # Create a non-root user & make sure it can write to the data directory | ||||||
|  | RUN set -x && \ | ||||||
|  | 	adduser -u 82 -D -S -G www-data www-data && \ | ||||||
|  |     mkdir /data && \ | ||||||
|  |     chown -R www-data:www-data /data | ||||||
|  | 
 | ||||||
|  | WORKDIR /data | ||||||
|  | 
 | ||||||
|  | USER www-data:www-data | ||||||
|  | 
 | ||||||
|  | ENTRYPOINT [ "/bin/dumb-init", "--" ] | ||||||
|  | CMD [ "/bin/calathea" ] | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
		Loading…
	
		Reference in New Issue