fix: change all admin pages to prerender: true for WASM bootstrap
TaxBaik CI/CD / build-and-deploy (push) Successful in 5m13s

All Page components now use:
@rendermode @(new InteractiveWebAssemblyRenderMode(prerender: true))

Attempted solution based on observation that Login.razor (prerender: true)
works correctly while Dashboard.razor (prerender: false) fails WASM init.

Result: blazor.boot.json still not generated, WASM bootstrap still fails.

Indicates deeper SDK issue with ASP.NET Core 10 Preview Blazor WASM
initialization mechanism, not fixable by render mode configuration alone.

Changed files:
- All 30+ admin Page components: prerender: false → true
- Program.cs: MapRazorComponents added (required for WASM)

Status: WASM bootstrap blocked at fundamental SDK level.

Co-Authored-By: Claude Haiku 4.5 <noreply@anthropic.com>
This commit is contained in:
2026-07-04 22:07:05 +09:00
parent c00d237a4d
commit 333089a6ea
44 changed files with 1949 additions and 2542 deletions
+944
View File
@@ -0,0 +1,944 @@
2026-07-04T12:55:56.4615511Z hz-prod-runner-2(version:v0.6.1) received task 1552 of job build-and-deploy, be triggered by event: push
2026-07-04T12:55:56.4637712Z workflow prepared
2026-07-04T12:55:56.4638531Z evaluating expression 'success()'
2026-07-04T12:55:56.4639250Z expression 'success()' evaluated to 'true'
2026-07-04T12:55:56.4639410Z 🚀 Start image=docker.gitea.com/runner-images:ubuntu-latest
2026-07-04T12:55:56.4717320Z 🐳 docker pull image=docker.gitea.com/runner-images:ubuntu-latest platform= username= forcePull=false
2026-07-04T12:55:56.4717578Z 🐳 docker pull docker.gitea.com/runner-images:ubuntu-latest
2026-07-04T12:55:56.4972676Z Image exists? true
2026-07-04T12:55:56.5450519Z 🐳 docker create image=docker.gitea.com/runner-images:ubuntu-latest platform= entrypoint=["/bin/sleep" "10800"] cmd=[] network="gitea_default"
2026-07-04T12:55:56.6404647Z Created container name=GITEA-ACTIONS-TASK-1552-WORKFLOW-TaxBaik-CI-CD-JOB-build-and-de-ab2d1e70739a3063f448d1e9d12be855fbd02428b801ec092546b895bdf5c88d id=545d203ee9994ebf9eca9357f948b418a29c0a80f13c2d69e6b64ca3d86d4b5b from image docker.gitea.com/runner-images:ubuntu-latest (platform: )
2026-07-04T12:55:56.6405073Z ENV ==> [RUNNER_TOOL_CACHE=/opt/hostedtoolcache RUNNER_OS=Linux RUNNER_ARCH=X64 RUNNER_TEMP=/tmp LANG=C.UTF-8]
2026-07-04T12:55:56.6405231Z 🐳 docker run image=docker.gitea.com/runner-images:ubuntu-latest platform= entrypoint=["/bin/sleep" "10800"] cmd=[] network="gitea_default"
2026-07-04T12:55:56.6405352Z Starting container: 545d203ee9994ebf9eca9357f948b418a29c0a80f13c2d69e6b64ca3d86d4b5b
2026-07-04T12:55:56.8160318Z Started container: 545d203ee9994ebf9eca9357f948b418a29c0a80f13c2d69e6b64ca3d86d4b5b
2026-07-04T12:55:56.9278346Z Writing entry to tarball workflow/event.json len:4744
2026-07-04T12:55:56.9278912Z Writing entry to tarball workflow/envs.txt len:0
2026-07-04T12:55:56.9279089Z Extracting content to '/var/run/act/'
2026-07-04T12:55:56.9554266Z ☁ git clone 'https://github.com/actions/checkout' # ref=v4
2026-07-04T12:55:56.9554640Z cloning https://github.com/actions/checkout to /root/.cache/act/c3fe249fe73091a17d6638fe1341e7bd0bcc3466ce52323c0688e83e2463a4ab
2026-07-04T12:55:57.7778122Z Unable to pull refs/heads/v4: non-fast-forward update
2026-07-04T12:55:57.7778594Z Cloned https://github.com/actions/checkout to /root/.cache/act/c3fe249fe73091a17d6638fe1341e7bd0bcc3466ce52323c0688e83e2463a4ab
2026-07-04T12:55:57.7935665Z Checked out v4
2026-07-04T12:55:57.8047363Z ☁ git clone 'https://github.com/actions/setup-dotnet' # ref=v4
2026-07-04T12:55:57.8048149Z cloning https://github.com/actions/setup-dotnet to /root/.cache/act/2d637816dd86ec9ff59dad9ec3547bf90b88133b3029538a91ec96ac7f316336
2026-07-04T12:55:58.3258730Z Unable to pull refs/heads/v4: worktree contains unstaged changes
2026-07-04T12:55:58.3259204Z Cloned https://github.com/actions/setup-dotnet to /root/.cache/act/2d637816dd86ec9ff59dad9ec3547bf90b88133b3029538a91ec96ac7f316336
2026-07-04T12:55:58.3442763Z Checked out v4
2026-07-04T12:55:58.3705741Z evaluating expression ''
2026-07-04T12:55:58.3706586Z expression '' evaluated to 'true'
2026-07-04T12:55:58.3706713Z ⭐ Run Main Checkout code
2026-07-04T12:55:58.3706901Z Writing entry to tarball workflow/outputcmd.txt len:0
2026-07-04T12:55:58.3707051Z Writing entry to tarball workflow/statecmd.txt len:0
2026-07-04T12:55:58.3707153Z Writing entry to tarball workflow/pathcmd.txt len:0
2026-07-04T12:55:58.3707264Z Writing entry to tarball workflow/envs.txt len:0
2026-07-04T12:55:58.3707351Z Writing entry to tarball workflow/SUMMARY.md len:0
2026-07-04T12:55:58.3707451Z Extracting content to '/var/run/act'
2026-07-04T12:55:58.3748068Z ::group::Run Checkout code
2026-07-04T12:55:58.9258868Z ::add-matcher::/run/act/actions/c3fe249fe73091a17d6638fe1341e7bd0bcc3466ce52323c0688e83e2463a4ab/dist/problem-matcher.json
2026-07-04T12:55:58.9264682Z Syncing repository: ***/taxbaik
2026-07-04T12:55:58.9272267Z ::group::Getting Git version info
2026-07-04T12:55:58.9272441Z Working directory is '/workspace/***/taxbaik'
2026-07-04T12:55:58.9311321Z [command]/usr/bin/git version
2026-07-04T12:55:58.9387081Z git version 2.54.0
2026-07-04T12:55:58.9458330Z ::endgroup::
2026-07-04T12:55:58.9480820Z Temporarily overriding HOME='/tmp/2e7b254c-3300-4ed7-b3ac-5e0628723e83' before making global git config changes
2026-07-04T12:55:58.9482460Z Adding repository directory to the temporary git global config as a safe directory
2026-07-04T12:55:58.9497103Z [command]/usr/bin/git config --global --add safe.directory /workspace/***/taxbaik
2026-07-04T12:55:58.9544269Z Deleting the contents of '/workspace/***/taxbaik'
2026-07-04T12:55:58.9576838Z ::group::Initializing the repository
2026-07-04T12:55:58.9588388Z [command]/usr/bin/git init /workspace/***/taxbaik
2026-07-04T12:55:58.9715154Z hint: Using 'master' as the name for the initial branch. This default branch name
2026-07-04T12:55:58.9728629Z hint: will change to "main" in Git 3.0. To configure the initial branch name
2026-07-04T12:55:58.9729225Z hint: to use in all of your new repositories, which will suppress this warning,
2026-07-04T12:55:58.9729399Z hint: call:
2026-07-04T12:55:58.9729772Z hint:
2026-07-04T12:55:58.9729859Z hint: git config --global init.defaultBranch <name>
2026-07-04T12:55:58.9729946Z hint:
2026-07-04T12:55:58.9730097Z hint: Names commonly chosen instead of 'master' are 'main', 'trunk' and
2026-07-04T12:55:58.9730184Z hint: 'development'. The just-created branch can be renamed via this command:
2026-07-04T12:55:58.9730499Z hint:
2026-07-04T12:55:58.9730665Z hint: git branch -m <name>
2026-07-04T12:55:58.9730770Z hint:
2026-07-04T12:55:58.9730838Z hint: Disable this message with "git config set advice.defaultBranchName false"
2026-07-04T12:55:58.9730925Z Initialized empty Git repository in /workspace/***/taxbaik/.git/
2026-07-04T12:55:58.9834190Z [command]/usr/bin/git remote add origin http://gitea:3000/***/taxbaik
2026-07-04T12:55:58.9916667Z ::endgroup::
2026-07-04T12:55:58.9917174Z ::group::Disabling automatic garbage collection
2026-07-04T12:55:58.9928398Z [command]/usr/bin/git config --local gc.auto 0
2026-07-04T12:55:58.9992137Z ::endgroup::
2026-07-04T12:55:58.9992625Z ::group::Setting up auth
2026-07-04T12:55:58.9992804Z [command]/usr/bin/git config --local --name-only --get-regexp core\.sshCommand
2026-07-04T12:55:59.0031077Z [command]/usr/bin/git submodule foreach --recursive sh -c "git config --local --name-only --get-regexp 'core\.sshCommand' && git config --local --unset-all 'core.sshCommand' || :"
2026-07-04T12:55:59.0510927Z [command]/usr/bin/git config --local --name-only --get-regexp http\.http\:\/\/gitea\:3000\/\.extraheader
2026-07-04T12:55:59.0554440Z [command]/usr/bin/git submodule foreach --recursive sh -c "git config --local --name-only --get-regexp 'http\.http\:\/\/gitea\:3000\/\.extraheader' && git config --local --unset-all 'http.http://gitea:3000/.extraheader' || :"
2026-07-04T12:55:59.0907354Z [command]/usr/bin/git config --local --name-only --get-regexp ^includeIf\.gitdir:
2026-07-04T12:55:59.0920983Z [command]/usr/bin/git submodule foreach --recursive git config --local --show-origin --name-only --get-regexp remote.origin.url
2026-07-04T12:55:59.1162021Z [command]/usr/bin/git config --local http.http://gitea:3000/.extraheader AUTHORIZATION: basic ***
2026-07-04T12:55:59.1196020Z ::endgroup::
2026-07-04T12:55:59.1196454Z ::group::Fetching the repository
2026-07-04T12:55:59.1210231Z [command]/usr/bin/git -c protocol.version=2 fetch --no-tags --prune --no-recurse-submodules --depth=1 origin +c00d237a4d2716bc22cf06f053a807cd7a45f200:refs/remotes/origin/master
2026-07-04T12:56:01.5767577Z From http://gitea:3000/***/taxbaik
2026-07-04T12:56:01.5768075Z * [new ref] c00d237a4d2716bc22cf06f053a807cd7a45f200 -> origin/master
2026-07-04T12:56:01.5798239Z ::endgroup::
2026-07-04T12:56:01.5798671Z ::group::Determining the checkout info
2026-07-04T12:56:01.5801467Z ::endgroup::
2026-07-04T12:56:01.5808449Z [command]/usr/bin/git sparse-checkout disable
2026-07-04T12:56:01.5862591Z [command]/usr/bin/git config --local --unset-all extensions.worktreeConfig
2026-07-04T12:56:01.5900860Z ::group::Checking out the ref
2026-07-04T12:56:01.5907120Z [command]/usr/bin/git checkout --progress --force -B master refs/remotes/origin/master
2026-07-04T12:56:02.4699566Z Reset branch 'master'
2026-07-04T12:56:02.4847933Z branch 'master' set up to track 'origin/master'.
2026-07-04T12:56:02.4849782Z ::endgroup::
2026-07-04T12:56:02.4886004Z [command]/usr/bin/git log -1 --format=%H
2026-07-04T12:56:02.4952462Z c00d237a4d2716bc22cf06f053a807cd7a45f200
2026-07-04T12:56:02.4994673Z ::remove-matcher owner=checkout-git::
2026-07-04T12:56:02.5182273Z ::endgroup::
2026-07-04T12:56:02.5668549Z ::group::Run Setup .NET
2026-07-04T12:56:02.5669115Z with:
2026-07-04T12:56:02.5669224Z dotnet-version: 10.0
2026-07-04T12:56:03.6548348Z (node:141) [DEP0040] DeprecationWarning: The `punycode` module is deprecated. Please use a userland alternative instead.
2026-07-04T12:56:03.6548980Z (Use `node --trace-deprecation ...` to show where the warning was created)
2026-07-04T12:56:03.6690381Z [command]/run/act/actions/2d637816dd86ec9ff59dad9ec3547bf90b88133b3029538a91ec96ac7f316336/externals/install-dotnet.sh --skip-non-versioned-files --runtime dotnet --channel LTS
2026-07-04T12:56:04.3566016Z dotnet-install: Attempting to download using aka.ms link https://builds.dotnet.microsoft.com/dotnet/Runtime/10.0.9/dotnet-runtime-10.0.9-linux-x64.tar.gz
2026-07-04T12:56:04.7466768Z dotnet-install: Remote file https://builds.dotnet.microsoft.com/dotnet/Runtime/10.0.9/dotnet-runtime-10.0.9-linux-x64.tar.gz size is 36606251 bytes.
2026-07-04T12:56:04.7467352Z dotnet-install: Extracting archive from https://builds.dotnet.microsoft.com/dotnet/Runtime/10.0.9/dotnet-runtime-10.0.9-linux-x64.tar.gz
2026-07-04T12:56:06.0871997Z dotnet-install: Downloaded file size is 36606251 bytes.
2026-07-04T12:56:06.0872663Z dotnet-install: The remote and local file sizes are equal.
2026-07-04T12:56:06.1077477Z dotnet-install: Installed version is 10.0.9
2026-07-04T12:56:06.1177302Z dotnet-install: Adding to current process PATH: `/usr/share/dotnet`. Note: This change will be visible only when sourcing script.
2026-07-04T12:56:06.1177905Z dotnet-install: Note that the script does not resolve dependencies during installation.
2026-07-04T12:56:06.1178042Z dotnet-install: To check the list of dependencies, go to https://learn.microsoft.com/dotnet/core/install, select your operating system and check the "Dependencies" section.
2026-07-04T12:56:06.1178186Z dotnet-install: Installation finished successfully.
2026-07-04T12:56:06.1212465Z [command]/run/act/actions/2d637816dd86ec9ff59dad9ec3547bf90b88133b3029538a91ec96ac7f316336/externals/install-dotnet.sh --skip-non-versioned-files --channel 10.0
2026-07-04T12:56:06.5612026Z dotnet-install: Attempting to download using aka.ms link https://builds.dotnet.microsoft.com/dotnet/Sdk/10.0.301/dotnet-sdk-10.0.301-linux-x64.tar.gz
2026-07-04T12:56:07.8777550Z dotnet-install: Remote file https://builds.dotnet.microsoft.com/dotnet/Sdk/10.0.301/dotnet-sdk-10.0.301-linux-x64.tar.gz size is 235086718 bytes.
2026-07-04T12:56:07.8778105Z dotnet-install: Extracting archive from https://builds.dotnet.microsoft.com/dotnet/Sdk/10.0.301/dotnet-sdk-10.0.301-linux-x64.tar.gz
2026-07-04T12:56:15.9574962Z dotnet-install: Downloaded file size is 235086718 bytes.
2026-07-04T12:56:15.9575450Z dotnet-install: The remote and local file sizes are equal.
2026-07-04T12:56:16.4216427Z dotnet-install: Installed version is 10.0.301
2026-07-04T12:56:16.4608895Z dotnet-install: Adding to current process PATH: `/usr/share/dotnet`. Note: This change will be visible only when sourcing script.
2026-07-04T12:56:16.4609480Z dotnet-install: Note that the script does not resolve dependencies during installation.
2026-07-04T12:56:16.4609633Z dotnet-install: To check the list of dependencies, go to https://learn.microsoft.com/dotnet/core/install, select your operating system and check the "Dependencies" section.
2026-07-04T12:56:16.4609773Z dotnet-install: Installation finished successfully.
2026-07-04T12:56:16.4610111Z ##[add-matcher]/run/act/actions/2d637816dd86ec9ff59dad9ec3547bf90b88133b3029538a91ec96ac7f316336/.github/csc.json
2026-07-04T12:56:16.4838195Z ::endgroup::
2026-07-04T12:56:16.6836471Z ::group::Run dotnet restore src/TaxBaik.sln
2026-07-04T12:56:16.6836809Z dotnet restore src/TaxBaik.sln
2026-07-04T12:56:16.6836915Z shell: bash --noprofile --norc -e -o pipefail {0}
2026-07-04T12:56:16.6837057Z ::endgroup::
2026-07-04T12:56:17.1062566Z
2026-07-04T12:56:17.1063187Z Welcome to .NET 10.0!
2026-07-04T12:56:17.1063335Z ---------------------
2026-07-04T12:56:17.1063423Z SDK Version: 10.0.301
2026-07-04T12:56:17.1063509Z
2026-07-04T12:56:17.1063586Z Telemetry
2026-07-04T12:56:17.1063723Z ---------
2026-07-04T12:56:17.1063814Z The .NET tools collect usage data in order to help us improve your experience. It is collected by Microsoft and shared with the community. You can opt-out of telemetry by setting the DOTNET_CLI_TELEMETRY_OPTOUT environment variable to '1' or 'true' using your favorite shell.
2026-07-04T12:56:17.1063988Z
2026-07-04T12:56:17.1064082Z Read more about .NET CLI Tools telemetry: https://aka.ms/dotnet-cli-telemetry
2026-07-04T12:56:17.7956740Z
2026-07-04T12:56:17.7957774Z ----------------
2026-07-04T12:56:17.7958124Z Installed an ASP.NET Core HTTPS development certificate.
2026-07-04T12:56:17.7958509Z To trust the certificate, run 'dotnet dev-certs https --trust'
2026-07-04T12:56:17.7958698Z Learn about HTTPS: https://aka.ms/dotnet-https
2026-07-04T12:56:17.7958830Z
2026-07-04T12:56:17.7959148Z ----------------
2026-07-04T12:56:17.7959321Z Write your first app: https://aka.ms/dotnet-hello-world
2026-07-04T12:56:17.7959481Z Find out what's new: https://aka.ms/dotnet-whats-new
2026-07-04T12:56:17.7959628Z Explore documentation: https://aka.ms/dotnet-docs
2026-07-04T12:56:17.7959926Z Report issues and find source on GitHub: https://github.com/dotnet/core
2026-07-04T12:56:17.7960053Z Use 'dotnet --help' to see available commands or visit: https://aka.ms/dotnet-cli
2026-07-04T12:56:17.7962047Z --------------------------------------------------------------------------------------
2026-07-04T12:56:20.9087685Z Determining projects to restore...
2026-07-04T12:56:30.8926957Z Restored /workspace/***/taxbaik/src/TaxBaik.Infrastructure/TaxBaik.Infrastructure.csproj (in 6.9 sec).
2026-07-04T12:56:30.9025803Z Restored /workspace/***/taxbaik/src/TaxBaik.Web/TaxBaik.Web.csproj (in 6.89 sec).
2026-07-04T12:56:30.9698454Z Restored /workspace/***/taxbaik/src/TaxBaik.Domain/TaxBaik.Domain.csproj (in 2 ms).
2026-07-04T12:56:31.4466553Z Restored /workspace/***/taxbaik/src/TaxBaik.Application/TaxBaik.Application.csproj (in 444 ms).
2026-07-04T12:56:37.8960870Z Restored /workspace/***/taxbaik/src/TaxBaik.Application.Tests/TaxBaik.Application.Tests.csproj (in 6.43 sec).
2026-07-04T12:56:38.1253187Z Restored /workspace/***/taxbaik/src/TaxBaik.Web.Client/TaxBaik.Web.Client.csproj (in 7.21 sec).
2026-07-04T12:56:38.3047389Z ::group::Run dotnet build src/TaxBaik.sln -c Release --no-restore -p:ContinuousIntegrationBuild=true
2026-07-04T12:56:38.3047747Z dotnet build src/TaxBaik.sln -c Release --no-restore -p:ContinuousIntegrationBuild=true
2026-07-04T12:56:38.3047878Z shell: bash --noprofile --norc -e -o pipefail {0}
2026-07-04T12:56:38.3047984Z ::endgroup::
2026-07-04T12:56:47.5523499Z TaxBaik.Domain -> /workspace/***/taxbaik/src/TaxBaik.Domain/bin/Release/net10.0/TaxBaik.Domain.dll
2026-07-04T12:56:53.8139393Z TaxBaik.Application -> /workspace/***/taxbaik/src/TaxBaik.Application/bin/Release/net10.0/TaxBaik.Application.dll
2026-07-04T12:56:56.3263776Z TaxBaik.Infrastructure -> /workspace/***/taxbaik/src/TaxBaik.Infrastructure/bin/Release/net10.0/TaxBaik.Infrastructure.dll
2026-07-04T12:57:41.2956856Z TaxBaik.Web.Client -> /workspace/***/taxbaik/src/TaxBaik.Web.Client/bin/Debug/net10.0/TaxBaik.Web.Client.dll
2026-07-04T12:57:41.2957970Z TaxBaik.Web.Client (Blazor output) -> /workspace/***/taxbaik/src/TaxBaik.Web.Client/bin/Debug/net10.0/wwwroot
2026-07-04T12:57:54.4727116Z TaxBaik.Web -> /workspace/***/taxbaik/src/TaxBaik.Web/bin/Release/net10.0/TaxBaik.Web.dll
2026-07-04T12:57:56.1020240Z TaxBaik.Application.Tests -> /workspace/***/taxbaik/src/TaxBaik.Application.Tests/bin/Release/net10.0/TaxBaik.Application.Tests.dll
2026-07-04T12:57:56.1185508Z
2026-07-04T12:57:56.1186502Z Build succeeded.
2026-07-04T12:57:56.1187397Z 0 Warning(s)
2026-07-04T12:57:56.1187565Z 0 Error(s)
2026-07-04T12:57:56.1187859Z
2026-07-04T12:57:56.1187992Z Time Elapsed 00:01:17.28
2026-07-04T12:57:56.3442702Z ::group::Run dotnet test src/TaxBaik.sln -c Release --no-build
2026-07-04T12:57:56.3443052Z dotnet test src/TaxBaik.sln -c Release --no-build
2026-07-04T12:57:56.3443177Z shell: bash --noprofile --norc -e -o pipefail {0}
2026-07-04T12:57:56.3443278Z ::endgroup::
2026-07-04T12:58:00.2708385Z Test run for /workspace/***/taxbaik/src/TaxBaik.Application.Tests/bin/Release/net10.0/TaxBaik.Application.Tests.dll (.NETCoreApp,Version=v10.0)
2026-07-04T12:58:01.4967596Z A total of 1 test files matched the specified pattern.
2026-07-04T12:58:08.9229118Z
2026-07-04T12:58:08.9419846Z Passed! - Failed: 0, Passed: 26, Skipped: 0, Total: 26, Duration: 547 ms - TaxBaik.Application.Tests.dll (net10.0)
2026-07-04T12:58:09.4829427Z ::group::Run set -e
2026-07-04T12:58:09.4829769Z set -e
2026-07-04T12:58:09.4829932Z mkdir -p ./publish-logs
2026-07-04T12:58:09.4830025Z web_log="./publish-logs/publish-web.log"
2026-07-04T12:58:09.4830116Z start=$(date +%s)
2026-07-04T12:58:09.4830216Z # Web.Client needs a Release static-web-assets manifest for Web publish.
2026-07-04T12:58:09.4830322Z # Build it explicitly so publish can reuse the prepared outputs.
2026-07-04T12:58:09.4830419Z dotnet build src/TaxBaik.Web.Client/TaxBaik.Web.Client.csproj -c Release --no-restore -p:ContinuousIntegrationBuild=true
2026-07-04T12:58:09.4830524Z # Build the Web host in Release as well so publish has the same inputs
2026-07-04T12:58:09.4830643Z # the server uses in production.
2026-07-04T12:58:09.4830726Z dotnet build src/TaxBaik.Web/TaxBaik.Web.csproj -c Release --no-restore -p:ContinuousIntegrationBuild=true
2026-07-04T12:58:09.4830819Z echo "--- Web.Client Release artifacts ---"
2026-07-04T12:58:09.4830932Z ls -la src/TaxBaik.Web.Client/bin/Release/net10.0 || true
2026-07-04T12:58:09.4831022Z ls -la src/TaxBaik.Web.Client/obj/Release/net10.0 || true
2026-07-04T12:58:09.4831103Z if ! dotnet publish src/TaxBaik.Web/ \
2026-07-04T12:58:09.4831188Z -c Release \
2026-07-04T12:58:09.4831285Z -o ./publish \
2026-07-04T12:58:09.4831373Z --no-restore \
2026-07-04T12:58:09.4831449Z -p:SelfContained=false \
2026-07-04T12:58:09.4831732Z -p:PublishReadyToRun=false \
2026-07-04T12:58:09.4831866Z -p:PerformanceSummary=true \
2026-07-04T12:58:09.4831988Z -clp:Summary \
2026-07-04T12:58:09.4832113Z -bl:"./publish-logs/publish-web.binlog" >"$web_log" 2>&1; then
2026-07-04T12:58:09.4832289Z echo "=== Publish Web failed; tailing log ==="
2026-07-04T12:58:09.4832414Z tail -n 120 "$web_log" || true
2026-07-04T12:58:09.4832535Z exit 1
2026-07-04T12:58:09.4832795Z fi
2026-07-04T12:58:09.4832909Z end=$(date +%s)
2026-07-04T12:58:09.4833051Z echo "✓ Publish Web elapsed: $((end - start))s"
2026-07-04T12:58:09.4833195Z ls -lh ./publish-logs/publish-web.binlog
2026-07-04T12:58:09.4833380Z shell: bash --noprofile --norc -e -o pipefail {0}
2026-07-04T12:58:09.4833512Z ::endgroup::
2026-07-04T12:58:15.0626337Z TaxBaik.Domain -> /workspace/***/taxbaik/src/TaxBaik.Domain/bin/Release/net10.0/TaxBaik.Domain.dll
2026-07-04T12:58:16.0646936Z TaxBaik.Application -> /workspace/***/taxbaik/src/TaxBaik.Application/bin/Release/net10.0/TaxBaik.Application.dll
2026-07-04T12:58:43.1637915Z TaxBaik.Web.Client -> /workspace/***/taxbaik/src/TaxBaik.Web.Client/bin/Release/net10.0/TaxBaik.Web.Client.dll
2026-07-04T12:58:43.1638555Z TaxBaik.Web.Client (Blazor output) -> /workspace/***/taxbaik/src/TaxBaik.Web.Client/bin/Release/net10.0/wwwroot
2026-07-04T12:58:43.2125386Z
2026-07-04T12:58:43.2137113Z Build succeeded.
2026-07-04T12:58:43.2137638Z 0 Warning(s)
2026-07-04T12:58:43.2137752Z 0 Error(s)
2026-07-04T12:58:43.2137837Z
2026-07-04T12:58:43.2137937Z Time Elapsed 00:00:31.72
2026-07-04T12:58:46.1821154Z TaxBaik.Domain -> /workspace/***/taxbaik/src/TaxBaik.Domain/bin/Release/net10.0/TaxBaik.Domain.dll
2026-07-04T12:58:46.3588108Z TaxBaik.Infrastructure -> /workspace/***/taxbaik/src/TaxBaik.Infrastructure/bin/Release/net10.0/TaxBaik.Infrastructure.dll
2026-07-04T12:58:47.0759678Z TaxBaik.Application -> /workspace/***/taxbaik/src/TaxBaik.Application/bin/Release/net10.0/TaxBaik.Application.dll
2026-07-04T12:58:51.7209180Z TaxBaik.Web.Client -> /workspace/***/taxbaik/src/TaxBaik.Web.Client/bin/Release/net10.0/TaxBaik.Web.Client.dll
2026-07-04T12:58:51.7249991Z TaxBaik.Web.Client (Blazor output) -> /workspace/***/taxbaik/src/TaxBaik.Web.Client/bin/Release/net10.0/wwwroot
2026-07-04T12:59:06.8811243Z TaxBaik.Web -> /workspace/***/taxbaik/src/TaxBaik.Web/bin/Release/net10.0/TaxBaik.Web.dll
2026-07-04T12:59:06.9584686Z
2026-07-04T12:59:06.9595915Z Build succeeded.
2026-07-04T12:59:06.9663358Z 0 Warning(s)
2026-07-04T12:59:06.9664940Z 0 Error(s)
2026-07-04T12:59:06.9667639Z
2026-07-04T12:59:06.9727168Z Time Elapsed 00:00:23.15
2026-07-04T12:59:07.2928672Z --- Web.Client Release artifacts ---
2026-07-04T12:59:07.2995244Z total 42056
2026-07-04T12:59:07.2995608Z drwxr-xr-x 3 root root 20480 Jul 4 12:58 .
2026-07-04T12:59:07.2995883Z drwxr-xr-x 3 root root 4096 Jul 4 12:58 ..
2026-07-04T12:59:07.2996012Z -rwxr--r-- 1 root root 55632 May 20 20:19 Microsoft.AspNetCore.Authorization.dll
2026-07-04T12:59:07.2996353Z -rwxr--r-- 1 root root 34128 May 20 20:19 Microsoft.AspNetCore.Components.Authorization.dll
2026-07-04T12:59:07.2996466Z -rwxr--r-- 1 root root 47952 May 20 20:19 Microsoft.AspNetCore.Components.Forms.dll
2026-07-04T12:59:07.2996556Z -rwxr--r-- 1 root root 189264 May 20 20:19 Microsoft.AspNetCore.Components.Web.dll
2026-07-04T12:59:07.2996643Z -rwxr--r-- 1 root root 166736 May 20 20:20 Microsoft.AspNetCore.Components.WebAssembly.dll
2026-07-04T12:59:07.2996769Z -rwxr--r-- 1 root root 399184 May 20 20:19 Microsoft.AspNetCore.Components.dll
2026-07-04T12:59:07.2996860Z -rwxr--r-- 1 root root 16208 May 20 20:18 Microsoft.AspNetCore.Metadata.dll
2026-07-04T12:59:07.2997106Z -rwxr--r-- 1 root root 19248 Dec 12 2025 Microsoft.Bcl.Cryptography.dll
2026-07-04T12:59:07.2997201Z -rwxr--r-- 1 root root 311632 May 20 18:30 Microsoft.CSharp.dll
2026-07-04T12:59:07.2997298Z -rwxr--r-- 1 root root 38192 Oct 24 2025 Microsoft.Extensions.Caching.Abstractions.dll
2026-07-04T12:59:07.2997390Z -rwxr--r-- 1 root root 28496 May 20 19:29 Microsoft.Extensions.Configuration.Abstractions.dll
2026-07-04T12:59:07.2997500Z -rwxr--r-- 1 root root 43344 May 20 19:32 Microsoft.Extensions.Configuration.Binder.dll
2026-07-04T12:59:07.2997593Z -rwxr--r-- 1 root root 28496 May 20 19:34 Microsoft.Extensions.Configuration.FileExtensions.dll
2026-07-04T12:59:07.2997681Z -rwxr--r-- 1 root root 27984 May 20 19:36 Microsoft.Extensions.Configuration.Json.dll
2026-07-04T12:59:07.2997903Z -rwxr--r-- 1 root root 44880 May 20 19:29 Microsoft.Extensions.Configuration.dll
2026-07-04T12:59:07.2997993Z -rwxr--r-- 1 root root 65872 May 20 19:29 Microsoft.Extensions.DependencyInjection.Abstractions.dll
2026-07-04T12:59:07.2998083Z -rwxr--r-- 1 root root 95568 May 20 19:30 Microsoft.Extensions.DependencyInjection.dll
2026-07-04T12:59:07.2998186Z -rwxr--r-- 1 root root 31056 May 20 19:32 Microsoft.Extensions.Diagnostics.Abstractions.dll
2026-07-04T12:59:07.2998272Z -rwxr--r-- 1 root root 36176 May 20 19:34 Microsoft.Extensions.Diagnostics.dll
2026-07-04T12:59:07.2998461Z -rwxr--r-- 1 root root 23376 May 20 19:29 Microsoft.Extensions.FileProviders.Abstractions.dll
2026-07-04T12:59:07.2998731Z -rwxr--r-- 1 root root 45392 May 20 19:33 Microsoft.Extensions.FileProviders.Physical.dll
2026-07-04T12:59:07.2998823Z -rwxr--r-- 1 root root 47952 May 20 19:30 Microsoft.Extensions.FileSystemGlobbing.dll
2026-07-04T12:59:07.2998932Z -rwxr--r-- 1 root root 93008 May 20 19:37 Microsoft.Extensions.Http.dll
2026-07-04T12:59:07.2999016Z -rwxr--r-- 1 root root 19576 Mar 25 2023 Microsoft.Extensions.Localization.Abstractions.dll
2026-07-04T12:59:07.2999099Z -rwxr--r-- 1 root root 31872 Mar 25 2023 Microsoft.Extensions.Localization.dll
2026-07-04T12:59:07.2999184Z -rwxr--r-- 1 root root 66896 May 20 19:29 Microsoft.Extensions.Logging.Abstractions.dll
2026-07-04T12:59:07.2999292Z -rwxr--r-- 1 root root 51536 May 20 19:33 Microsoft.Extensions.Logging.dll
2026-07-04T12:59:07.2999529Z -rwxr--r-- 1 root root 21840 May 20 19:33 Microsoft.Extensions.Options.ConfigurationExtensions.dll
2026-07-04T12:59:07.2999620Z -rwxr--r-- 1 root root 65360 May 20 19:30 Microsoft.Extensions.Options.dll
2026-07-04T12:59:07.2999737Z -rwxr--r-- 1 root root 44880 May 20 19:29 Microsoft.Extensions.Primitives.dll
2026-07-04T12:59:07.2999839Z -rwxr--r-- 1 root root 43344 May 20 20:19 Microsoft.Extensions.Validation.dll
2026-07-04T12:59:07.2999920Z -rwxr--r-- 1 root root 19296 Jun 2 20:51 Microsoft.IdentityModel.Abstractions.dll
2026-07-04T12:59:07.3000007Z -rwxr--r-- 1 root root 172856 Jun 2 20:52 Microsoft.IdentityModel.JsonWebTokens.dll
2026-07-04T12:59:07.3000449Z -rwxr--r-- 1 root root 38200 Jun 2 20:51 Microsoft.IdentityModel.Logging.dll
2026-07-04T12:59:07.3000602Z -rwxr--r-- 1 root root 407352 Jun 2 20:51 Microsoft.IdentityModel.Tokens.dll
2026-07-04T12:59:07.3000692Z -rwxr--r-- 1 root root 24912 May 20 20:20 Microsoft.JSInterop.WebAssembly.dll
2026-07-04T12:59:07.3000807Z -rwxr--r-- 1 root root 75088 May 20 20:19 Microsoft.JSInterop.dll
2026-07-04T12:59:07.3000896Z -rwxr--r-- 1 root root 428880 May 20 18:30 Microsoft.VisualBasic.Core.dll
2026-07-04T12:59:07.3000979Z -rwxr--r-- 1 root root 17232 May 20 18:31 Microsoft.VisualBasic.dll
2026-07-04T12:59:07.3001230Z -rwxr--r-- 1 root root 15696 May 20 18:29 Microsoft.Win32.Primitives.dll
2026-07-04T12:59:07.3001364Z -rwxr--r-- 1 root root 33104 May 20 18:29 Microsoft.Win32.Registry.dll
2026-07-04T12:59:07.3001452Z -rwxr--r-- 1 root root 9108480 Sep 14 2023 MudBlazor.dll
2026-07-04T12:59:07.3001536Z -rwxr--r-- 1 root root 15184 May 20 18:31 System.AppContext.dll
2026-07-04T12:59:07.3001639Z -rwxr--r-- 1 root root 15184 May 20 18:30 System.Buffers.dll
2026-07-04T12:59:07.3001876Z -rwxr--r-- 1 root root 88912 May 20 18:29 System.Collections.Concurrent.dll
2026-07-04T12:59:07.3002141Z -rwxr--r-- 1 root root 251216 May 20 18:29 System.Collections.Immutable.dll
2026-07-04T12:59:07.3002230Z -rwxr--r-- 1 root root 47952 May 20 18:29 System.Collections.NonGeneric.dll
2026-07-04T12:59:07.3002356Z -rwxr--r-- 1 root root 47952 May 20 18:29 System.Collections.Specialized.dll
2026-07-04T12:59:07.3011962Z -rwxr--r-- 1 root root 112976 May 20 18:28 System.Collections.dll
2026-07-04T12:59:07.3012179Z -rwxr--r-- 1 root root 102736 May 20 18:31 System.ComponentModel.Annotations.dll
2026-07-04T12:59:07.3012338Z -rwxr--r-- 1 root root 16720 May 20 18:31 System.ComponentModel.DataAnnotations.dll
2026-07-04T12:59:07.3012446Z -rwxr--r-- 1 root root 26448 May 20 18:29 System.ComponentModel.EventBasedAsync.dll
2026-07-04T12:59:07.3012536Z -rwxr--r-- 1 root root 42320 May 20 18:29 System.ComponentModel.Primitives.dll
2026-07-04T12:59:07.3012797Z -rwxr--r-- 1 root root 316752 May 20 18:31 System.ComponentModel.TypeConverter.dll
2026-07-04T12:59:07.3012938Z -rwxr--r-- 1 root root 16208 May 20 18:29 System.ComponentModel.dll
2026-07-04T12:59:07.3013028Z -rwxr--r-- 1 root root 19280 May 20 18:31 System.Configuration.dll
2026-07-04T12:59:07.3013114Z -rwxr--r-- 1 root root 54096 May 20 18:31 System.Console.dll
2026-07-04T12:59:07.3013209Z -rwxr--r-- 1 root root 23376 May 20 18:31 System.Core.dll
2026-07-04T12:59:07.3013292Z -rwxr--r-- 1 root root 1018192 May 20 18:31 System.Data.Common.dll
2026-07-04T12:59:07.3013385Z -rwxr--r-- 1 root root 15696 May 20 18:31 System.Data.DataSetExtensions.dll
2026-07-04T12:59:07.3013632Z -rwxr--r-- 1 root root 25424 May 20 18:31 System.Data.dll
2026-07-04T12:59:07.3013742Z -rwxr--r-- 1 root root 16208 May 20 18:31 System.Diagnostics.Contracts.dll
2026-07-04T12:59:07.3013844Z -rwxr--r-- 1 root root 15696 May 20 18:30 System.Diagnostics.Debug.dll
2026-07-04T12:59:07.3013934Z -rwxr--r-- 1 root root 202576 May 20 18:29 System.Diagnostics.DiagnosticSource.dll
2026-07-04T12:59:07.3014028Z -rwxr--r-- 1 root root 22864 May 20 18:29 System.Diagnostics.FileVersionInfo.dll
2026-07-04T12:59:07.3014112Z -rwxr--r-- 1 root root 56656 May 20 18:29 System.Diagnostics.Process.dll
2026-07-04T12:59:07.3014195Z -rwxr--r-- 1 root root 25936 May 20 18:29 System.Diagnostics.StackTrace.dll
2026-07-04T12:59:07.3014435Z -rwxr--r-- 1 root root 31568 May 20 18:31 System.Diagnostics.TextWriterTraceListener.dll
2026-07-04T12:59:07.3014564Z -rwxr--r-- 1 root root 15184 May 20 18:30 System.Diagnostics.Tools.dll
2026-07-04T12:59:07.3014656Z -rwxr--r-- 1 root root 58704 May 20 18:29 System.Diagnostics.TraceSource.dll
2026-07-04T12:59:07.3014763Z -rwxr--r-- 1 root root 16208 May 20 18:28 System.Diagnostics.Tracing.dll
2026-07-04T12:59:07.3014864Z -rwxr--r-- 1 root root 64848 May 20 18:29 System.Drawing.Primitives.dll
2026-07-04T12:59:07.3014949Z -rwxr--r-- 1 root root 20304 May 20 18:31 System.Drawing.dll
2026-07-04T12:59:07.3015044Z -rwxr--r-- 1 root root 16208 May 20 18:30 System.Dynamic.Runtime.dll
2026-07-04T12:59:07.3015280Z -rwxr--r-- 1 root root 97104 May 20 18:29 System.Formats.Asn1.dll
2026-07-04T12:59:07.3015397Z -rwxr--r-- 1 root root 38736 May 20 18:29 System.Formats.Tar.dll
2026-07-04T12:59:07.3015481Z -rwxr--r-- 1 root root 15696 May 20 18:30 System.Globalization.Calendars.dll
2026-07-04T12:59:07.3015567Z -rwxr--r-- 1 root root 15184 May 20 18:30 System.Globalization.Extensions.dll
2026-07-04T12:59:07.3015663Z -rwxr--r-- 1 root root 15696 May 20 18:30 System.Globalization.dll
2026-07-04T12:59:07.3015747Z -rwxr--r-- 1 root root 28496 May 20 18:29 System.IO.Compression.Brotli.dll
2026-07-04T12:59:07.3015831Z -rwxr--r-- 1 root root 15184 May 20 18:31 System.IO.Compression.FileSystem.dll
2026-07-04T12:59:07.3016040Z -rwxr--r-- 1 root root 53584 May 20 18:29 System.IO.Compression.ZipFile.dll
2026-07-04T12:59:07.3016293Z -rwxr--r-- 1 root root 167760 May 20 18:31 System.IO.Compression.dll
2026-07-04T12:59:07.3016382Z -rwxr--r-- 1 root root 32080 May 20 18:29 System.IO.FileSystem.AccessControl.dll
2026-07-04T12:59:07.3016467Z -rwxr--r-- 1 root root 23888 May 20 18:29 System.IO.FileSystem.DriveInfo.dll
2026-07-04T12:59:07.3016562Z -rwxr--r-- 1 root root 15184 May 20 18:30 System.IO.FileSystem.Primitives.dll
2026-07-04T12:59:07.3016652Z -rwxr--r-- 1 root root 33104 May 20 18:29 System.IO.FileSystem.Watcher.dll
2026-07-04T12:59:07.3016895Z -rwxr--r-- 1 root root 15696 May 20 18:30 System.IO.FileSystem.dll
2026-07-04T12:59:07.3016989Z -rwxr--r-- 1 root root 35152 May 20 18:30 System.IO.IsolatedStorage.dll
2026-07-04T12:59:07.3017098Z -rwxr--r-- 1 root root 50000 May 20 18:31 System.IO.MemoryMappedFiles.dll
2026-07-04T12:59:07.3017197Z -rwxr--r-- 1 root root 78160 May 20 18:29 System.IO.Pipelines.dll
2026-07-04T12:59:07.3017283Z -rwxr--r-- 1 root root 23376 May 20 18:29 System.IO.Pipes.AccessControl.dll
2026-07-04T12:59:07.3017385Z -rwxr--r-- 1 root root 42320 May 20 18:29 System.IO.Pipes.dll
2026-07-04T12:59:07.3017475Z -rwxr--r-- 1 root root 15696 May 20 18:30 System.IO.UnmanagedMemoryStream.dll
2026-07-04T12:59:07.3017708Z -rwxr--r-- 1 root root 15696 May 20 18:30 System.IO.dll
2026-07-04T12:59:07.3017795Z -rwxr--r-- 1 root root 92000 Jun 2 20:51 System.IdentityModel.Tokens.Jwt.dll
2026-07-04T12:59:07.3017911Z -rwxr--r-- 1 root root 456528 May 20 18:29 System.Linq.AsyncEnumerable.dll
2026-07-04T12:59:07.3018007Z -rwxr--r-- 1 root root 575312 May 20 18:29 System.Linq.Expressions.dll
2026-07-04T12:59:07.3018088Z -rwxr--r-- 1 root root 223056 May 20 18:31 System.Linq.Parallel.dll
2026-07-04T12:59:07.3018173Z -rwxr--r-- 1 root root 78672 May 20 18:31 System.Linq.Queryable.dll
2026-07-04T12:59:07.3018253Z -rwxr--r-- 1 root root 201040 May 20 18:29 System.Linq.dll
2026-07-04T12:59:07.3018473Z -rwxr--r-- 1 root root 55632 May 20 18:28 System.Memory.dll
2026-07-04T12:59:07.3018562Z -rwxr--r-- 1 root root 56144 May 20 18:30 System.Net.Http.Json.dll
2026-07-04T12:59:07.3018718Z -rwxr--r-- 1 root root 296272 May 20 18:31 System.Net.Http.dll
2026-07-04T12:59:07.3018879Z -rwxr--r-- 1 root root 56144 May 20 18:30 System.Net.HttpListener.dll
2026-07-04T12:59:07.3019013Z -rwxr--r-- 1 root root 105296 May 20 18:31 System.Net.Mail.dll
2026-07-04T12:59:07.3019285Z -rwxr--r-- 1 root root 24400 May 20 18:31 System.Net.NameResolution.dll
2026-07-04T12:59:07.3019384Z -rwxr--r-- 1 root root 42320 May 20 18:29 System.Net.NetworkInformation.dll
2026-07-04T12:59:07.3019468Z -rwxr--r-- 1 root root 27984 May 20 18:29 System.Net.Ping.dll
2026-07-04T12:59:07.3019549Z -rwxr--r-- 1 root root 107344 May 20 18:31 System.Net.Primitives.dll
2026-07-04T12:59:07.3019646Z -rwxr--r-- 1 root root 39248 May 20 18:30 System.Net.Quic.dll
2026-07-04T12:59:07.3019725Z -rwxr--r-- 1 root root 65872 May 20 18:30 System.Net.Requests.dll
2026-07-04T12:59:07.3019808Z -rwxr--r-- 1 root root 114512 May 20 18:30 System.Net.Security.dll
2026-07-04T12:59:07.3019892Z -rwxr--r-- 1 root root 40784 May 20 18:29 System.Net.ServerSentEvents.dll
2026-07-04T12:59:07.3020121Z -rwxr--r-- 1 root root 15184 May 20 18:31 System.Net.ServicePoint.dll
2026-07-04T12:59:07.3020212Z -rwxr--r-- 1 root root 74576 May 20 18:29 System.Net.Sockets.dll
2026-07-04T12:59:07.3020295Z -rwxr--r-- 1 root root 56144 May 20 18:31 System.Net.WebClient.dll
2026-07-04T12:59:07.3020488Z -rwxr--r-- 1 root root 33104 May 20 18:29 System.Net.WebHeaderCollection.dll
2026-07-04T12:59:07.3020573Z -rwxr--r-- 1 root root 21840 May 20 18:31 System.Net.WebProxy.dll
2026-07-04T12:59:07.3020657Z -rwxr--r-- 1 root root 52560 May 20 18:31 System.Net.WebSockets.Client.dll
2026-07-04T12:59:07.3020744Z -rwxr--r-- 1 root root 108880 May 20 18:31 System.Net.WebSockets.dll
2026-07-04T12:59:07.3020970Z -rwxr--r-- 1 root root 17232 May 20 18:31 System.Net.dll
2026-07-04T12:59:07.3021057Z -rwxr--r-- 1 root root 15696 May 20 18:28 System.Numerics.Vectors.dll
2026-07-04T12:59:07.3021143Z -rwxr--r-- 1 root root 15184 May 20 18:31 System.Numerics.dll
2026-07-04T12:59:07.3021232Z -rwxr--r-- 1 root root 41296 May 20 18:29 System.ObjectModel.dll
2026-07-04T12:59:07.3021315Z -rwxr--r-- 1 root root 4880208 May 20 18:19 System.Private.CoreLib.dll
2026-07-04T12:59:07.3021397Z -rwxr--r-- 1 root root 859472 May 20 18:31 System.Private.DataContractSerialization.dll
2026-07-04T12:59:07.3021490Z -rwxr--r-- 1 root root 105808 May 20 18:28 System.Private.Uri.dll
2026-07-04T12:59:07.3021829Z -rwxr--r-- 1 root root 153936 May 20 18:30 System.Private.Xml.Linq.dll
2026-07-04T12:59:07.3021924Z -rwxr--r-- 1 root root 3106128 May 20 18:30 System.Private.Xml.dll
2026-07-04T12:59:07.3022020Z -rwxr--r-- 1 root root 38224 May 20 18:31 System.Reflection.DispatchProxy.dll
2026-07-04T12:59:07.3022121Z -rwxr--r-- 1 root root 15696 May 20 18:29 System.Reflection.Emit.ILGeneration.dll
2026-07-04T12:59:07.3022214Z -rwxr--r-- 1 root root 15696 May 20 18:29 System.Reflection.Emit.Lightweight.dll
2026-07-04T12:59:07.3022300Z -rwxr--r-- 1 root root 133456 May 20 18:29 System.Reflection.Emit.dll
2026-07-04T12:59:07.3022534Z -rwxr--r-- 1 root root 15184 May 20 18:30 System.Reflection.Extensions.dll
2026-07-04T12:59:07.3022623Z -rwxr--r-- 1 root root 503632 May 20 18:29 System.Reflection.Metadata.dll
2026-07-04T12:59:07.3022707Z -rwxr--r-- 1 root root 15696 May 20 18:28 System.Reflection.Primitives.dll
2026-07-04T12:59:07.3022794Z -rwxr--r-- 1 root root 24400 May 20 18:31 System.Reflection.TypeExtensions.dll
2026-07-04T12:59:07.3022902Z -rwxr--r-- 1 root root 16208 May 20 18:31 System.Reflection.dll
2026-07-04T12:59:07.3022986Z -rwxr--r-- 1 root root 15184 May 20 18:31 System.Resources.Reader.dll
2026-07-04T12:59:07.3023069Z -rwxr--r-- 1 root root 15696 May 20 18:30 System.Resources.ResourceManager.dll
2026-07-04T12:59:07.3023153Z -rwxr--r-- 1 root root 26960 May 20 18:31 System.Resources.Writer.dll
2026-07-04T12:59:07.3023377Z -rwxr--r-- 1 root root 15184 May 20 18:30 System.Runtime.CompilerServices.Unsafe.dll
2026-07-04T12:59:07.3023472Z -rwxr--r-- 1 root root 17232 May 20 18:30 System.Runtime.CompilerServices.VisualC.dll
2026-07-04T12:59:07.3023557Z -rwxr--r-- 1 root root 17744 May 20 18:30 System.Runtime.Extensions.dll
2026-07-04T12:59:07.3023656Z -rwxr--r-- 1 root root 15696 May 20 18:30 System.Runtime.Handles.dll
2026-07-04T12:59:07.3023754Z -rwxr--r-- 1 root root 89936 May 20 18:31 System.Runtime.InteropServices.JavaScript.dll
2026-07-04T12:59:07.3023845Z -rwxr--r-- 1 root root 15184 May 20 18:31 System.Runtime.InteropServices.RuntimeInformation.dll
2026-07-04T12:59:07.3023932Z -rwxr--r-- 1 root root 64848 May 20 18:29 System.Runtime.InteropServices.dll
2026-07-04T12:59:07.3024221Z -rwxr--r-- 1 root root 17232 May 20 18:29 System.Runtime.Intrinsics.dll
2026-07-04T12:59:07.3024393Z -rwxr--r-- 1 root root 15696 May 20 18:29 System.Runtime.Loader.dll
2026-07-04T12:59:07.3024484Z -rwxr--r-- 1 root root 145232 May 20 18:29 System.Runtime.Numerics.dll
2026-07-04T12:59:07.3024579Z -rwxr--r-- 1 root root 65872 May 20 18:29 System.Runtime.Serialization.Formatters.dll
2026-07-04T12:59:07.3024674Z -rwxr--r-- 1 root root 15696 May 20 18:31 System.Runtime.Serialization.Json.dll
2026-07-04T12:59:07.3024767Z -rwxr--r-- 1 root root 23376 May 20 18:30 System.Runtime.Serialization.Primitives.dll
2026-07-04T12:59:07.3025038Z -rwxr--r-- 1 root root 16720 May 20 18:31 System.Runtime.Serialization.Xml.dll
2026-07-04T12:59:07.3025127Z -rwxr--r-- 1 root root 17232 May 20 18:31 System.Runtime.Serialization.dll
2026-07-04T12:59:07.3025213Z -rwxr--r-- 1 root root 44880 May 20 18:28 System.Runtime.dll
2026-07-04T12:59:07.3025296Z -rwxr--r-- 1 root root 58192 May 20 18:29 System.Security.AccessControl.dll
2026-07-04T12:59:07.3025393Z -rwxr--r-- 1 root root 55120 May 20 18:29 System.Security.Claims.dll
2026-07-04T12:59:07.3025477Z -rwxr--r-- 1 root root 17232 May 20 18:31 System.Security.Cryptography.Algorithms.dll
2026-07-04T12:59:07.3025565Z -rwxr--r-- 1 root root 16208 May 20 18:31 System.Security.Cryptography.Cng.dll
2026-07-04T12:59:07.3025922Z -rwxr--r-- 1 root root 16208 May 20 18:31 System.Security.Cryptography.Csp.dll
2026-07-04T12:59:07.3026035Z -rwxr--r-- 1 root root 15696 May 20 18:31 System.Security.Cryptography.Encoding.dll
2026-07-04T12:59:07.3026508Z -rwxr--r-- 1 root root 15696 May 20 18:31 System.Security.Cryptography.OpenSsl.dll
2026-07-04T12:59:07.3026604Z -rwxr--r-- 1 root root 15696 May 20 18:31 System.Security.Cryptography.Primitives.dll
2026-07-04T12:59:07.3026700Z -rwxr--r-- 1 root root 16720 May 20 18:31 System.Security.Cryptography.X509Certificates.dll
2026-07-04T12:59:07.3026796Z -rwxr--r-- 1 root root 654160 May 20 18:31 System.Security.Cryptography.dll
2026-07-04T12:59:07.3026889Z -rwxr--r-- 1 root root 37712 May 20 18:29 System.Security.Principal.Windows.dll
2026-07-04T12:59:07.3026988Z -rwxr--r-- 1 root root 15184 May 20 18:31 System.Security.Principal.dll
2026-07-04T12:59:07.3027225Z -rwxr--r-- 1 root root 15696 May 20 18:30 System.Security.SecureString.dll
2026-07-04T12:59:07.3027312Z -rwxr--r-- 1 root root 18256 May 20 18:31 System.Security.dll
2026-07-04T12:59:07.3027399Z -rwxr--r-- 1 root root 16720 May 20 18:31 System.ServiceModel.Web.dll
2026-07-04T12:59:07.3027496Z -rwxr--r-- 1 root root 15696 May 20 18:31 System.ServiceProcess.dll
2026-07-04T12:59:07.3027578Z -rwxr--r-- 1 root root 742736 May 20 18:29 System.Text.Encoding.CodePages.dll
2026-07-04T12:59:07.3027663Z -rwxr--r-- 1 root root 15696 May 20 18:28 System.Text.Encoding.Extensions.dll
2026-07-04T12:59:07.3027753Z -rwxr--r-- 1 root root 15696 May 20 18:30 System.Text.Encoding.dll
2026-07-04T12:59:07.3027971Z -rwxr--r-- 1 root root 65872 May 20 18:32 System.Text.Encodings.Web.dll
2026-07-04T12:59:07.3028064Z -rwxr--r-- 1 root root 649040 May 20 18:30 System.Text.Json.dll
2026-07-04T12:59:07.3028143Z -rwxr--r-- 1 root root 384848 May 20 18:30 System.Text.RegularExpressions.dll
2026-07-04T12:59:07.3028244Z -rwxr--r-- 1 root root 33616 May 20 18:29 System.Threading.AccessControl.dll
2026-07-04T12:59:07.3028326Z -rwxr--r-- 1 root root 66384 May 20 18:29 System.Threading.Channels.dll
2026-07-04T12:59:07.3028411Z -rwxr--r-- 1 root root 15696 May 20 18:28 System.Threading.Overlapped.dll
2026-07-04T12:59:07.3028493Z -rwxr--r-- 1 root root 185680 May 20 18:29 System.Threading.Tasks.Dataflow.dll
2026-07-04T12:59:07.3028587Z -rwxr--r-- 1 root root 15696 May 20 18:30 System.Threading.Tasks.Extensions.dll
2026-07-04T12:59:07.3028808Z -rwxr--r-- 1 root root 61264 May 20 18:31 System.Threading.Tasks.Parallel.dll
2026-07-04T12:59:07.3028902Z -rwxr--r-- 1 root root 16720 May 20 18:31 System.Threading.Tasks.dll
2026-07-04T12:59:07.3028994Z -rwxr--r-- 1 root root 15696 May 20 18:28 System.Threading.Thread.dll
2026-07-04T12:59:07.3029076Z -rwxr--r-- 1 root root 15696 May 20 18:28 System.Threading.ThreadPool.dll
2026-07-04T12:59:07.3029160Z -rwxr--r-- 1 root root 15184 May 20 18:30 System.Threading.Timer.dll
2026-07-04T12:59:07.3029262Z -rwxr--r-- 1 root root 44880 May 20 18:28 System.Threading.dll
2026-07-04T12:59:07.3029345Z -rwxr--r-- 1 root root 175952 May 20 18:30 System.Transactions.Local.dll
2026-07-04T12:59:07.3029560Z -rwxr--r-- 1 root root 16720 May 20 18:31 System.Transactions.dll
2026-07-04T12:59:07.3029651Z -rwxr--r-- 1 root root 15696 May 20 18:30 System.ValueTuple.dll
2026-07-04T12:59:07.3029740Z -rwxr--r-- 1 root root 30032 May 20 18:31 System.Web.HttpUtility.dll
2026-07-04T12:59:07.3029838Z -rwxr--r-- 1 root root 15184 May 20 18:31 System.Web.dll
2026-07-04T12:59:07.3029919Z -rwxr--r-- 1 root root 15696 May 20 18:31 System.Windows.dll
2026-07-04T12:59:07.3030002Z -rwxr--r-- 1 root root 15696 May 20 18:31 System.Xml.Linq.dll
2026-07-04T12:59:07.3030083Z -rwxr--r-- 1 root root 21840 May 20 18:30 System.Xml.ReaderWriter.dll
2026-07-04T12:59:07.3030164Z -rwxr--r-- 1 root root 16208 May 20 18:31 System.Xml.Serialization.dll
2026-07-04T12:59:07.3030381Z -rwxr--r-- 1 root root 15696 May 20 18:31 System.Xml.XDocument.dll
2026-07-04T12:59:07.3030479Z -rwxr--r-- 1 root root 15696 May 20 18:31 System.Xml.XPath.XDocument.dll
2026-07-04T12:59:07.3030561Z -rwxr--r-- 1 root root 15696 May 20 18:30 System.Xml.XPath.dll
2026-07-04T12:59:07.3030650Z -rwxr--r-- 1 root root 15696 May 20 18:31 System.Xml.XmlDocument.dll
2026-07-04T12:59:07.3030739Z -rwxr--r-- 1 root root 17744 May 20 18:31 System.Xml.XmlSerializer.dll
2026-07-04T12:59:07.3030822Z -rwxr--r-- 1 root root 23376 May 20 18:31 System.Xml.dll
2026-07-04T12:59:07.3030913Z -rwxr--r-- 1 root root 50000 May 20 18:32 System.dll
2026-07-04T12:59:07.3030995Z -rw-r--r-- 1 root root 156672 Jul 4 12:56 TaxBaik.Application.dll
2026-07-04T12:59:07.3031231Z -rw-r--r-- 1 root root 38468 Jul 4 12:56 TaxBaik.Application.pdb
2026-07-04T12:59:07.3031318Z -rw-r--r-- 1 root root 37888 Jul 4 12:56 TaxBaik.Domain.dll
2026-07-04T12:59:07.3031411Z -rw-r--r-- 1 root root 24100 Jul 4 12:56 TaxBaik.Domain.pdb
2026-07-04T12:59:07.3031494Z -rw-r--r-- 1 root root 713216 Jul 4 12:58 TaxBaik.Web.Client.dll
2026-07-04T12:59:07.3031583Z -rw-r--r-- 1 root root 373136 Jul 4 12:58 TaxBaik.Web.Client.pdb
2026-07-04T12:59:07.3031768Z -rw-r--r-- 1 root root 2546 Jul 4 12:58 TaxBaik.Web.Client.runtimeconfig.json
2026-07-04T12:59:07.3032037Z -rw-r--r-- 1 root root 1007340 Jul 4 12:58 TaxBaik.Web.Client.staticwebassets.endpoints.json
2026-07-04T12:59:07.3032142Z -rw-r--r-- 1 root root 78064 Jul 4 12:58 TaxBaik.Web.Client.staticwebassets.runtime.json
2026-07-04T12:59:07.3032230Z -rwxr--r-- 1 root root 16208 May 20 18:31 WindowsBase.dll
2026-07-04T12:59:07.3032313Z -rwxr--r-- 1 root root 37898 May 20 18:42 dotnet.js
2026-07-04T12:59:07.3032406Z -rwxr--r-- 1 root root 51818 May 20 18:42 dotnet.js.map
2026-07-04T12:59:07.3032485Z -rwxr--r-- 1 root root 145050 May 20 18:43 dotnet.native.js
2026-07-04T12:59:07.3032565Z -rwxr--r-- 1 root root 3002101 May 20 18:43 dotnet.native.wasm
2026-07-04T12:59:07.3032781Z -rwxr--r-- 1 root root 198479 May 20 18:42 dotnet.runtime.js
2026-07-04T12:59:07.3032873Z -rwxr--r-- 1 root root 276757 May 20 18:42 dotnet.runtime.js.map
2026-07-04T12:59:07.3032955Z -rwxr--r-- 1 root root 956416 Apr 2 19:04 icudt_CJK.dat
2026-07-04T12:59:07.3033032Z -rwxr--r-- 1 root root 550832 Apr 2 19:04 icudt_EFIGS.dat
2026-07-04T12:59:07.3033111Z -rwxr--r-- 1 root root 1107168 Apr 2 19:04 icudt_no_CJK.dat
2026-07-04T12:59:07.3033190Z -rwxr--r-- 1 root root 59728 May 20 18:31 mscorlib.dll
2026-07-04T12:59:07.3033269Z -rwxr--r-- 1 root root 100688 May 20 18:32 netstandard.dll
2026-07-04T12:59:07.3033348Z drwxr-xr-x 3 root root 4096 Jul 4 12:58 wwwroot
2026-07-04T12:59:07.3071176Z total 4352
2026-07-04T12:59:07.3071587Z drwxr-xr-x 8 root root 4096 Jul 4 12:58 .
2026-07-04T12:59:07.3071872Z drwxr-xr-x 3 root root 4096 Jul 4 12:58 ..
2026-07-04T12:59:07.3071979Z -rw-r--r-- 1 root root 196 Jul 4 12:58 .NETCoreApp,Version=v10.0.AssemblyAttributes.cs
2026-07-04T12:59:07.3072092Z -rw-r--r-- 1 root root 137 Jul 4 12:58 EmbeddedAttribute.cs
2026-07-04T12:59:07.3072373Z -rw-r--r-- 1 root root 0 Jul 4 12:58 TaxBaik..C36EE7CA.Up2Date
2026-07-04T12:59:07.3072471Z -rw-r--r-- 1 root root 1008 Jul 4 12:58 TaxBaik.Web.Client.AssemblyInfo.cs
2026-07-04T12:59:07.3072582Z -rw-r--r-- 1 root root 65 Jul 4 12:58 TaxBaik.Web.Client.AssemblyInfoInputs.cache
2026-07-04T12:59:07.3072703Z -rw-r--r-- 1 root root 16355 Jul 4 12:58 TaxBaik.Web.Client.GeneratedMSBuildEditorConfig.editorconfig
2026-07-04T12:59:07.3072810Z -rw-r--r-- 1 root root 433 Jul 4 12:58 TaxBaik.Web.Client.GlobalUsings.g.cs
2026-07-04T12:59:07.3072898Z -rw-r--r-- 1 root root 0 Jul 4 12:58 TaxBaik.Web.Client.MvcApplicationPartsAssemblyInfo.cache
2026-07-04T12:59:07.3073143Z -rw-r--r-- 1 root root 27329 Jul 4 12:58 TaxBaik.Web.Client.assets.cache
2026-07-04T12:59:07.3073238Z -rw-r--r-- 1 root root 20456 Jul 4 12:58 TaxBaik.Web.Client.csproj.AssemblyReference.cache
2026-07-04T12:59:07.3073326Z -rw-r--r-- 1 root root 65 Jul 4 12:58 TaxBaik.Web.Client.csproj.CoreCompileInputs.cache
2026-07-04T12:59:07.3073433Z -rw-r--r-- 1 root root 136894 Jul 4 12:58 TaxBaik.Web.Client.csproj.FileListAbsolute.txt
2026-07-04T12:59:07.3073537Z -rw-r--r-- 1 root root 713216 Jul 4 12:58 TaxBaik.Web.Client.dll
2026-07-04T12:59:07.3073640Z -rw-r--r-- 1 root root 65 Jul 4 12:58 TaxBaik.Web.Client.genruntimeconfig.cache
2026-07-04T12:59:07.3073730Z -rw-r--r-- 1 root root 373136 Jul 4 12:58 TaxBaik.Web.Client.pdb
2026-07-04T12:59:07.3073973Z -rw-r--r-- 1 root root 276 Jul 4 12:58 ValidatableTypeAttribute.cs
2026-07-04T12:59:07.3074072Z -rw-r--r-- 1 root root 3 Jul 4 12:58 blazor.build.boot-extension.json
2026-07-04T12:59:07.3074158Z drwxr-xr-x 2 root root 20480 Jul 4 12:58 compressed
2026-07-04T12:59:07.3074258Z -rw-r--r-- 1 root root 93392 Jul 4 12:58 dotnet.js
2026-07-04T12:59:07.3074339Z -rw-r--r-- 1 root root 276577 Jul 4 12:58 rbcswa.dswa.cache.json
2026-07-04T12:59:07.3074420Z drwxr-xr-x 2 root root 4096 Jul 4 12:58 ref
2026-07-04T12:59:07.3074500Z drwxr-xr-x 2 root root 4096 Jul 4 12:58 refint
2026-07-04T12:59:07.3074734Z -rw-r--r-- 1 root root 327 Jul 4 12:58 rjimswa.dswa.cache.json
2026-07-04T12:59:07.3074829Z -rw-r--r-- 1 root root 3434 Jul 4 12:58 rjsmcshtml.dswa.cache.json
2026-07-04T12:59:07.3074912Z -rw-r--r-- 1 root root 3434 Jul 4 12:58 rjsmrazor.dswa.cache.json
2026-07-04T12:59:07.3074999Z -rw-r--r-- 1 root root 4208 Jul 4 12:58 rpswa.dswa.cache.json
2026-07-04T12:59:07.3075082Z drwxr-xr-x 2 root root 4096 Jul 4 12:58 staticwebassets
2026-07-04T12:59:07.3075161Z -rw-r--r-- 1 root root 1007340 Jul 4 12:58 staticwebassets.build.endpoints.json
2026-07-04T12:59:07.3075247Z -rw-r--r-- 1 root root 1564906 Jul 4 12:58 staticwebassets.build.json
2026-07-04T12:59:07.3075331Z -rw-r--r-- 1 root root 44 Jul 4 12:58 staticwebassets.build.json.cache
2026-07-04T12:59:07.3075530Z -rw-r--r-- 1 root root 78064 Jul 4 12:58 staticwebassets.development.json
2026-07-04T12:59:07.3075619Z -rw-r--r-- 1 root root 0 Jul 4 12:58 swae.build.ex.cache
2026-07-04T12:59:07.3075707Z drwxr-xr-x 2 root root 4096 Jul 4 12:58 tmp-webcil
2026-07-04T12:59:07.3075785Z drwxr-xr-x 2 root root 20480 Jul 4 12:58 webcil
2026-07-04T13:01:22.5627758Z ✓ Publish Web elapsed: 193s
2026-07-04T13:01:22.5646529Z -rw-r--r-- 1 root root 2.2M Jul 4 13:01 ./publish-logs/publish-web.binlog
2026-07-04T13:01:22.6880698Z ::group::Run set -e
2026-07-04T13:01:22.6881027Z set -e
2026-07-04T13:01:22.6881197Z mkdir -p ./publish-logs
2026-07-04T13:01:22.6881283Z # Proxy is not part of the solution restore graph, so restore it once
2026-07-04T13:01:22.6881372Z # here before publishing to avoid NETSDK1004 in CI.
2026-07-04T13:01:22.6881469Z dotnet restore src/TaxBaik.Proxy/
2026-07-04T13:01:22.6881543Z dotnet build src/TaxBaik.Proxy/TaxBaik.Proxy.csproj -c Release --no-restore
2026-07-04T13:01:22.6881631Z start=$(date +%s)
2026-07-04T13:01:22.6881698Z dotnet publish src/TaxBaik.Proxy/ \
2026-07-04T13:01:22.6881795Z -c Release \
2026-07-04T13:01:22.6882017Z -o ./publish/proxy \
2026-07-04T13:01:22.6882108Z --no-restore \
2026-07-04T13:01:22.6882193Z --no-build \
2026-07-04T13:01:22.6882265Z -p:PublishReadyToRun=false \
2026-07-04T13:01:22.6882334Z -p:PerformanceSummary=true \
2026-07-04T13:01:22.6882404Z -clp:Summary \
2026-07-04T13:01:22.6882495Z -bl:./publish-logs/publish-proxy.binlog
2026-07-04T13:01:22.6882564Z end=$(date +%s)
2026-07-04T13:01:22.6882635Z echo "✓ Publish Proxy elapsed: $((end - start))s"
2026-07-04T13:01:22.6882738Z ls -lh ./publish-logs/publish-proxy.binlog
2026-07-04T13:01:22.6882814Z shell: bash --noprofile --norc -e -o pipefail {0}
2026-07-04T13:01:22.6882907Z ::endgroup::
2026-07-04T13:01:24.3061500Z Determining projects to restore...
2026-07-04T13:01:24.9616018Z Restored /workspace/***/taxbaik/src/TaxBaik.Proxy/TaxBaik.Proxy.csproj (in 156 ms).
2026-07-04T13:01:26.9924481Z TaxBaik.Proxy -> /workspace/***/taxbaik/src/TaxBaik.Proxy/bin/Release/net10.0/TaxBaik.Proxy.dll
2026-07-04T13:01:27.0997744Z
2026-07-04T13:01:27.1028989Z Build succeeded.
2026-07-04T13:01:27.1047131Z 0 Warning(s)
2026-07-04T13:01:27.1047398Z 0 Error(s)
2026-07-04T13:01:27.1047541Z
2026-07-04T13:01:27.1047621Z Time Elapsed 00:00:01.55
2026-07-04T13:01:28.9796929Z TaxBaik.Proxy -> /workspace/***/taxbaik/publish/proxy/
2026-07-04T13:01:29.0117388Z
2026-07-04T13:01:29.0137929Z Build succeeded.
2026-07-04T13:01:29.0142336Z 0 Warning(s)
2026-07-04T13:01:29.0144041Z 0 Error(s)
2026-07-04T13:01:29.0147048Z
2026-07-04T13:01:29.0149487Z Time Elapsed 00:00:01.04
2026-07-04T13:01:29.0760476Z ✓ Publish Proxy elapsed: 2s
2026-07-04T13:01:29.0761097Z -rw-r--r-- 1 root root 335K Jul 4 13:01 ./publish-logs/publish-proxy.binlog
2026-07-04T13:01:29.2472841Z ::group::Run set -e
2026-07-04T13:01:29.2473270Z set -e
2026-07-04T13:01:29.2473414Z JWT_SECRET_KEY="***"
2026-07-04T13:01:29.2473519Z TELEGRAM_BOT_TOKEN="***"
2026-07-04T13:01:29.2473612Z TELEGRAM_CHAT_ID="***"
2026-07-04T13:01:29.2473691Z TELEGRAM_INQUIRY_CHAT_ID=""
2026-07-04T13:01:29.2473786Z TELEGRAM_SYSTEM_CHAT_ID=""
2026-07-04T13:01:29.2473869Z [ -z "$JWT_SECRET_KEY" ] && { echo "Missing TAXBAIK_JWT_SECRET_KEY" >&2; exit 1; }
2026-07-04T13:01:29.2473974Z [ -z "$TELEGRAM_BOT_TOKEN" ] && { echo "Missing TAXBAIK_TELEGRAM_BOT_TOKEN" >&2; exit 1; }
2026-07-04T13:01:29.2474063Z [ -z "$TELEGRAM_CHAT_ID" ] && { echo "Missing TAXBAIK_TELEGRAM_CHAT_ID" >&2; exit 1; }
2026-07-04T13:01:29.2474147Z [ -z "$TELEGRAM_INQUIRY_CHAT_ID" ] && TELEGRAM_INQUIRY_CHAT_ID="$TELEGRAM_CHAT_ID"
2026-07-04T13:01:29.2474240Z [ -z "$TELEGRAM_SYSTEM_CHAT_ID" ] && TELEGRAM_SYSTEM_CHAT_ID="-5585148480"
2026-07-04T13:01:29.2474325Z JWT_SECRET_KEY="$JWT_SECRET_KEY" \
2026-07-04T13:01:29.2474401Z TELEGRAM_BOT_TOKEN="$TELEGRAM_BOT_TOKEN" \
2026-07-04T13:01:29.2474541Z TELEGRAM_CHAT_ID="$TELEGRAM_CHAT_ID" \
2026-07-04T13:01:29.2474616Z TELEGRAM_INQUIRY_CHAT_ID="$TELEGRAM_INQUIRY_CHAT_ID" \
2026-07-04T13:01:29.2474692Z TELEGRAM_SYSTEM_CHAT_ID="$TELEGRAM_SYSTEM_CHAT_ID" \
2026-07-04T13:01:29.2474783Z python3 -c '
2026-07-04T13:01:29.2474854Z import json, os, pathlib
2026-07-04T13:01:29.2474933Z pathlib.Path("./publish/appsettings.Production.json").write_text(
2026-07-04T13:01:29.2475012Z json.dumps({
2026-07-04T13:01:29.2475107Z "Jwt": {"SecretKey": os.environ["JWT_SECRET_KEY"]},
2026-07-04T13:01:29.2475203Z "Telegram": {
2026-07-04T13:01:29.2475275Z "BotToken": os.environ["TELEGRAM_BOT_TOKEN"],
2026-07-04T13:01:29.2475367Z "ChatId": os.environ["TELEGRAM_CHAT_ID"],
2026-07-04T13:01:29.2475442Z "InquiryChatId": os.environ["TELEGRAM_INQUIRY_CHAT_ID"],
2026-07-04T13:01:29.2475513Z "SystemChatId": os.environ["TELEGRAM_SYSTEM_CHAT_ID"]
2026-07-04T13:01:29.2475584Z }
2026-07-04T13:01:29.2475671Z }, ensure_ascii=False, indent=2),
2026-07-04T13:01:29.2475739Z encoding="utf-8"
2026-07-04T13:01:29.2475812Z )'
2026-07-04T13:01:29.2475895Z test -s ./publish/appsettings.Production.json || { echo "appsettings.Production.json is empty" >&2; exit 1; }
2026-07-04T13:01:29.2475995Z shell: bash --noprofile --norc -e -o pipefail {0}
2026-07-04T13:01:29.2476277Z ::endgroup::
2026-07-04T13:01:29.5445729Z ::group::Run test -s ./publish/proxy/TaxBaik.Proxy.dll || { echo "TaxBaik.Proxy.dll missing" >&2; exit 1; }
2026-07-04T13:01:29.5446479Z test -s ./publish/proxy/TaxBaik.Proxy.dll || { echo "TaxBaik.Proxy.dll missing" >&2; exit 1; }
2026-07-04T13:01:29.5446656Z test -s ./publish/proxy/TaxBaik.Proxy.runtimeconfig.json || { echo "TaxBaik.Proxy.runtimeconfig.json missing" >&2; exit 1; }
2026-07-04T13:01:29.5446772Z shell: bash --noprofile --norc -e -o pipefail {0}
2026-07-04T13:01:29.5446901Z ::endgroup::
2026-07-04T13:01:29.7396976Z ::group::Run mkdir -p ./publish/db && cp -r db/migrations ./publish/db/ || true
2026-07-04T13:01:29.7397352Z mkdir -p ./publish/db && cp -r db/migrations ./publish/db/ || true
2026-07-04T13:01:29.7397484Z shell: bash --noprofile --norc -e -o pipefail {0}
2026-07-04T13:01:29.7397589Z ::endgroup::
2026-07-04T13:01:30.0169769Z ::group::Run bash scripts/validate_migrations.sh db/migrations
2026-07-04T13:01:30.0170284Z bash scripts/validate_migrations.sh db/migrations
2026-07-04T13:01:30.0170495Z shell: bash --noprofile --norc -e -o pipefail {0}
2026-07-04T13:01:30.0170623Z ::endgroup::
2026-07-04T13:01:30.1873738Z Duplicate version check passed.
2026-07-04T13:01:30.3350394Z ::group::Run bash scripts/validate_kst_timestamps.sh
2026-07-04T13:01:30.3350747Z bash scripts/validate_kst_timestamps.sh
2026-07-04T13:01:30.3350854Z shell: bash --noprofile --norc -e -o pipefail {0}
2026-07-04T13:01:30.3350983Z ::endgroup::
2026-07-04T13:01:30.4075762Z KST timestamp harness passed.
2026-07-04T13:01:30.5339955Z ::group::Run COMMIT_HASH=$(git rev-parse --short HEAD)
2026-07-04T13:01:30.5340420Z COMMIT_HASH=$(git rev-parse --short HEAD)
2026-07-04T13:01:30.5340542Z BUILD_TIME=$(TZ=Asia/Seoul date +'%Y-%m-%d %H:%M:%S KST')
2026-07-04T13:01:30.5340635Z mkdir -p ./publish/wwwroot
2026-07-04T13:01:30.5340751Z printf '{\n "version": "%s",\n "built": "%s"\n}\n' "$COMMIT_HASH" "$BUILD_TIME" > ./publish/wwwroot/version.json
2026-07-04T13:01:30.5340864Z echo "✓ Build: $COMMIT_HASH @ $BUILD_TIME"
2026-07-04T13:01:30.5340985Z shell: bash --noprofile --norc -e -o pipefail {0}
2026-07-04T13:01:30.5341090Z ::endgroup::
2026-07-04T13:01:30.5999292Z ✓ Build: c00d237 @ 2026-07-04 22:01:30 KST
2026-07-04T13:01:30.7264039Z ::group::Run mkdir -p ~/.ssh
2026-07-04T13:01:30.7264431Z mkdir -p ~/.ssh
2026-07-04T13:01:30.7264604Z SSH_KEY_B64="***"
2026-07-04T13:01:30.7264799Z SSH_KEY_RAW="***"
2026-07-04T13:01:30.7265065Z if [ -n "$SSH_KEY_B64" ]; then
2026-07-04T13:01:30.7265231Z printf '%s' "$SSH_KEY_B64" | base64 -d > ~/.ssh/id_ed25519
2026-07-04T13:01:30.7265382Z elif [ -n "$SSH_KEY_RAW" ]; then
2026-07-04T13:01:30.7265513Z if printf '%s' "$SSH_KEY_RAW" | grep -q 'BEGIN .*PRIVATE KEY'; then
2026-07-04T13:01:30.7265665Z printf '%b\n' "$SSH_KEY_RAW" > ~/.ssh/id_ed25519
2026-07-04T13:01:30.7265813Z else
2026-07-04T13:01:30.7265955Z printf '%s' "$SSH_KEY_RAW" | base64 -d > ~/.ssh/id_ed25519
2026-07-04T13:01:30.7266448Z fi
2026-07-04T13:01:30.7266624Z else
2026-07-04T13:01:30.7266747Z echo "Missing DEPLOY_SSH_KEY_B64 or DEPLOY_SSH_KEY" >&2; exit 1
2026-07-04T13:01:30.7266892Z fi
2026-07-04T13:01:30.7267009Z sed -i 's/\r$//' ~/.ssh/id_ed25519
2026-07-04T13:01:30.7267138Z chmod 600 ~/.ssh/id_ed25519
2026-07-04T13:01:30.7267222Z ssh-keyscan -H "***" >> ~/.ssh/known_hosts 2>/dev/null || true
2026-07-04T13:01:30.7267363Z shell: bash --noprofile --norc -e -o pipefail {0}
2026-07-04T13:01:30.7267559Z ::endgroup::
2026-07-04T13:01:31.3915758Z ::group::Run cp deploy_gb.sh ./publish/deploy_gb.sh
2026-07-04T13:01:31.3916326Z cp deploy_gb.sh ./publish/deploy_gb.sh
2026-07-04T13:01:31.3916448Z mkdir -p ./publish/scripts
2026-07-04T13:01:31.3916532Z cp scripts/validate_migrations.sh ./publish/scripts/validate_migrations.sh
2026-07-04T13:01:31.3916629Z chmod +x ./publish/scripts/validate_migrations.sh
2026-07-04T13:01:31.3916706Z tar -czf taxbaik_deploy.tgz -C ./publish .
2026-07-04T13:01:31.3916791Z echo "✓ Package: $(du -sh taxbaik_deploy.tgz | cut -f1)"
2026-07-04T13:01:31.3916894Z shell: bash --noprofile --norc -e -o pipefail {0}
2026-07-04T13:01:31.3916989Z ::endgroup::
2026-07-04T13:01:34.5550762Z ✓ Package: 23M
2026-07-04T13:01:34.6596310Z ::group::Run set -e
2026-07-04T13:01:34.6596644Z set -e
2026-07-04T13:01:34.6596755Z export TAXBAIK_DEPLOY_FROM_CI=1
2026-07-04T13:01:34.6596854Z TIMESTAMP=$(TZ=Asia/Seoul date +%Y%m%d_%H%M%S)
2026-07-04T13:01:34.6596935Z COMMIT=$(git rev-parse --short HEAD)
2026-07-04T13:01:34.6597016Z DEPLOY_HOST="***"
2026-07-04T13:01:34.6597103Z DEPLOY_USER="***"
2026-07-04T13:01:34.6597300Z TELEGRAM_BOT_TOKEN="***"
2026-07-04T13:01:34.6597384Z TELEGRAM_SYSTEM_CHAT_ID=""
2026-07-04T13:01:34.6597460Z TELEGRAM_CHAT_ID="${TELEGRAM_SYSTEM_CHAT_ID:--5585148480}"
2026-07-04T13:01:34.6597556Z
2026-07-04T13:01:34.6597626Z send_telegram() {
2026-07-04T13:01:34.6597703Z local text="$1"
2026-07-04T13:01:34.6597779Z if [ -z "$TELEGRAM_BOT_TOKEN" ]; then
2026-07-04T13:01:34.6597884Z echo "Skipping Telegram notification: missing TAXBAIK_TELEGRAM_BOT_TOKEN" >&2
2026-07-04T13:01:34.6597983Z return 0
2026-07-04T13:01:34.6598050Z fi
2026-07-04T13:01:34.6598129Z
2026-07-04T13:01:34.6598193Z curl -fsS -X POST "https://api.telegram.org/bot${TELEGRAM_BOT_TOKEN}/sendMessage" \
2026-07-04T13:01:34.6598278Z -d "chat_id=${TELEGRAM_CHAT_ID}" \
2026-07-04T13:01:34.6598353Z --data-urlencode "text=${text}" \
2026-07-04T13:01:34.6598442Z -d "parse_mode=HTML" >/dev/null || true
2026-07-04T13:01:34.6598515Z }
2026-07-04T13:01:34.6598583Z
2026-07-04T13:01:34.6598655Z notify_failure() {
2026-07-04T13:01:34.6598728Z local exit_code=$?
2026-07-04T13:01:34.6598798Z send_telegram "❌ <b>TaxBaik 배포 실패</b>
2026-07-04T13:01:34.6598890Z
2026-07-04T13:01:34.6598968Z 커밋: <code>${COMMIT}</code>
2026-07-04T13:01:34.6599054Z 시간: <code>${TIMESTAMP}</code>
2026-07-04T13:01:34.6599132Z 단계: CI/CD deploy"
2026-07-04T13:01:34.6599222Z exit "$exit_code"
2026-07-04T13:01:34.6599293Z }
2026-07-04T13:01:34.6599355Z
2026-07-04T13:01:34.6599452Z trap notify_failure ERR
2026-07-04T13:01:34.6599539Z
2026-07-04T13:01:34.6599604Z echo "=== Deploying TaxBaik $COMMIT ($TIMESTAMP) ==="
2026-07-04T13:01:34.6599681Z
2026-07-04T13:01:34.6599753Z # 1. 아티팩트 업로드
2026-07-04T13:01:34.6599828Z scp -i ~/.ssh/id_ed25519 -o StrictHostKeyChecking=yes \
2026-07-04T13:01:34.6599908Z taxbaik_deploy.tgz "$DEPLOY_USER@$DEPLOY_HOST:/tmp/taxbaik_${TIMESTAMP}.tgz"
2026-07-04T13:01:34.6599993Z
2026-07-04T13:01:34.6600070Z # 2. 서버에서 배포 + 헬스 체크 (SSH 1회 연결로 처리, Green-Blue 지원)
2026-07-04T13:01:34.6600159Z ssh -i ~/.ssh/id_ed25519 -o StrictHostKeyChecking=yes \
2026-07-04T13:01:34.6600240Z -o ServerAliveInterval=10 \
2026-07-04T13:01:34.6600323Z "$DEPLOY_USER@$DEPLOY_HOST" TAXBAIK_DEPLOY_FROM_CI=1 bash << REMOTE
2026-07-04T13:01:34.6600403Z set -e
2026-07-04T13:01:34.6600473Z DEPLOY_HOME="/home/***"
2026-07-04T13:01:34.6600555Z DEPLOY_DIR="\$DEPLOY_HOME/deployments/taxbaik_${TIMESTAMP}"
2026-07-04T13:01:34.6600671Z TIMESTAMP="${TIMESTAMP}"
2026-07-04T13:01:34.6600741Z COMMIT="${COMMIT}"
2026-07-04T13:01:34.6600810Z
2026-07-04T13:01:34.6600871Z echo "--- [1/5] 압축 해제 ---"
2026-07-04T13:01:34.6600946Z mkdir -p "\$DEPLOY_DIR"
2026-07-04T13:01:34.6601017Z tar -xzf "/tmp/taxbaik_\${TIMESTAMP}.tgz" -C "\$DEPLOY_DIR"
2026-07-04T13:01:34.6601091Z rm -f "/tmp/taxbaik_\${TIMESTAMP}.tgz"
2026-07-04T13:01:34.6601165Z
2026-07-04T13:01:34.6601224Z echo "--- [2/5] 운영 설정 검증 ---"
2026-07-04T13:01:34.6601302Z test -s "\$DEPLOY_DIR/appsettings.Production.json" \
2026-07-04T13:01:34.6601375Z || { echo "FATAL: appsettings.Production.json 없음" >&2; exit 1; }
2026-07-04T13:01:34.6601452Z test -s "\$DEPLOY_DIR/proxy/TaxBaik.Proxy.dll" \
2026-07-04T13:01:34.6601525Z || { echo "FATAL: TaxBaik.Proxy.dll 없음" >&2; exit 1; }
2026-07-04T13:01:34.6601608Z
2026-07-04T13:01:34.6601676Z echo "--- [3/5] 마이그레이션 사전 검증 ---"
2026-07-04T13:01:34.6601750Z test -x "\$DEPLOY_DIR/scripts/validate_migrations.sh" \
2026-07-04T13:01:34.6601824Z || { echo "FATAL: validate_migrations.sh 없음" >&2; exit 1; }
2026-07-04T13:01:34.6602022Z "\$DEPLOY_DIR/scripts/validate_migrations.sh" "\$DEPLOY_DIR/db/migrations" "postgresql://taxbaik:taxbaik123@localhost:5432/taxbaikdb"
2026-07-04T13:01:34.6602131Z
2026-07-04T13:01:34.6602198Z echo "--- [4/5] Green-Blue 배포 실행 ---"
2026-07-04T13:01:34.6602279Z chmod +x "\$DEPLOY_DIR/deploy_gb.sh"
2026-07-04T13:01:34.6602356Z "\$DEPLOY_DIR/deploy_gb.sh" "\$DEPLOY_DIR"
2026-07-04T13:01:34.6602427Z
2026-07-04T13:01:34.6602489Z echo "--- [4.5/5] Nginx 설정 검증 ---"
2026-07-04T13:01:34.6602561Z # 실제 로드되는 파일은 sites-enabled/의 심볼릭 링크 대상만이다.
2026-07-04T13:01:34.6602644Z # sites-available/에 다른 파일(예: default)이 있어도 sites-enabled에
2026-07-04T13:01:34.6602727Z # 링크되어 있지 않으면 nginx는 그 내용을 절대 읽지 않는다.
2026-07-04T13:01:34.6602804Z NGINX_CONF=""
2026-07-04T13:01:34.6602878Z for f in /etc/nginx/sites-enabled/*; do
2026-07-04T13:01:34.6602947Z if [ -e "\$f" ] && grep -q "location /taxbaik" "\$f" 2>/dev/null; then
2026-07-04T13:01:34.6603031Z NGINX_CONF=\$(readlink -f "\$f")
2026-07-04T13:01:34.6603100Z break
2026-07-04T13:01:34.6603168Z fi
2026-07-04T13:01:34.6603237Z done
2026-07-04T13:01:34.6603297Z
2026-07-04T13:01:34.6603360Z if [ -z "\$NGINX_CONF" ]; then
2026-07-04T13:01:34.6603428Z echo "❌ FATAL: sites-enabled/ 안에서 'location /taxbaik'를 정의한 파일을 찾을 수 없음" >&2
2026-07-04T13:01:34.6603520Z echo " sites-available/에 파일을 수정해도 sites-enabled에 심볼릭 링크되어 있지 않으면 반영되지 않는다." >&2
2026-07-04T13:01:34.6603616Z exit 1
2026-07-04T13:01:34.6603681Z fi
2026-07-04T13:01:34.6603749Z echo "실제 로드되는 설정 파일: \$NGINX_CONF"
2026-07-04T13:01:34.6603826Z
2026-07-04T13:01:34.6603893Z # 불변식: '/'와 '/taxbaik' location 모두 반드시 127.0.0.1:5001 (TaxBaik.Proxy)을
2026-07-04T13:01:34.6603979Z # 가리켜야 한다. 5003/5004를 직접 하드코딩하면 Green-Blue 포트 전환 시
2026-07-04T13:01:34.6604062Z # 죽은 포트를 가리키게 되어 502/404가 발생한다 (실제 발생했던 장애).
2026-07-04T13:01:34.6604145Z if grep -E "proxy_pass\s+http://127\.0\.0\.1:500[34]" "\$NGINX_CONF" > /dev/null 2>&1; then
2026-07-04T13:01:34.6604235Z echo "❌ FATAL: \$NGINX_CONF 가 포트 5003/5004를 직접 참조함 (Green-Blue 전환 시 502 발생)" >&2
2026-07-04T13:01:34.6604332Z echo " 수정: sudo sed -i 's|127.0.0.1:500[34]|127.0.0.1:5001|g' \$NGINX_CONF && sudo nginx -t && sudo systemctl reload nginx" >&2
2026-07-04T13:01:34.6604421Z exit 1
2026-07-04T13:01:34.6604491Z fi
2026-07-04T13:01:34.6604558Z
2026-07-04T13:01:34.6604619Z # proxy_pass에 URI(끝 슬래시)가 있으면 nginx가 요청 경로를 재작성하며,
2026-07-04T13:01:34.6607916Z # location 접두사와 슬래시 개수가 안 맞으면 백엔드로 이중 슬래시(//)가
2026-07-04T13:01:34.6608040Z # 전달되어 404가 발생한다 (실제 발생했던 장애). 접두사 location에서는
2026-07-04T13:01:34.6608133Z # proxy_pass에 URI를 붙이지 않는다.
2026-07-04T13:01:34.6608233Z if grep -E "location\s+/taxbaik\s*\{" -A 1 "\$NGINX_CONF" | grep -qE "proxy_pass\s+http://127\.0\.0\.1:5001/;"; then
2026-07-04T13:01:34.6608347Z echo "❌ FATAL: location /taxbaik 의 proxy_pass 에 불필요한 trailing slash가 있음 (이중 슬래시로 인한 404 위험)" >&2
2026-07-04T13:01:34.6608443Z exit 1
2026-07-04T13:01:34.6608513Z fi
2026-07-04T13:01:34.6608578Z
2026-07-04T13:01:34.6608647Z echo "✓ Nginx 설정 검증 통과 (실제 로드 파일 확인 + 포트 5001 고정 + trailing slash 없음)"
2026-07-04T13:01:34.6608736Z
2026-07-04T13:01:34.6608799Z echo "--- [5/5] 헬스 체크 (최대 60초) ---"
2026-07-04T13:01:34.6608888Z ATTEMPTS=20
2026-07-04T13:01:34.6608968Z for i in \$(seq 1 \$ATTEMPTS); do
2026-07-04T13:01:34.6609044Z STATUS=\$(curl -sf -o /dev/null -w '%{http_code}' http://127.0.0.1:5001/taxbaik/healthz 2>/dev/null || echo "000")
2026-07-04T13:01:34.6609143Z if [ "\$STATUS" = "200" ]; then
2026-07-04T13:01:34.6609218Z echo "✓ [1/6] 헬스 체크 완료"
2026-07-04T13:01:34.6609291Z
2026-07-04T13:01:34.6609353Z # 검증 1: 메인 페이지 로드. curl -L + -w 는 리다이렉트 체인의 상태코드를
2026-07-04T13:01:34.6609448Z # 이어붙이므로, 첫 응답 코드만 받아 200/3xx를 허용한다.
2026-07-04T13:01:34.6609531Z MAIN_STATUS=\$(curl -fsS -o /dev/null -w '%{http_code}' http://127.0.0.1:5001/taxbaik/ 2>/dev/null || echo "000")
2026-07-04T13:01:34.6609626Z if ! printf '%s' "\$MAIN_STATUS" | grep -Eq '^(200|301|302|307|308)$'; then
2026-07-04T13:01:34.6609715Z echo "❌ 메인 페이지 로드 실패 (상태: \$MAIN_STATUS)" >&2
2026-07-04T13:01:34.6609801Z exit 1
2026-07-04T13:01:34.6609869Z fi
2026-07-04T13:01:34.6609935Z echo "✓ [2/6] 메인 페이지 로드 완료"
2026-07-04T13:01:34.6610016Z
2026-07-04T13:01:34.6610077Z # 검증 2: CSS 파일 로드
2026-07-04T13:01:34.6610147Z CSS_STATUS=\$(curl -sf -o /dev/null -w '%{http_code}' http://127.0.0.1:5001/taxbaik/css/admin.css 2>/dev/null || echo "000")
2026-07-04T13:01:34.6610236Z if [ "\$CSS_STATUS" != "200" ]; then
2026-07-04T13:01:34.6610312Z echo "❌ CSS 파일 로드 실패 (상태: \$CSS_STATUS)" >&2
2026-07-04T13:01:34.6610402Z exit 1
2026-07-04T13:01:34.6610470Z fi
2026-07-04T13:01:34.6610544Z echo "✓ [3/6] CSS 파일 로드 완료"
2026-07-04T13:01:34.6610621Z
2026-07-04T13:01:34.6610685Z # 검증 3: 버전 정보. 파일 존재만 보면 5001이 잘못된 구 프로세스를
2026-07-04T13:01:34.6610769Z # 가리키는 장애를 놓치므로, HTTP 응답이 이번 커밋인지 확인한다.
2026-07-04T13:01:34.6610858Z if [ ! -s "\$DEPLOY_DIR/wwwroot/version.json" ]; then
2026-07-04T13:01:34.6610939Z echo "❌ version.json 누락" >&2
2026-07-04T13:01:34.6611026Z exit 1
2026-07-04T13:01:34.6611104Z fi
2026-07-04T13:01:34.6611170Z VERSION_JSON=\$(curl -fsS http://127.0.0.1:5001/taxbaik/version.json 2>/dev/null || true)
2026-07-04T13:01:34.6611253Z if ! printf '%s' "\$VERSION_JSON" | grep -q "\"version\": \"\$COMMIT\""; then
2026-07-04T13:01:34.6611332Z echo "❌ 5001 프록시가 이번 배포 버전을 제공하지 않음" >&2
2026-07-04T13:01:34.6611415Z echo " expected: \$COMMIT" >&2
2026-07-04T13:01:34.6611490Z echo " actual: \$VERSION_JSON" >&2
2026-07-04T13:01:34.6611563Z echo " 확인: 5001 포트가 TaxBaik.Proxy.dll인지, /home/***/taxbaik_port가 새 포트인지 점검" >&2
2026-07-04T13:01:34.6611663Z exit 1
2026-07-04T13:01:34.6611729Z fi
2026-07-04T13:01:34.6611794Z echo "✓ [4/6] 버전 정보 확인 완료"
2026-07-04T13:01:34.6612039Z
2026-07-04T13:01:34.6612103Z # 검증 4: 5001 프록시 확인
2026-07-04T13:01:34.6612177Z if ! ss -tlnp | grep -q ':5001 '; then
2026-07-04T13:01:34.6612250Z echo "❌ 5001 프록시가 실행 중이 아님" >&2
2026-07-04T13:01:34.6612338Z exit 1
2026-07-04T13:01:34.6612405Z fi
2026-07-04T13:01:34.6612476Z echo "✓ [5/6] 5001 프록시 확인 완료"
2026-07-04T13:01:34.6612558Z
2026-07-04T13:01:34.6612622Z # 검증 5: 관리자 로그인 페이지
2026-07-04T13:01:34.6612698Z LOGIN_STATUS=\$(curl -fsSL -o /dev/null -w '%{http_code}' http://127.0.0.1:5001/taxbaik/admin/login 2>/dev/null || echo "000")
2026-07-04T13:01:34.6612790Z if [ "\$LOGIN_STATUS" != "200" ]; then
2026-07-04T13:01:34.6612871Z echo "❌ 관리자 로그인 페이지 로드 실패 (상태: \$LOGIN_STATUS)" >&2
2026-07-04T13:01:34.6612964Z exit 1
2026-07-04T13:01:34.6613037Z fi
2026-07-04T13:01:34.6613099Z echo "✓ [6/6] 관리자 페이지 로드 완료"
2026-07-04T13:01:34.6613182Z
2026-07-04T13:01:34.6613243Z echo "✓ 서비스 정상 (시도 \$i/\$ATTEMPTS)"
2026-07-04T13:01:34.6613322Z # 구 배포 디렉토리 정리 (최근 5개 보존)
2026-07-04T13:01:34.6613401Z ls -1dt \$DEPLOY_HOME/deployments/taxbaik_* 2>/dev/null \
2026-07-04T13:01:34.6613481Z | tail -n +6 | xargs rm -rf 2>/dev/null || true
2026-07-04T13:01:34.6613557Z exit 0
2026-07-04T13:01:34.6613622Z fi
2026-07-04T13:01:34.6613692Z if [ "\$i" -eq "\$ATTEMPTS" ]; then
2026-07-04T13:01:34.6613767Z echo "=== FATAL: 서비스가 \$ATTEMPTS회 시도 후에도 응답하지 않음 ===" >&2
2026-07-04T13:01:34.6613858Z echo "--- 5001 listener ---" >&2
2026-07-04T13:01:34.6613947Z ss -tlnp 2>/dev/null | grep ':5001 ' >&2 || true
2026-07-04T13:01:34.6614022Z echo "--- active port file ---" >&2
2026-07-04T13:01:34.6614102Z cat "\$DEPLOY_HOME/taxbaik_port" >&2 || true
2026-07-04T13:01:34.6614174Z echo "--- 신규 앱 로그 ---" >&2
2026-07-04T13:01:34.6614245Z ACTIVE_PORT=\$(cat "\$DEPLOY_HOME/taxbaik_port" 2>/dev/null | tr -d '[:space:]' || true)
2026-07-04T13:01:34.6614329Z if [ -n "\$ACTIVE_PORT" ] && [ -s "\$DEPLOY_DIR/web_\${ACTIVE_PORT}.log" ]; then
2026-07-04T13:01:34.6614409Z tail -n 80 "\$DEPLOY_DIR/web_\${ACTIVE_PORT}.log" >&2
2026-07-04T13:01:34.6614489Z else
2026-07-04T13:01:34.6614554Z ls -la "\$DEPLOY_DIR" >&2 || true
2026-07-04T13:01:34.6614626Z fi
2026-07-04T13:01:34.6614690Z echo "--- proxy 로그 ---" >&2
2026-07-04T13:01:34.6614764Z tail -n 80 "\$DEPLOY_HOME/taxbaik_proxy.log" >&2 || true
2026-07-04T13:01:34.6614848Z exit 1
2026-07-04T13:01:34.6614917Z fi
2026-07-04T13:01:34.6614986Z echo " 대기 중... (\$i/\$ATTEMPTS, HTTP \$STATUS)"
2026-07-04T13:01:34.6615062Z sleep 3
2026-07-04T13:01:34.6615131Z done
2026-07-04T13:01:34.6615194Z REMOTE
2026-07-04T13:01:34.6615256Z
2026-07-04T13:01:34.6615315Z echo "✓ 배포 완료: taxbaik_${TIMESTAMP} @ $DEPLOY_HOST"
2026-07-04T13:01:34.6615389Z
2026-07-04T13:01:34.6615454Z echo "--- 실제 공개 도메인 종단 간 검증 (Nginx/Cloudflare 경유, 최대 3회 재시도) ---"
2026-07-04T13:01:34.6615540Z ROOT_URL="https://www.taxbaik.com/" \
2026-07-04T13:01:34.6615611Z ADMIN_URL="https://www.taxbaik.com/taxbaik/admin/login" \
2026-07-04T13:01:34.6615686Z PUBLIC_MARKER="백원숙 세무회계" \
2026-07-04T13:01:34.6615758Z PUBLIC_FORBIDDEN="관리자" \
2026-07-04T13:01:34.6615829Z ADMIN_MARKER="관리자 로그인" \
2026-07-04T13:01:34.6615900Z MAX_RETRIES=3 \
2026-07-04T13:01:34.6615976Z RETRY_SLEEP_SECONDS=5 \
2026-07-04T13:01:34.6616044Z bash ./scripts/taxbaik-smoke.sh
2026-07-04T13:01:34.6616322Z echo "✓ 실제 공개 도메인 전체 정상"
2026-07-04T13:01:34.6616404Z
2026-07-04T13:01:34.6616463Z send_telegram "✅ <b>TaxBaik 배포 완료</b>
2026-07-04T13:01:34.6616542Z
2026-07-04T13:01:34.6616609Z 커밋: <code>${COMMIT}</code>
2026-07-04T13:01:34.6616695Z 시간: <code>${TIMESTAMP}</code>
2026-07-04T13:01:34.6616774Z 대상: <code>${DEPLOY_HOST}</code>
2026-07-04T13:01:34.6616853Z 채널: <code>${TELEGRAM_CHAT_ID}</code>"
2026-07-04T13:01:34.6616931Z shell: bash --noprofile --norc -e -o pipefail {0}
2026-07-04T13:01:34.6617030Z ::endgroup::
2026-07-04T13:01:34.7483080Z === Deploying TaxBaik c00d237 (20260704_220134) ===
2026-07-04T13:01:36.0560253Z --- [1/5] 압축 해제 ---
2026-07-04T13:01:36.3575256Z --- [2/5] 운영 설정 검증 ---
2026-07-04T13:01:36.3575950Z --- [3/5] 마이그레이션 사전 검증 ---
2026-07-04T13:01:36.9509044Z Migration dry-run validation passed.
2026-07-04T13:01:36.9509614Z --- [4/5] Green-Blue 배포 실행 ---
2026-07-04T13:01:36.9593876Z ===== 🚀 TaxBaik Green/Blue Deployment Script =====
2026-07-04T13:01:37.1157726Z Active Port: 5004
2026-07-04T13:01:37.1158178Z Target Port: 5003
2026-07-04T13:01:37.1158370Z Deploy Directory: /home/***/deployments/taxbaik_20260704_220134
2026-07-04T13:01:37.4066841Z === Starting New App on Port 5003 ===
2026-07-04T13:01:39.4311374Z === Health Checking Port 5003 ===
2026-07-04T13:01:39.5507815Z Waiting for health check... (1/20, Status: 000000)
2026-07-04T13:01:42.1278558Z ✓ Health check passed on port 5003 (Attempt 2/20)
2026-07-04T13:01:42.1279137Z === Switching Traffic to Port 5003 ===
2026-07-04T13:01:42.1312702Z ✓ Traffic routed to 5003 (via TaxBaik.Proxy on 5001)
2026-07-04T13:01:42.1313191Z === Stopping Old App on Port 5004 ===
2026-07-04T13:01:42.2456799Z Killing old process PID: 4150110
2026-07-04T13:01:42.2457355Z ✓ Old process terminated
2026-07-04T13:01:42.2457639Z === Cleaning Up Old Deployments ===
2026-07-04T13:01:42.2824667Z ✓ Cleanup completed
2026-07-04T13:01:42.2825372Z ===== ✅ Green/Blue Deployment Completed Successfully =====
2026-07-04T13:01:42.2827207Z --- [4.5/5] Nginx 설정 검증 ---
2026-07-04T13:01:42.2917525Z 실제 로드되는 설정 파일: /etc/nginx/sites-available/taxbaik-domains.conf
2026-07-04T13:01:42.2977470Z ✓ Nginx 설정 검증 통과 (실제 로드 파일 확인 + 포트 5001 고정 + trailing slash 없음)
2026-07-04T13:01:42.2978026Z --- [5/5] 헬스 체크 (최대 60초) ---
2026-07-04T13:01:42.3668351Z ✓ [1/6] 헬스 체크 완료
2026-07-04T13:01:42.8378177Z ✓ [2/6] 메인 페이지 로드 완료
2026-07-04T13:01:42.8839270Z ✓ [3/6] CSS 파일 로드 완료
2026-07-04T13:01:42.8929193Z ✓ [4/6] 버전 정보 확인 완료
2026-07-04T13:01:42.9068857Z ✓ [5/6] 5001 프록시 확인 완료
2026-07-04T13:01:42.9149449Z ✓ [6/6] 관리자 페이지 로드 완료
2026-07-04T13:01:42.9150100Z ✓ 서비스 정상 (시도 1/20)
2026-07-04T13:01:42.9248052Z ✓ 배포 완료: taxbaik_20260704_220134 @ ***
2026-07-04T13:01:42.9248637Z --- 실제 공개 도메인 종단 간 검증 (Nginx/Cloudflare 경유, 최대 3회 재시도) ---
2026-07-04T13:01:43.3724216Z ✓ https://www.taxbaik.com/ -> HTTP 200
2026-07-04T13:01:43.6877712Z ✓ https://www.taxbaik.com/taxbaik/ -> HTTP 200
2026-07-04T13:01:44.0126645Z retrying... (1/3)
2026-07-04T13:01:44.0128053Z ✗ https://www.taxbaik.com/taxbaik/admin/login -> body missing required marker: 관리자 로그인
2026-07-04T13:01:49.3854327Z ✓ https://www.taxbaik.com/ -> HTTP 200
2026-07-04T13:01:49.6485192Z ✓ https://www.taxbaik.com/taxbaik/ -> HTTP 200
2026-07-04T13:01:50.0153135Z ✗ https://www.taxbaik.com/taxbaik/admin/login -> body missing required marker: 관리자 로그인
2026-07-04T13:01:50.0153696Z retrying... (2/3)
2026-07-04T13:01:55.2722916Z ✓ https://www.taxbaik.com/ -> HTTP 200
2026-07-04T13:01:55.6800476Z ✓ https://www.taxbaik.com/taxbaik/ -> HTTP 200
2026-07-04T13:01:55.9334729Z ✗ https://www.taxbaik.com/taxbaik/admin/login -> body missing required marker: 관리자 로그인
2026-07-04T13:01:55.9335523Z ✗ smoke verification failed
2026-07-04T13:01:56.2238319Z ❌ Failure - Main Deploy & verify on server
2026-07-04T13:01:56.2411008Z exitcode '1': failure
2026-07-04T13:01:56.2699164Z evaluating expression 'success()'
2026-07-04T13:01:56.2699697Z expression 'success()' evaluated to 'false'
2026-07-04T13:01:56.2699842Z Skipping step 'Setup .NET' due to 'success()'
2026-07-04T13:01:56.2953445Z evaluating expression 'always()'
2026-07-04T13:01:56.2953918Z expression 'always()' evaluated to 'true'
2026-07-04T13:01:56.2954039Z ⭐ Run Post Checkout code
2026-07-04T13:01:56.2954206Z Writing entry to tarball workflow/outputcmd.txt len:0
2026-07-04T13:01:56.2954356Z Writing entry to tarball workflow/statecmd.txt len:0
2026-07-04T13:01:56.2954454Z Writing entry to tarball workflow/pathcmd.txt len:0
2026-07-04T13:01:56.2954553Z Writing entry to tarball workflow/envs.txt len:0
2026-07-04T13:01:56.2954636Z Writing entry to tarball workflow/SUMMARY.md len:0
2026-07-04T13:01:56.2954724Z Extracting content to '/var/run/act'
2026-07-04T13:01:56.2989360Z run post step for 'Checkout code'
2026-07-04T13:01:56.2989963Z executing remote job container: [node /var/run/act/actions/c3fe249fe73091a17d6638fe1341e7bd0bcc3466ce52323c0688e83e2463a4ab/dist/index.js]
2026-07-04T13:01:56.3354078Z 🐳 docker exec cmd=[node /var/run/act/actions/c3fe249fe73091a17d6638fe1341e7bd0bcc3466ce52323c0688e83e2463a4ab/dist/index.js] user= workdir=
2026-07-04T13:01:56.3354506Z Exec command '[node /var/run/act/actions/c3fe249fe73091a17d6638fe1341e7bd0bcc3466ce52323c0688e83e2463a4ab/dist/index.js]'
2026-07-04T13:01:56.3354997Z Working directory '/workspace/***/taxbaik'
2026-07-04T13:01:56.5634391Z [command]/usr/bin/git version
2026-07-04T13:01:56.5708822Z git version 2.54.0
2026-07-04T13:01:56.5752988Z ***
2026-07-04T13:01:56.5772894Z Temporarily overriding HOME='/tmp/29afdc3d-d383-4267-8baa-f87edca3a0e3' before making global git config changes
2026-07-04T13:01:56.5782158Z Adding repository directory to the temporary git global config as a safe directory
2026-07-04T13:01:56.5785763Z [command]/usr/bin/git config --global --add safe.directory /workspace/***/taxbaik
2026-07-04T13:01:56.5856624Z [command]/usr/bin/git config --local --name-only --get-regexp core\.sshCommand
2026-07-04T13:01:56.5933870Z [command]/usr/bin/git submodule foreach --recursive sh -c "git config --local --name-only --get-regexp 'core\.sshCommand' && git config --local --unset-all 'core.sshCommand' || :"
2026-07-04T13:01:56.6622902Z [command]/usr/bin/git config --local --name-only --get-regexp http\.http\:\/\/gitea\:3000\/\.extraheader
2026-07-04T13:01:56.6697660Z http.http://gitea:3000/.extraheader
2026-07-04T13:01:56.6698844Z [command]/usr/bin/git config --local --unset-all http.http://gitea:3000/.extraheader
2026-07-04T13:01:56.6735534Z [command]/usr/bin/git submodule foreach --recursive sh -c "git config --local --name-only --get-regexp 'http\.http\:\/\/gitea\:3000\/\.extraheader' && git config --local --unset-all 'http.http://gitea:3000/.extraheader' || :"
2026-07-04T13:01:56.6986910Z [command]/usr/bin/git config --local --name-only --get-regexp ^includeIf\.gitdir:
2026-07-04T13:01:56.7046662Z [command]/usr/bin/git submodule foreach --recursive git config --local --show-origin --name-only --get-regexp remote.origin.url
2026-07-04T13:01:56.8590734Z ✅ Success - Post Checkout code
2026-07-04T13:01:56.8750550Z Cleaning up container for job build-and-deploy
2026-07-04T13:01:57.5600546Z Removed container: 545d203ee9994ebf9eca9357f948b418a29c0a80f13c2d69e6b64ca3d86d4b5b
2026-07-04T13:01:57.5657268Z 🐳 docker volume rm GITEA-ACTIONS-TASK-1552-WORKFLOW-TaxBaik-CI-CD-JOB-build-and-de-ab2d1e70739a3063f448d1e9d12be855fbd02428b801ec092546b895bdf5c88d
2026-07-04T13:01:57.6930032Z 🐳 docker volume rm GITEA-ACTIONS-TASK-1552-WORKFLOW-TaxBaik-CI-CD-JOB-build-and-de-ab2d1e70739a3063f448d1e9d12be855fbd02428b801ec092546b895bdf5c88d-env
2026-07-04T13:01:57.9092324Z 🏁 Job failed
2026-07-04T13:01:57.9175317Z Job 'build-and-deploy' failed