Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions .commitlintrc.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
{
"extends": ["@commitlint/config-conventional"]
}
25 changes: 25 additions & 0 deletions .github/workflows/commitlint.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
name: Lint Commits

on:
pull_request:

jobs:
commitlint:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
with:
fetch-depth: 0
persist-credentials: false

- name: Setup Node.js
uses: actions/setup-node@6044e13b5dc448c55e2357c09f80417699197238 # v6.2.0
with:
node-version: '24'

- name: Install dependencies
run: npm install

- name: Validate commit messages
run: npx commitlint --from ${{ github.event.pull_request.base.sha }} --to ${{ github.event.pull_request.head.sha }} --verbose
75 changes: 75 additions & 0 deletions .github/workflows/prepare-release.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,75 @@
name: Prepare Release

on:
push:
branches:
- master

concurrency:
group: prepare-release
cancel-in-progress: true

permissions:
contents: write
pull-requests: write

jobs:
prepare:
runs-on: ubuntu-latest
if: "!startsWith(github.event.head_commit.message, 'chore(release):')"
steps:
- name: Checkout code
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
with:
fetch-depth: 0
persist-credentials: false

- name: Setup Node.js
uses: actions/setup-node@6044e13b5dc448c55e2357c09f80417699197238 # v6.2.0
with:
node-version: '24'

- name: Install dependencies
run: npm install

- name: Build
run: npm run build

- name: Detect Next Version
id: version
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: |
# Run semantic-release with only commit analyzer to detect version
NEXT_VERSION=$(npx semantic-release --dry-run --plugins @semantic-release/commit-analyzer | tee /dev/stderr | awk '/The next release version is/{print $NF}')
echo "next=$NEXT_VERSION" >> $GITHUB_OUTPUT

- name: Update package.json
if: steps.version.outputs.next != ''
run: npm version "$NEXT_VERSION" --no-git-tag-version
env:
NEXT_VERSION: ${{ steps.version.outputs.next }}

- name: Update CHANGELOG.md
if: steps.version.outputs.next != ''
run: npx conventional-changelog-cli -p angular -i CHANGELOG.md -s

- name: Create Pull Request
if: steps.version.outputs.next != ''
uses: peter-evans/create-pull-request@c0f553fe549906ede9cf27b5156039d195d2ece0 # v8.1.0
with:
token: ${{ secrets.GITHUB_TOKEN }}
commit-message: "chore(release): ${{ steps.version.outputs.next }}"
branch: "release/v${{ steps.version.outputs.next }}"
delete-branch: true
title: "chore(release): ${{ steps.version.outputs.next }}"
body: |
This PR prepares the release of version ${{ steps.version.outputs.next }}.

**Changes:**
- Updated version in `package.json` to ${{ steps.version.outputs.next }}
- Updated `CHANGELOG.md` with release notes

**Next Steps:**
Review and merge this PR to trigger the publish workflow.
labels: release
66 changes: 66 additions & 0 deletions .github/workflows/release.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
name: Release

on:
push:
branches:
- master

permissions:
contents: write
issues: write
pull-requests: write
id-token: write

jobs:
release:
runs-on: ubuntu-latest
if: startsWith(github.event.head_commit.message, 'chore(release):')

steps:
- name: Checkout code
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
with:
fetch-depth: 0
persist-credentials: false

- name: Setup Node.js
uses: actions/setup-node@6044e13b5dc448c55e2357c09f80417699197238 # v6.2.0
with:
node-version: '24'

- name: Install dependencies
run: npm install

- name: Build
run: npm run build

- name: Set up Python
uses: actions/setup-python@a309ff8b426b58ec0e2a45f0f869d46889d02405 # v6.2.0
with:
python-version: "3.10"

- name: Install Python dependencies
shell: bash
run: pip install boto3>=1.34.159 requests>=2.32.3 rl-deploy>=2.2.3.0 pip-system-certs>=4.0

- name: Configure AWS credentials
uses: aws-actions/configure-aws-credentials@8df5847569e6427dd6c4fb1cf565c83acfa8afa7 # v6.0.0
with:
role-to-assume: ${{ secrets.PRODSEC_TOOLS_ARN }}
aws-region: us-east-1
mask-aws-account-id: true

- name: Install rl-wrapper
env:
WRAPPER_INDEX_URL: "https://${{ secrets.PRODSEC_TOOLS_USER }}:${{ secrets.PRODSEC_TOOLS_TOKEN }}@a0us.jfrog.io/artifactory/api/pypi/python-local/simple"
run: pip install "rl-wrapper>=1.0.0" --index-url $WRAPPER_INDEX_URL

- name: Release
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
NPM_CONFIG_PROVENANCE: true
RLSECURE_LICENSE: ${{ secrets.RLSECURE_LICENSE }}
RLSECURE_SITE_KEY: ${{ secrets.RLSECURE_SITE_KEY }}
SIGNAL_HANDLER_TOKEN: ${{ secrets.SIGNAL_HANDLER_TOKEN }}
PYTHONUNBUFFERED: 1
run: npx semantic-release
10 changes: 10 additions & 0 deletions .github/workflows/sca-scan.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
name: Snyk Scan

on:
push:
branches: ["master"]

jobs:
snyk-cli:
uses: auth0/devsecops-tooling/.github/workflows/sca-scan.yml@5246a8b59100e3eea284ce4f2e2a51b51e237380
secrets: inherit
20 changes: 0 additions & 20 deletions .github/workflows/semgrep.yml

This file was deleted.

39 changes: 39 additions & 0 deletions .github/workflows/test.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
name: Test

on:
pull_request:

concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true

jobs:
test:
runs-on: ubuntu-latest
strategy:
fail-fast: false
matrix:
node-version: ['20', '22', '24']

steps:
- name: Checkout code
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
with:
persist-credentials: false

- name: Setup Node.js ${{ matrix.node-version }}
uses: actions/setup-node@6044e13b5dc448c55e2357c09f80417699197238 # v6.2.0
with:
node-version: ${{ matrix.node-version }}

- name: Install dependencies
run: npm install

- name: Build
run: npm run build

- name: Lint
run: npm run lint

- name: Test
run: npm test
1 change: 1 addition & 0 deletions .husky/commit-msg
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
npx --no -- commitlint --edit $1
22 changes: 22 additions & 0 deletions .releaserc.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
{
"branches": ["master"],
"plugins": [
"@semantic-release/commit-analyzer",
"@semantic-release/release-notes-generator",
[
"@semantic-release/npm",
{
"npmPublish": true,
"pkgRoot": "."
}
],
[
"@semantic-release/exec",
{
"verifyReleaseCmd": "ARTIFACT=\"$(pwd)/$(npm pack --ignore-scripts | tail -1)\" && rl-wrapper --artifact \"$ARTIFACT\" --name express-jwt --version ${nextRelease.version} --repository $GITHUB_REPOSITORY --commit $GITHUB_SHA --build-env github_actions --suppress-output",
"prepareCmd": "git diff --exit-code -- package.json"
}
],
"@semantic-release/github"
]
}
6 changes: 0 additions & 6 deletions .travis.yml

This file was deleted.

14 changes: 10 additions & 4 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@
],
"repository": {
"type": "git",
"url": "git://github.com/auth0/express-jwt.git"
"url": "https://github.com/auth0/express-jwt.git"
},
"bugs": {
"url": "http://github.com/auth0/express-jwt/issues"
Expand All @@ -31,7 +31,7 @@
"types": "dist/index.d.ts",
"files": [
"README.md",
"/dist"
"dist"
],
"dependencies": {
"@types/jsonwebtoken": "^9",
Expand All @@ -41,13 +41,19 @@
"devDependencies": {
"@types/express": "^4.17.16",
"@types/mocha": "^9.1.0",
"@types/node": "^18.19.130",
"@typescript-eslint/eslint-plugin": "^5.15.0",
"@typescript-eslint/parser": "^5.15.0",
"conventional-changelog": "^3.1.25",
"@commitlint/cli": "^20.3.1",
"@commitlint/config-conventional": "^20.3.1",
"@semantic-release/exec": "^7.1.0",
"@semantic-release/git": "^10.0.1",
"eslint": "^8.11.0",
"express": "^4.17.3",
"husky": "^9.1.7",
"mocha": "^10.2.0",
"prettier": "^2.6.0",
"semantic-release": "^25.0.2",
"ts-node": "^10.7.0",
"typescript": "^4.6.2"
},
Expand All @@ -56,7 +62,7 @@
},
"scripts": {
"build": "rm -rf dist ; tsc",
"prepare": "npm run build",
"prepare": "husky",
"test": "mocha --reporter spec --require ts-node/register test/**",
"lint": "eslint --fix --ext .ts ./src"
}
Expand Down
3 changes: 2 additions & 1 deletion tsconfig.json
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,8 @@
"allowJs": true,
"target": "es5",
"declaration": true,
"esModuleInterop": false
"esModuleInterop": false,
"skipLibCheck": true
},
"include": [
"./src/**/*"
Expand Down
Loading