3 Commits

Author SHA1 Message Date
56106622b2 Fix Version Number
All checks were successful
Build and Push Image / build-and-push (push) Successful in 7m34s
2025-07-05 21:48:14 -04:00
21c11446d7 Added forward version number to wasm
All checks were successful
Build and Push Image / build-and-push (push) Successful in 6m36s
2025-07-05 21:42:46 -04:00
0093128001 Added forward version number to wasm 2025-07-05 21:42:31 -04:00
9 changed files with 2502 additions and 2462 deletions

View File

@@ -34,4 +34,4 @@ jobs:
context: . context: .
push: true push: true
tags: git.kaisei.app/amatsugu/aoba:${{ env.VERSION }} tags: git.kaisei.app/amatsugu/aoba:${{ env.VERSION }}
build-args: VERSION=${ env.VERSION } build-args: VERSION=${{ env.VERSION }}

1
AobaClient/.env Normal file
View File

@@ -0,0 +1 @@
APP_VERSION=Debug

4923
AobaClient/Cargo.lock generated

File diff suppressed because it is too large Load Diff

View File

@@ -19,6 +19,7 @@ web-sys = { version = "0.3.77", features = ["Storage", "Window"] }
[build-dependencies] [build-dependencies]
tonic-build = { version = "*", default-features = false, features = ["prost"] } tonic-build = { version = "*", default-features = false, features = ["prost"] }
dotenv = "0.15.0"
[features] [features]
default = ["web"] default = ["web"]

View File

@@ -1,3 +1,8 @@
use dotenv::dotenv;
use std::env;
use std::fs::File;
use std::io::Write;
fn main() -> Result<(), Box<dyn std::error::Error>> { fn main() -> Result<(), Box<dyn std::error::Error>> {
tonic_build::configure() tonic_build::configure()
.build_server(false) .build_server(false)
@@ -6,6 +11,26 @@ fn main() -> Result<(), Box<dyn std::error::Error>> {
&["../AobaServer/Proto/Aoba.proto", "../AobaServer/Proto/Auth.proto"], &["../AobaServer/Proto/Aoba.proto", "../AobaServer/Proto/Auth.proto"],
&["../AobaServer/Proto/"], &["../AobaServer/Proto/"],
)?; )?;
forward_env();
Ok(()) Ok(())
} }
fn forward_env() {
let dest_path = "./src/env.rs";
let mut f = File::create(&dest_path).unwrap();
f.write_all(b"// This file is automatically generated by build.rs\n\n")
.unwrap();
dotenv().ok();
for (key, value) in env::vars() {
if key.starts_with("APP_") {
f.write_all("#[allow(dead_code)]\n".as_bytes()).unwrap();
let line = format!(
"pub const {}: &'static str = \"{}\";\n",
key,
value.replace("\"", "\\\"")
);
f.write_all(line.as_bytes()).unwrap();
}
}
}

View File

@@ -2,7 +2,7 @@ use std::env;
use dioxus::prelude::*; use dioxus::prelude::*;
use crate::{Route, contexts::AuthContext}; use crate::{Route, contexts::AuthContext, env::APP_VERSION};
const NAV_CSS: Asset = asset!("/assets/style/nav.scss"); const NAV_CSS: Asset = asset!("/assets/style/nav.scss");
const NAV_ICON: Asset = asset!("/assets/favicon.ico"); const NAV_ICON: Asset = asset!("/assets/favicon.ico");
@@ -49,7 +49,7 @@ pub fn Widgets() -> Element {
#[component] #[component]
pub fn Utils() -> Element { pub fn Utils() -> Element {
let mut auth_context = use_context::<AuthContext>(); let mut auth_context = use_context::<AuthContext>();
let version = env::var("APP_VERSION").unwrap_or("DEBUG".into()); let version = APP_VERSION;
rsx! { rsx! {
div { class: "utils", div { class: "utils",
div { "{version}" } div { "{version}" }

4
AobaClient/src/env.rs Normal file
View File

@@ -0,0 +1,4 @@
// This file is automatically generated by build.rs
#[allow(dead_code)]
pub const APP_VERSION: &'static str = "Debug";

View File

@@ -1,5 +1,6 @@
pub mod components; pub mod components;
pub mod contexts; pub mod contexts;
mod env;
mod layouts; mod layouts;
pub mod models; pub mod models;
pub mod route; pub mod route;

View File

@@ -60,4 +60,5 @@ WORKDIR /app
COPY --from=publish /app/publish . COPY --from=publish /app/publish .
COPY --from=client-builder /bin/ffmpeg /bin/ffprobe /bin/ffplay /usr/bin/ COPY --from=client-builder /bin/ffmpeg /bin/ffprobe /bin/ffplay /usr/bin/
ENV APP_VERSION=$VERSION
ENTRYPOINT ["dotnet", "AobaServer.dll"] ENTRYPOINT ["dotnet", "AobaServer.dll"]