Compare commits

..

2 Commits

Author SHA1 Message Date
ec126bbdc4 Formatted project 2025-10-27 08:45:45 +01:00
0fe13b6ce7 Added database to AppState 2025-10-27 08:45:35 +01:00
4 changed files with 55 additions and 6 deletions

View File

@@ -3,3 +3,9 @@
assets="./assets" assets="./assets"
# Set bind address # Set bind address
bind="127.0.0.1:8080" bind="127.0.0.1:8080"
[database]
address="127.0.0.1:5432"
user="web"
password="apassword"
database_name="website"

View File

@@ -163,8 +163,18 @@ impl BasePageBuilder {
.classes(vec!["name"]) .classes(vec!["name"])
.text("AINDUSTRIES") .text("AINDUSTRIES")
.build(); .build();
let home = Anchor::builder().id("home").classes(vec!["nav-button"]).href("/").text("Home").build(); let home = Anchor::builder()
let projects = Anchor::builder().id("projects").classes(vec!["nav-button"]).href("/projects").text("Projects").build(); .id("home")
.classes(vec!["nav-button"])
.href("/")
.text("Home")
.build();
let projects = Anchor::builder()
.id("projects")
.classes(vec!["nav-button"])
.href("/projects")
.text("Projects")
.build();
let buttons = Division::builder() let buttons = Division::builder()
.classes(vec!["nav-buttons"]) .classes(vec!["nav-buttons"])
.elements(boxed_vec![home, projects]) .elements(boxed_vec![home, projects])

View File

@@ -5,6 +5,7 @@ mod pages;
use actix_web::{App, HttpServer, web}; use actix_web::{App, HttpServer, web};
use clap::Parser; use clap::Parser;
use serde::Deserialize; use serde::Deserialize;
use sqlx::PgPool;
use std::fs::File; use std::fs::File;
use std::io::Read; use std::io::Read;
use std::process::exit; use std::process::exit;
@@ -32,6 +33,7 @@ struct Cli {
#[derive(Deserialize)] #[derive(Deserialize)]
struct Config { struct Config {
server: ServerConfig, server: ServerConfig,
database: DatabaseConfig,
} }
#[derive(Deserialize)] #[derive(Deserialize)]
@@ -40,8 +42,17 @@ struct ServerConfig {
bind: String, bind: String,
} }
#[derive(Deserialize)]
struct DatabaseConfig {
address: String,
user: String,
password: String,
database_name: String,
}
struct AppState { struct AppState {
assets: String, assets: String,
pool: PgPool,
} }
#[actix_web::main] #[actix_web::main]
@@ -71,7 +82,22 @@ async fn main() {
}; };
let bind_address = config.server.bind; let bind_address = config.server.bind;
let assets = config.server.assets; let assets = config.server.assets;
let data = web::Data::new(AppState { assets }); let database_address = format!(
"postgres://{}:{}@{}/{}",
config.database.user,
config.database.password,
config.database.address,
config.database.database_name
);
let pool = match PgPool::connect(&database_address).await {
Ok(pool) => pool,
Err(e) => {
eprintln!("Could not connect to database: {e}");
exit(1);
}
};
let assets = assets.replace("~", "/home/conta/Code/aindustries.be/assets");
let data = web::Data::new(AppState { assets, pool });
if let Ok(server) = HttpServer::new(move || { if let Ok(server) = HttpServer::new(move || {
App::new().app_data(data.clone()).service(file).service( App::new().app_data(data.clone()).service(file).service(
web::scope("") web::scope("")

View File

@@ -19,7 +19,11 @@ async fn projects() -> impl Responder {
.classes(vec!["project-desc"]) .classes(vec!["project-desc"])
.text("This project is the website you currently are on.") .text("This project is the website you currently are on.")
.build(); .build();
let view = Anchor::builder().classes(vec!["project-view"]).href("/projects/website").text("Learn More").build(); let view = Anchor::builder()
.classes(vec!["project-view"])
.href("/projects/website")
.text("Learn More")
.build();
let info = Division::builder() let info = Division::builder()
.classes(vec!["project-info"]) .classes(vec!["project-info"])
.elements(boxed_vec![website_desc, view]) .elements(boxed_vec![website_desc, view])
@@ -53,7 +57,10 @@ async fn project(project: web::Path<String>) -> impl Responder {
match project.as_str() { match project.as_str() {
"website" => { "website" => {
let title = Heading::builder().text("Website").build(); let title = Heading::builder().text("Website").build();
let gitea = Anchor::builder().href("https://git.aindustries.be/AINDUSTRIES/aindustries.be").text("aindustries-be").build(); let gitea = Anchor::builder()
.href("https://git.aindustries.be/AINDUSTRIES/aindustries.be")
.text("aindustries-be")
.build();
let desc = Paragraph::builder().classes(vec!["description"]).text( let desc = Paragraph::builder().classes(vec!["description"]).text(
format!("This project, the website you are on, \ format!("This project, the website you are on, \
is made in Rust such that all the pages are generated by code.<br>\ is made in Rust such that all the pages are generated by code.<br>\