chore(deps): bump three from 0.176.0 to 0.183.2 in the production-dependencies group #142
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| name: CI | |
| on: | |
| push: | |
| branches: | |
| - main | |
| pull_request: | |
| permissions: | |
| contents: write | |
| packages: write | |
| pull-requests: write | |
| jobs: | |
| lint: | |
| name: Lint | |
| runs-on: ubuntu-latest | |
| steps: | |
| - name: Checkout | |
| uses: actions/checkout@v4 | |
| - name: Setup bun | |
| uses: oven-sh/setup-bun@v2 | |
| with: | |
| bun-version: ${{ env.BUN_VERSION }} | |
| - name: Install Dependencies | |
| run: bun install --frozen-lockfile | |
| - name: Lint | |
| run: bun run lint | |
| build: | |
| name: Build | |
| runs-on: ubuntu-latest | |
| steps: | |
| - name: Checkout | |
| uses: actions/checkout@v4 | |
| - name: Setup bun | |
| uses: oven-sh/setup-bun@v2 | |
| with: | |
| bun-version: ${{ env.BUN_VERSION }} | |
| - name: Install Dependencies | |
| run: bun install --frozen-lockfile | |
| - name: Build | |
| env: | |
| ADMIN_EMAIL: ${{ secrets.ADMIN_EMAIL }} | |
| ADMIN_PASSWORD: ${{ secrets.ADMIN_PASSWORD }} | |
| POCKETBASE_URL: ${{ secrets.POCKETBASE_URL }} | |
| run: bun run build | |
| test: | |
| name: Test | |
| needs: build | |
| runs-on: ubuntu-latest | |
| steps: | |
| - name: Checkout | |
| uses: actions/checkout@v4 | |
| - name: Setup bun | |
| uses: oven-sh/setup-bun@v2 | |
| with: | |
| bun-version: ${{ env.BUN_VERSION }} | |
| - name: Install Dependencies | |
| run: bun install --frozen-lockfile | |
| - name: Test | |
| env: | |
| ADMIN_EMAIL: ${{ secrets.ADMIN_EMAIL }} | |
| ADMIN_PASSWORD: ${{ secrets.ADMIN_PASSWORD }} | |
| POCKETBASE_URL: ${{ secrets.POCKETBASE_URL }} | |
| run: bun run test | |
| changelog: | |
| name: Changelog | |
| needs: | |
| - lint | |
| - build | |
| - test | |
| if: github.event_name != 'pull_request' | |
| runs-on: ubuntu-latest | |
| outputs: | |
| skipped: ${{ steps.changelog.outputs.skipped }} | |
| tag: ${{ steps.changelog.outputs.tag }} | |
| clean_changelog: ${{ steps.changelog.outputs.clean_changelog }} | |
| version: ${{ steps.changelog.outputs.version }} | |
| env: | |
| PR_BRANCH: release/ci-${{ github.sha }} | |
| steps: | |
| - uses: actions/checkout@v4 | |
| - name: Create Branch | |
| run: | | |
| git checkout -b ${{ env.PR_BRANCH }} | |
| - name: Create Changelog | |
| uses: TriPSs/conventional-changelog-action@v5 | |
| id: changelog | |
| with: | |
| github-token: ${{ github.token }} | |
| git-user-name: 'github-actions[bot]' | |
| git-user-email: 'github-actions[bot]@users.noreply.github.com' | |
| git-branch: ${{ env.PR_BRANCH }} | |
| skip-git-pull: true | |
| output-file: false | |
| version-file: package.json | |
| create-summary: true | |
| - name: Create Changelog PR | |
| if: steps.changelog.outputs.skipped == 'false' | |
| env: | |
| GH_TOKEN: ${{ github.token }} | |
| run: | | |
| gh pr create --base main --head ${{ env.PR_BRANCH }} --title 'chore(release): ${{ steps.changelog.outputs.tag }} [skip-ci]' --body '${{ steps.changelog.outputs.clean_changelog }}' | |
| - name: Merge Changelog PR | |
| if: steps.changelog.outputs.skipped == 'false' | |
| env: | |
| GH_TOKEN: ${{ github.token }} | |
| run: | | |
| gh pr merge --squash --delete-branch ${{ env.PR_BRANCH }} | |
| release: | |
| name: Release | |
| needs: changelog | |
| if: github.event_name != 'pull_request' && needs.changelog.outputs.skipped == 'false' | |
| runs-on: ubuntu-latest | |
| steps: | |
| - name: Create Release | |
| uses: softprops/action-gh-release@v1 | |
| with: | |
| tag_name: ${{ needs.changelog.outputs.tag }} | |
| name: ${{ needs.changelog.outputs.tag }} | |
| body: | | |
| <details> | |
| <summary>Changelog</summary> | |
| ${{ needs.changelog.outputs.clean_changelog }} | |
| </details> | |
| build-deploy: | |
| name: Build & Push | |
| needs: [changelog, release] | |
| runs-on: ubuntu-latest | |
| steps: | |
| - name: Login to GitHub Container Registry | |
| uses: docker/login-action@v3 | |
| with: | |
| registry: ghcr.io | |
| username: ${{ github.actor }} | |
| password: ${{ github.token }} | |
| - name: Checkout | |
| uses: actions/checkout@v4 | |
| - name: Update env | |
| run: | | |
| echo "REGISTRY_DIR=${GITHUB_REPOSITORY_OWNER@L}" >> "${GITHUB_ENV}" | |
| - name: Build | |
| working-directory: ./resources/deployment | |
| run: | | |
| docker compose -f compose.production.yml build | |
| docker tag ghcr.io/${{ env.REGISTRY_DIR }}/shapez-base ghcr.io/${{ env.REGISTRY_DIR }}/shapez-base:${{ needs.changelog.outputs.tag }} | |
| docker tag ghcr.io/${{ env.REGISTRY_DIR }}/shapez-proxy ghcr.io/${{ env.REGISTRY_DIR }}/shapez-proxy:${{ needs.changelog.outputs.tag }} | |
| - name: Push | |
| run: | | |
| docker image ls | |
| docker push -a ghcr.io/${{ env.REGISTRY_DIR }}/shapez-base | |
| docker push -a ghcr.io/${{ env.REGISTRY_DIR }}/shapez-proxy | |
| deploy: | |
| name: Deploy | |
| needs: build-deploy | |
| environment: production | |
| runs-on: ubuntu-latest | |
| steps: | |
| - name: Checkout | |
| uses: actions/checkout@v4 | |
| - name: Create Context | |
| uses: amirmarmul/docker-context-ssh-action@v2.1.3 | |
| with: | |
| ssh-host: ${{ secrets.DEPLOYMENT_SSH_HOST }} | |
| ssh-username: ${{ secrets.DEPLOYMENT_SSH_USER }} | |
| ssh-private-key: ${{ secrets.DEPLOYMENT_SSH_KEY }} | |
| context-use: true | |
| - name: Deploy | |
| working-directory: ./resources/deployment | |
| # todo use docker stack deploy | |
| run: | | |
| docker compose -f compose.production.yml up -d --force-recreate --pull always |