| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186 | name: Publish Bolt SDKson:  release:    types: [ published ]  push:    branches:      - 'release/v*'  workflow_dispatch:env:  solana_version: v1.18.15jobs:  install:    runs-on: ubuntu-latest    steps:      - uses: actions/checkout@v4      - uses: actions/cache@v4        name: cache solana cli        id: cache-solana        with:          path: |            ~/.cache/solana/            ~/.local/share/solana/          key: solana-${{ runner.os }}-v0000-${{ env.solana_version }}      - uses: actions/setup-node@v4        with:          node-version: 21      - name: install essentials        run: |          sudo apt-get update          sudo apt-get install -y pkg-config build-essential libudev-dev          npm install --global yarn      - name: Cache node dependencies        uses: actions/cache@v3        with:          path: '**/node_modules'          key: ${{ runner.os }}-modules-${{ hashFiles('**/yarn.lock') }}      - name: install node_modules        run: |          export PATH="/home/runner/.local/share/solana/install/active_release/bin:$PATH"          yarn --frozen-lockfile --network-concurrency 2      - name: install rust        uses: dtolnay/rust-toolchain@stable        with:          toolchain: stable      - name: Cache rust        uses: Swatinem/rust-cache@v2      - name: install solana        if: steps.cache-solana.outputs.cache-hit != 'true'        run: |          sh -c "$(curl -sSfL https://release.anza.xyz/${{ env.solana_version }}/install)"          export PATH="$HOME/.local/share/solana/install/active_release/bin:$PATH"          solana --version  yarn-lint:    needs: install    runs-on: ubuntu-latest    steps:      - uses: actions/checkout@v4      - name: Use Node ${{ matrix.node }}        uses: actions/setup-node@v4        with:          node-version: 21      # FIXME: This is not working      # - name: Cache node dependencies      #   uses: actions/cache@v4      #   with:      #     path: '**/node_modules'      #     key: ${{ runner.os }}-modules-${{ hashFiles('**/yarn.lock') }}      - name: install node_modules        run: yarn install      - name: Run lint        run: yarn lint  test:    needs: [yarn-lint]    runs-on: ubuntu-latest    steps:      - name: install rust        uses: dtolnay/rust-toolchain@stable        with:          toolchain: stable      - name: Cache rust        uses: Swatinem/rust-cache@v2      - uses: actions/checkout@v4      - name: Set DRY_RUN based on trigger        run: echo "DRY_RUN=true" >> $GITHUB_ENV        if: github.event_name == 'push' && startsWith(github.ref, 'refs/heads/release/v')      - name: Use Node ${{ matrix.node }}        uses: actions/setup-node@v4        with:          node-version: 21      - name: Cache node dependencies        uses: actions/cache@v3        with:          path: '**/node_modules'          key: ${{ runner.os }}-modules-${{ hashFiles('**/yarn.lock') }}      - name: install node_modules        run: |          export PATH="/home/runner/.local/share/solana/install/active_release/bin:$PATH"          yarn --frozen-lockfile      - uses: actions/cache@v4        name: cache solana cli        id: cache-solana        with:          path: |            ~/.cache/solana/            ~/.local/share/solana/          key: solana-${{ runner.os }}-v0000-${{ env.solana_version }}      - name: setup solana        run: |          export PATH="/home/runner/.local/share/solana/install/active_release/bin:$PATH"          solana --version          solana-keygen new --silent --no-bip39-passphrase      - name: Set deployments keys        run: |          mkdir -p target/deploy          echo ${{ secrets.WORLD }} > target/deploy/world-keypair.json          echo ${{ secrets.BOLT_COMPONENT }} > target/deploy/bolt_component-keypair.json          echo ${{ secrets.BOLT_SYSTEM }} > target/deploy/bolt_system-keypair.json          echo ${{ secrets.COMPONENT_POSITION }} > target/deploy/component_position-keypair.json          echo ${{ secrets.COMPONENT_VELOCITY }} > target/deploy/component_velocity-keypair.json          echo ${{ secrets.SYSTEM_APPLY_VELOCITY }} > target/deploy/system_apply_velocity-keypair.json          echo ${{ secrets.SYSTEM_FLY }} > target/deploy/system_fly-keypair.json          echo ${{ secrets.SYSTEM_SIMPLE_MOVEMENT }} > target/deploy/system_simple_movement-keypair.json      - name: Check versions are aligned        run: |          # Fails if versions are not aligned          cargo install git-cliff@2.6.1 --locked          ./scripts/version-align.sh --check      - name: run build        run: |          export PATH="/home/runner/.local/share/solana/install/active_release/bin:$PATH"          cargo install --path crates/bolt-cli --force --locked          bolt build      - name: Generate lib        run: |          cd clients/typescript          yarn install && yarn build          cd ../..      - name: run tests        run: |          export PATH="/home/runner/.local/share/solana/install/active_release/bin:$PATH"          cargo install --path crates/bolt-cli --force --locked          bolt test      - name: npm publish        run: |          npm install          echo "//registry.npmjs.org/:_authToken=${{ secrets.NPM_TOKEN }}" > ~/.npmrc          npm set //registry.npmjs.org/:_authToken ${{ secrets.NPM_TOKEN }}          cd clients/typescript && npm run build && npm run lint:fix && cd ../.. && npm run lint:fix          cd clients/typescript          if [ "${DRY_RUN}" = "true" ]; then            echo "Running npm publish in dry-run mode"            npm publish --access public --dry-run          else            npm publish --access public          fi        env:          NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
 |