diff --git a/.gitea/workflows/deploy.yaml b/.gitea/workflows/deploy.yaml index 0255dd9..7ab6a5e 100644 --- a/.gitea/workflows/deploy.yaml +++ b/.gitea/workflows/deploy.yaml @@ -1,61 +1,43 @@ -# name: Koori-ERP-Deploy -# on: -# push: -# branches: -# - main +name: Koori-ERP-Sync-Only +on: + push: + branches: + - main -# jobs: -# auto-deploy: -# runs-on: ubuntu-latest -# steps: -# - name: 1. Checkout Code -# uses: actions/checkout@v3 -# with: -# # --- 關鍵:直接指定 Gitea 的伺服器網址為 IP --- -# github-server-url: http://192.168.0.103:3000 -# repository: ${{ gitea.repository }} -# # ------------------------------------------ +jobs: + sync-update: + runs-on: ubuntu-latest + steps: + - name: 1. Checkout New Code + uses: actions/checkout@v3 + with: + github-server-url: http://192.168.0.103:3000 + repository: ${{ gitea.repository }} -# - name: 2. Create .env from Secrets -# run: echo "${{ secrets.DOT2_ENV }}" > .env + - name: 2. Sync Files to Running Container + run: | + # 這一步最關鍵!它把剛抓下來的新 Code 塞進去「正在跑」的容器 + # 它不會刪掉你的 .env,因為它是用 tar 覆蓋進去 + tar -cf - . | docker exec -i koori-erp-laravel.test-1 tar -xf - -C /var/www/html + + # 確保權限(避免你 push 上去的檔案權限不對) + docker exec koori-erp-laravel.test-1 chown -R www-data:www-data /var/www/html -# - name: 3. Build and Start Docker -# run: | -# docker compose down --remove-orphans -# docker compose up -d --build --force-recreate - -# # 【強制注入】不管是掛載失效還是路徑對不上,這招一定能把 web.php 送進去 -# tar -cf - . | docker exec -i koori-erp-laravel.test-1 tar -xf - -C /var/www/html - -# # 修正權限(這步沒做,Laravel 後面也會噴錯) -# docker exec koori-erp-laravel.test-1 chown -R www-data:www-data /var/www/html + - name: 3. Refresh Backend (Only if needed) + run: | + # 執行 Composer (確保你有加新套件的話會抓到) + docker exec -w /var/www/html koori-erp-laravel.test-1 composer install --optimize-autoloader + # 同步資料庫欄位 (如果你有改 Migration 的話) + docker exec koori-erp-laravel.test-1 php artisan migrate --force -# - name: 4. Initialize Laravel -# run: | -# # 先進容器確認 composer.json 是否真的在那裡 -# docker exec koori-erp-laravel.test-1 ls -F /var/www/html/ - -# # 執行安裝 -# docker exec -w /var/www/html koori-erp-laravel.test-1 composer install --optimize-autoloader --no-dev - -# # 其他初始化指令 -# docker exec koori-erp-laravel.test-1 php artisan key:generate --force -# docker exec koori-erp-laravel.test-1 php artisan storage:link -# docker exec koori-erp-laravel.test-1 php artisan migrate --force + - name: 4. Build New React Assets + run: | + # 既然你改了前端,就要在容器內重新跑一次打包 + docker exec -w /var/www/html koori-erp-laravel.test-1 npm install + docker exec -w /var/www/html koori-erp-laravel.test-1 npm run build -# - name: 5. Fix Permissions (Sail Mode) -# run: | -# # 同時照顧 www-data 和 sail -# docker exec koori-erp-laravel.test-1 chmod -R 777 /var/www/html/storage -# docker exec koori-erp-laravel.test-1 php artisan view:clear - -# - name: 6. Build Frontend Assets (Vite) -# run: | -# # 1. 進入容器安裝 NPM 套件 -# docker exec -w /var/www/html koori-erp-laravel.test-1 npm install - -# # 2. 執行 Vite 編譯 (這會產生 manifest.json) -# docker exec -w /var/www/html koori-erp-laravel.test-1 npm run build - -# # 3. 再次確保編譯出來的 public/build 權限也是正確的 -# docker exec koori-erp-laravel.test-1 chown -R www-data:www-data /var/www/html/public \ No newline at end of file + - name: 5. Clear Old Cache + run: | + # 讓 Laravel 重新讀取最新的路由與設定 + docker exec koori-erp-laravel.test-1 php artisan config:clear + docker exec koori-erp-laravel.test-1 php artisan route:clear \ No newline at end of file diff --git a/README.md b/README.md index 2839a39..7426401 100644 --- a/README.md +++ b/README.md @@ -15,22 +15,17 @@ ### 1. 安裝依賴 (初次啟動) +建立目錄:mkdir 檔案名稱 && cd 檔案名稱 + +抓取代碼:git clone http://git網址/帳號/專案.git . + 如果您是第一次 clone 專案,請先安裝 PHP 與 JS 依賴: ```bash -# 安裝 PHP 依賴 (透過暫時的容器) -docker run --rm \ - -u "$(id -u):$(id -g)" \ - -v "$(pwd):/var/www/html" \ - -w /var/www/html \ - laravelsail/php84-composer:latest \ - composer install --ignore-platform-reqs # 初始化 .env 檔案 cp .env.example .env -# 生成 App Key -./vendor/bin/sail artisan key:generate ``` ### 2. 啟動 Docker 容器 @@ -39,22 +34,27 @@ cp .env.example .env ```bash # 背景執行容器 -./vendor/bin/sail up -d +docker compose up -d --build + +docker exec -it koori-erp-laravel.test-1 composer install + +# 生成 App Key +docker exec -it koori-erp-laravel.test-1 php artisan key:generate ``` ### 3. 資料庫遷移與初始化 ```bash -./vendor/bin/sail artisan migrate # (選填) 如果有種子資料 -# ./vendor/bin/sail artisan db:seed +docker exec -it koori-erp-laravel.test-1 php artisan migrate --seed + ``` ### 4. 啟動前端開發伺服器 (Vite) ```bash -./vendor/bin/sail npm install -./vendor/bin/sail npm run dev +docker exec -it koori-erp-laravel.test-1 npm install +docker exec -it koori-erp-laravel.test-1 npm run build ``` 啟動後,您可以透過以下連結瀏覽專案: