mirror of
https://github.com/13hannes11/ics-proxy.git
synced 2024-09-06 08:01:41 +02:00
adding docker and docker compose files to make app ready for deployment
This commit is contained in:
1
.dockerignore
Normal file
1
.dockerignore
Normal file
@@ -0,0 +1 @@
|
||||
target
|
||||
7
.env
7
.env
@@ -1,3 +1,8 @@
|
||||
DATABASE_URL=sqlite://db/db.db
|
||||
|
||||
# PROTOCOL and BASE_URL are used to build links in application
|
||||
PROTOCOL=http
|
||||
BASE_URL=localhost:8080
|
||||
BASE_URL=localhost:8080
|
||||
|
||||
# HOST tells the app which address to bind to (do not change for docker) default is 0.0.0.0:8080
|
||||
# HOST=localhost:8080
|
||||
|
||||
14
Dockerfile
Normal file
14
Dockerfile
Normal file
@@ -0,0 +1,14 @@
|
||||
FROM rust:1.54 as builder
|
||||
RUN apt-get update && apt-get install -y sqlite3 && rm -rf /var/lib/apt/lists/*
|
||||
WORKDIR /usr/src/ics-proxy
|
||||
COPY . .
|
||||
RUN cd db && ./create_db.sh
|
||||
RUN cargo install --path .
|
||||
|
||||
FROM debian:buster-slim
|
||||
RUN apt-get update && apt-get install -y sqlite3 openssl && rm -rf /var/lib/apt/lists/*
|
||||
WORKDIR app
|
||||
COPY --from=builder /usr/local/cargo/bin/ics-proxy ./ics-proxy
|
||||
COPY --from=builder /usr/src/ics-proxy/db db
|
||||
COPY templates ./templates
|
||||
CMD ["./ics-proxy"]
|
||||
12
docker-compose.yml
Normal file
12
docker-compose.yml
Normal file
@@ -0,0 +1,12 @@
|
||||
version: '3'
|
||||
services:
|
||||
ics-proxy:
|
||||
container_name: ics-proxy
|
||||
build: .
|
||||
env_file: .env
|
||||
ports:
|
||||
- "8080:8080"
|
||||
volumes:
|
||||
- database:/app/db
|
||||
volumes:
|
||||
database:
|
||||
17
src/main.rs
17
src/main.rs
@@ -9,7 +9,6 @@ use uuid::Uuid;
|
||||
|
||||
extern crate dotenv;
|
||||
use dotenv::dotenv;
|
||||
use std::env;
|
||||
|
||||
mod model;
|
||||
use model::Link;
|
||||
@@ -279,6 +278,11 @@ async fn main() -> std::io::Result<()> {
|
||||
let base_url =
|
||||
std::env::var("BASE_URL").expect("BASE_URL environemt variable error, make sure it is set");
|
||||
|
||||
let host = match std::env::var("HOST") {
|
||||
Ok(host) => host,
|
||||
Err(_e) => "0.0.0.0:8080".to_string(),
|
||||
};
|
||||
|
||||
let conf = Config {
|
||||
root: format!("{}://{}", protocol, base_url),
|
||||
};
|
||||
@@ -287,9 +291,12 @@ async fn main() -> std::io::Result<()> {
|
||||
.await
|
||||
.expect("could not create db pool");
|
||||
|
||||
println!("Listening on: 127.0.0.1:8080, open browser and visit have a try!");
|
||||
println!(
|
||||
"Listening on: {}://{}, open browser and visit have a try!",
|
||||
protocol, base_url
|
||||
);
|
||||
HttpServer::new(move || {
|
||||
let tera = Tera::new(concat!(env!("CARGO_MANIFEST_DIR"), "/templates/**/*")).unwrap();
|
||||
let tera = Tera::new("templates/**/*.html").unwrap();
|
||||
|
||||
App::new()
|
||||
.data(db_pool.clone()) // pass database pool to application so we can access it inside handlers
|
||||
@@ -301,9 +308,7 @@ async fn main() -> std::io::Result<()> {
|
||||
.service(web::resource("/index_process").route(web::get().to(index_process)))
|
||||
.service(web::resource("/edit_process").route(web::get().to(edit_process)))
|
||||
})
|
||||
.bind("127.0.0.1:8080")?
|
||||
.bind(host)?
|
||||
.run()
|
||||
.await
|
||||
|
||||
//.route("/{id}/events.ics", web::get().to(make_ics_request))
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user