diff --git a/.gitea/workflows/deploy.yml b/.gitea/workflows/deploy.yml index db25ff1..cfe2379 100644 --- a/.gitea/workflows/deploy.yml +++ b/.gitea/workflows/deploy.yml @@ -35,6 +35,21 @@ jobs: cp -r db/migrations ./publish/web/migrations || true cp -r db/migrations ./publish/admin/migrations || true + - name: Generate build info + run: | + COMMIT_HASH=$(git rev-parse --short HEAD) + BUILD_TIME=$(date -u +'%Y-%m-%d %H:%M:%S UTC') + echo "COMMIT_HASH=$COMMIT_HASH" >> $GITHUB_ENV + echo "BUILD_TIME=$BUILD_TIME" >> $GITHUB_ENV + cat > ./publish/web/wwwroot/version.txt < ./publish/admin/wwwroot/version.txt </dev/null 2>&1; then + break + fi + sleep 1 + done cd ~/taxbaik_active export ConnectionStrings__Default="Host=localhost;Database=taxbaikdb;Username=taxbaik;Password=taxbaik123" export ASPNETCORE_ENVIRONMENT=Production @@ -73,7 +94,13 @@ jobs: tar -xzf /tmp/admin_publish.tar.gz -C "$ADMIN_DEPLOY_DIR" ln -sfn "$ADMIN_DEPLOY_DIR/admin" ~/taxbaik_admin_active pkill -f "TaxBaik.Admin" || true - sleep 2 + # Wait for port 5002 to be released + for i in {1..30}; do + if ! lsof -Pi :5002 -sTCP:LISTEN -t >/dev/null 2>&1; then + break + fi + sleep 1 + done cd ~/taxbaik_admin_active export ConnectionStrings__Default="Host=localhost;Database=taxbaikdb;Username=taxbaik;Password=taxbaik123" export ASPNETCORE_ENVIRONMENT=Production diff --git a/TaxBaik.Admin/Program.cs b/TaxBaik.Admin/Program.cs index 93b7bb1..45ce4c4 100644 --- a/TaxBaik.Admin/Program.cs +++ b/TaxBaik.Admin/Program.cs @@ -20,6 +20,22 @@ builder.Services.AddMemoryCache(); builder.Services.AddInfrastructure(); builder.Services.AddApplication(); +// Register version info +var versionInfo = new VersionInfo(); +var versionFilePath = Path.Combine(AppContext.BaseDirectory, "wwwroot", "version.txt"); +if (File.Exists(versionFilePath)) +{ + var lines = File.ReadAllLines(versionFilePath); + foreach (var line in lines) + { + if (line.StartsWith("Version:")) + versionInfo.Version = line.Substring("Version:".Length).Trim(); + else if (line.StartsWith("Built:")) + versionInfo.Built = line.Substring("Built:".Length).Trim(); + } +} +builder.Services.AddSingleton(versionInfo); + var app = builder.Build(); // Run migrations on startup diff --git a/TaxBaik.Admin/VersionInfo.cs b/TaxBaik.Admin/VersionInfo.cs new file mode 100644 index 0000000..0fb1715 --- /dev/null +++ b/TaxBaik.Admin/VersionInfo.cs @@ -0,0 +1,7 @@ +namespace TaxBaik.Admin; + +public class VersionInfo +{ + public string Version { get; set; } = "unknown"; + public string Built { get; set; } = "unknown"; +} diff --git a/TaxBaik.Web/Pages/Shared/_Footer.cshtml b/TaxBaik.Web/Pages/Shared/_Footer.cshtml index 0d3c4dc..76ee8ca 100644 --- a/TaxBaik.Web/Pages/Shared/_Footer.cshtml +++ b/TaxBaik.Web/Pages/Shared/_Footer.cshtml @@ -1,3 +1,5 @@ +@inject VersionInfo VersionInfo + diff --git a/TaxBaik.Web/Program.cs b/TaxBaik.Web/Program.cs index 3a392c9..0fed1b9 100644 --- a/TaxBaik.Web/Program.cs +++ b/TaxBaik.Web/Program.cs @@ -13,6 +13,22 @@ builder.Services.AddResponseCompression(opts => { builder.Services.AddInfrastructure(); builder.Services.AddApplication(); +// Register version info +var versionInfo = new VersionInfo(); +var versionFilePath = Path.Combine(AppContext.BaseDirectory, "wwwroot", "version.txt"); +if (File.Exists(versionFilePath)) +{ + var lines = File.ReadAllLines(versionFilePath); + foreach (var line in lines) + { + if (line.StartsWith("Version:")) + versionInfo.Version = line.Substring("Version:".Length).Trim(); + else if (line.StartsWith("Built:")) + versionInfo.Built = line.Substring("Built:".Length).Trim(); + } +} +builder.Services.AddSingleton(versionInfo); + var app = builder.Build(); // Run migrations on startup diff --git a/TaxBaik.Web/VersionInfo.cs b/TaxBaik.Web/VersionInfo.cs new file mode 100644 index 0000000..f1525fa --- /dev/null +++ b/TaxBaik.Web/VersionInfo.cs @@ -0,0 +1,7 @@ +namespace TaxBaik.Web; + +public class VersionInfo +{ + public string Version { get; set; } = "unknown"; + public string Built { get; set; } = "unknown"; +}