|  | 
|  | 1 | +name: Publish NPM | 
|  | 2 | + | 
|  | 3 | +on: | 
|  | 4 | +  workflow_dispatch: | 
|  | 5 | +    inputs: | 
|  | 6 | +      release_tag: | 
|  | 7 | +        type: string | 
|  | 8 | +        required: true | 
|  | 9 | +        description: Release Tag to Publish | 
|  | 10 | +  release: | 
|  | 11 | +    types: [released, prereleased] | 
|  | 12 | + | 
|  | 13 | +jobs: | 
|  | 14 | +  validate_tag: | 
|  | 15 | +    if: github.event_name == 'workflow_dispatch' | 
|  | 16 | +    runs-on: ubuntu-latest | 
|  | 17 | +    outputs: | 
|  | 18 | +      is-prerelease: ${{ steps.validate-release.outputs.is-prerelease }} | 
|  | 19 | +    steps: | 
|  | 20 | +      - uses: actions/github-script@v7 | 
|  | 21 | +        id: validate-release | 
|  | 22 | +        with: | 
|  | 23 | +          script: | | 
|  | 24 | +            /** the "core" module does not have access to workflow_dispatch inputs */ | 
|  | 25 | +            const tag = '${{ inputs.release_tag }}'; | 
|  | 26 | +
 | 
|  | 27 | +            /** Releases don't have a guaranteed order, so we'll have to paginate */ | 
|  | 28 | +            let exhausted = false; | 
|  | 29 | +            let page = 1; | 
|  | 30 | +            while (!exhausted) { | 
|  | 31 | +              const releases = await github.rest.repos.listReleases({ | 
|  | 32 | +                owner: context.repo.owner, | 
|  | 33 | +                repo: context.repo.repo, | 
|  | 34 | +                page, | 
|  | 35 | +                per_page: 100, | 
|  | 36 | +              }).then(r => r.data); | 
|  | 37 | +
 | 
|  | 38 | +              const matchingRelease = releases.find(r => r.tag_name === tag); | 
|  | 39 | +              if (matchingRelease) { | 
|  | 40 | +                core.setOutput('has-release', 'true'); | 
|  | 41 | +                core.setOutput('is-prerelease', matchingRelease.prerelease.toString()); | 
|  | 42 | +                return; | 
|  | 43 | +              } | 
|  | 44 | +
 | 
|  | 45 | +              if (releases.length < 100) { | 
|  | 46 | +                exhausted = true; | 
|  | 47 | +              } else if (page >= 10) { | 
|  | 48 | +                throw new Error("We iterated over 10 pages. Does the script work?"); | 
|  | 49 | +              } else { | 
|  | 50 | +                page++ | 
|  | 51 | +              } | 
|  | 52 | +
 | 
|  | 53 | +            } | 
|  | 54 | +
 | 
|  | 55 | +            core.setOutput('has-release', 'false'); | 
|  | 56 | +            core.setOutput('is-prerelease', 'false'); | 
|  | 57 | +
 | 
|  | 58 | +      - name: Abort | 
|  | 59 | +        if: steps.validate-release.outputs.has-release != 'true' | 
|  | 60 | +        run: | | 
|  | 61 | +          { | 
|  | 62 | +            echo "Tag ${{ github.event.inputs.release_tag }} not found." | 
|  | 63 | +            exit 1 | 
|  | 64 | +          } | 
|  | 65 | +
 | 
|  | 66 | +  publish: | 
|  | 67 | +    name: Publish All the Things | 
|  | 68 | +    needs: [validate_tag] | 
|  | 69 | +    if: | | 
|  | 70 | +      always() && | 
|  | 71 | +      (needs.validate_tag.result == 'success' || needs.validate_tag.result == 'skipped') | 
|  | 72 | +    runs-on: ubuntu-latest | 
|  | 73 | +    permissions: | 
|  | 74 | +      contents: write | 
|  | 75 | +      id-token: write | 
|  | 76 | +    steps: | 
|  | 77 | +      - uses: actions/checkout@v4 | 
|  | 78 | + | 
|  | 79 | +      - name: Install Node | 
|  | 80 | +        uses: actions/setup-node@v4 | 
|  | 81 | +        with: | 
|  | 82 | +          node-version: lts/* | 
|  | 83 | +          registry-url: "https://registry.npmjs.org" | 
|  | 84 | + | 
|  | 85 | +      # Ensure npm 11.5.1 or later is installed for trusted publishing support | 
|  | 86 | +      - name: Update npm | 
|  | 87 | +        run: npm install -g npm@latest | 
|  | 88 | + | 
|  | 89 | +      - name: Verify `jq` is installed | 
|  | 90 | +        run: | | 
|  | 91 | +          if ! jq --version 2>/dev/null; then | 
|  | 92 | +            echo "jq not installed, required for extracting package names." | 
|  | 93 | +            exit 1 | 
|  | 94 | +          fi | 
|  | 95 | +
 | 
|  | 96 | +      - name: Generate Packages (deprecated) | 
|  | 97 | +        id: generate-packages-deprecated | 
|  | 98 | +        run: node packages/@postgrestools/postgrestools/scripts/generate-packages.mjs | 
|  | 99 | +        env: | 
|  | 100 | +          GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | 
|  | 101 | +          RELEASE_TAG: ${{ github.event_name == 'workflow_dispatch' && inputs.release_tag || github.event.release.tag_name }} | 
|  | 102 | +          PRERELEASE: ${{ github.event_name == 'workflow_dispatch' && needs.validate_tag.outputs.is-prerelease || github.event.release.prerelease }} | 
|  | 103 | + | 
|  | 104 | +      - name: Generate Packages | 
|  | 105 | +        id: generate-packages | 
|  | 106 | +        run: node packages/@postgres-language-server/cli/scripts/generate-packages.mjs | 
|  | 107 | +        env: | 
|  | 108 | +          GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | 
|  | 109 | +          RELEASE_TAG: ${{ github.event_name == 'workflow_dispatch' && inputs.release_tag || github.event.release.tag_name }} | 
|  | 110 | +          PRERELEASE: ${{ github.event_name == 'workflow_dispatch' && needs.validate_tag.outputs.is-prerelease || github.event.release.prerelease }} | 
|  | 111 | + | 
|  | 112 | +      - name: Publish npm packages as nightly (deprecated) | 
|  | 113 | +        if: (github.event_name == 'workflow_dispatch' && needs.validate_tag.outputs.is-prerelease == 'true') || (github.event_name == 'release' && github.event.release.prerelease) | 
|  | 114 | +        run: | | 
|  | 115 | +          for package in packages/@postgrestools/*; do | 
|  | 116 | +            npm publish "$package" --tag nightly --access public --provenance | 
|  | 117 | +          done | 
|  | 118 | +
 | 
|  | 119 | +      - name: Publish npm packages as nightly | 
|  | 120 | +        if: (github.event_name == 'workflow_dispatch' && needs.validate_tag.outputs.is-prerelease == 'true') || (github.event_name == 'release' && github.event.release.prerelease) | 
|  | 121 | +        run: | | 
|  | 122 | +          for package in packages/@postgres-language-server/*; do | 
|  | 123 | +            npm publish "$package" --tag nightly --access public --provenance | 
|  | 124 | +          done | 
|  | 125 | +
 | 
|  | 126 | +      - name: Publish npm packages as latest (deprecated) | 
|  | 127 | +        if: (github.event_name == 'workflow_dispatch' && needs.validate_tag.outputs.is-prerelease != 'true') || (github.event_name == 'release' && !github.event.release.prerelease) | 
|  | 128 | +        run: | | 
|  | 129 | +          for package in packages/@postgrestools/*; do | 
|  | 130 | +            version="${{ github.event_name == 'workflow_dispatch' && inputs.release_tag || github.event.release.tag_name }}" | 
|  | 131 | +            npm_package_name=$(jq -r ".name" "$package/package.json") | 
|  | 132 | +
 | 
|  | 133 | +            if npm view "$npm_package_name@$version" version 2>/dev/null; then | 
|  | 134 | +              echo "Package $npm_package_name@$version already exists, skipping..." | 
|  | 135 | +            else | 
|  | 136 | +              echo "Publishing $npm_package_name@$version..." | 
|  | 137 | +              npm publish "$package" --tag latest --access public --provenance | 
|  | 138 | +            fi | 
|  | 139 | +          done | 
|  | 140 | +
 | 
|  | 141 | +      - name: Publish npm packages as latest | 
|  | 142 | +        if: (github.event_name == 'workflow_dispatch' && needs.validate_tag.outputs.is-prerelease != 'true') || (github.event_name == 'release' && !github.event.release.prerelease) | 
|  | 143 | +        run: | | 
|  | 144 | +          for package in packages/@postgres-language-server/*; do | 
|  | 145 | +            version="${{ github.event_name == 'workflow_dispatch' && inputs.release_tag || github.event.release.tag_name }}" | 
|  | 146 | +            npm_package_name=$(jq -r ".name" "$package/package.json") | 
|  | 147 | +
 | 
|  | 148 | +            if npm view "$npm_package_name@$version" version 2>/dev/null; then | 
|  | 149 | +              echo "Package $npm_package_name@$version already exists, skipping..." | 
|  | 150 | +            else | 
|  | 151 | +              echo "Publishing $npm_package_name@$version..." | 
|  | 152 | +              npm publish "$package" --tag latest --access public --provenance | 
|  | 153 | +            fi | 
|  | 154 | +          done | 
0 commit comments