🛡️ chore: Bump ESLint Tooling Deps and Resolve ajv Security Vulnera…
#4
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: Publish `@librechat/data-schemas` to NPM | |
| on: | |
| push: | |
| branches: | |
| - main | |
| paths: | |
| - 'packages/data-schemas/package.json' | |
| workflow_dispatch: | |
| inputs: | |
| reason: | |
| description: 'Reason for manual trigger' | |
| required: false | |
| default: 'Manual publish requested' | |
| permissions: | |
| id-token: write # Required for OIDC trusted publishing | |
| contents: read | |
| jobs: | |
| build-and-publish: | |
| runs-on: ubuntu-latest | |
| environment: publish # Must match npm trusted publisher config | |
| steps: | |
| - uses: actions/checkout@v4 | |
| - name: Use Node.js | |
| uses: actions/setup-node@v4 | |
| with: | |
| node-version: '20.x' | |
| registry-url: 'https://registry.npmjs.org' | |
| - name: Update npm for OIDC support | |
| run: npm install -g npm@latest # Must be 11.5.1+ for provenance | |
| - name: Install dependencies | |
| run: cd packages/data-schemas && npm ci | |
| - name: Build | |
| run: cd packages/data-schemas && npm run build | |
| - name: Check version change | |
| id: check | |
| working-directory: packages/data-schemas | |
| run: | | |
| PACKAGE_VERSION=$(node -p "require('./package.json').version") | |
| PUBLISHED_VERSION=$(npm view @librechat/data-schemas version 2>/dev/null || echo "0.0.0") | |
| if [ "$PACKAGE_VERSION" = "$PUBLISHED_VERSION" ]; then | |
| echo "No version change, skipping publish" | |
| echo "skip=true" >> $GITHUB_OUTPUT | |
| else | |
| echo "Version changed, proceeding with publish" | |
| echo "skip=false" >> $GITHUB_OUTPUT | |
| fi | |
| - name: Pack package | |
| if: steps.check.outputs.skip != 'true' | |
| working-directory: packages/data-schemas | |
| run: npm pack | |
| - name: Publish | |
| if: steps.check.outputs.skip != 'true' | |
| working-directory: packages/data-schemas | |
| run: npm publish *.tgz --access public --provenance |