name: build-and-deploy on: push: branches: [ main, master ] jobs: #───────────────── build & deploy ───────────────── build-and-deploy: runs-on: docker env: REG: ${{ vars.REGISTRY_URL }} REPO_OWNER: ${{ github.repository_owner }} APP_NAME: ${{ vars.APP_NAME }} APP_DOMAIN: ${{ vars.APP_DOMAIN }} NUXT_PUBLIC_APP_URL: ${{ vars.NUXT_PUBLIC_APP_URL }} NUXT_AUTHENTIK_API_TOKEN: ${{ secrets.NUXT_AUTHENTIK_API_TOKEN }} NUXT_AUTHENTIK_API_URL: ${{ vars.NUXT_AUTHENTIK_API_URL }} NUXT_PUBLIC_AUTHENTIK_URL: ${{ vars.NUXT_PUBLIC_AUTHENTIK_URL }} # Metabase API (para contactos) NUXT_METABASE_API_URL: ${{ vars.NUXT_METABASE_API_URL }} NUXT_METABASE_API_KEY: ${{ secrets.NUXT_METABASE_API_KEY }} NUXT_METABASE_DATABASE_ID: ${{ vars.NUXT_METABASE_DATABASE_ID }} NUXT_METABASE_TABLE_ID: ${{ vars.NUXT_METABASE_TABLE_ID }} steps: - uses: actions/checkout@v3 - uses: docker/setup-buildx-action@v2 - uses: docker/login-action@v2 with: registry: ${{ vars.REGISTRY_URL }} username: ${{ secrets.REGISTRY_USERNAME }} password: ${{ secrets.REGISTRY_PASSWORD }} - name: Build+push ${{ vars.APP_NAME }} run: | cd nuxt4 docker build -t $REG/${{ github.repository_owner }}/$APP_NAME:${{ github.sha }} -t $REG/${{ github.repository_owner }}/$APP_NAME:latest . docker push $REG/${{ github.repository_owner }}/$APP_NAME:${{ github.sha }} docker push $REG/${{ github.repository_owner }}/$APP_NAME:latest - name: Info about environment run: | echo "ℹ️ Deploying ${{ vars.APP_NAME }}" echo " Domain: ${{ vars.APP_DOMAIN }}" echo " Image: ${{ vars.REGISTRY_URL }}/${{ github.repository_owner }}/${{ vars.APP_NAME }}:latest" echo " Network: principal" - name: Pull fresh images used in compose run: docker compose pull - name: Clean up stack run: docker compose --project-name $APP_NAME down - name: Update stack run: docker compose --project-name $APP_NAME up -d --remove-orphans --wait