mirror of
https://github.com/actions/runner.git
synced 2025-12-10 12:36:23 +00:00
Compare commits
24 Commits
copilot/fi
...
salmanmkc-
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
82dcbedb3e | ||
|
|
0b074a3e93 | ||
|
|
25faeabaa8 | ||
|
|
b121ef832b | ||
|
|
170033c92b | ||
|
|
f9c4e17fd9 | ||
|
|
646da708ba | ||
|
|
bf8236344b | ||
|
|
720f16aef6 | ||
|
|
f77066a6a8 | ||
|
|
df83df2a32 | ||
|
|
97b2254146 | ||
|
|
7f72ba9e48 | ||
|
|
f8ae5bb1a7 | ||
|
|
a5631456a2 | ||
|
|
65dfa460ba | ||
|
|
80ee51f164 | ||
|
|
c95883f28e | ||
|
|
6e940643a9 | ||
|
|
629f2384a4 | ||
|
|
c3bf70becb | ||
|
|
8b65f5f9df | ||
|
|
5f1efec208 | ||
|
|
20d82ad357 |
@@ -4,7 +4,7 @@
|
|||||||
"features": {
|
"features": {
|
||||||
"ghcr.io/devcontainers/features/docker-in-docker:1": {},
|
"ghcr.io/devcontainers/features/docker-in-docker:1": {},
|
||||||
"ghcr.io/devcontainers/features/dotnet": {
|
"ghcr.io/devcontainers/features/dotnet": {
|
||||||
"version": "8.0.412"
|
"version": "8.0.413"
|
||||||
},
|
},
|
||||||
"ghcr.io/devcontainers/features/node:1": {
|
"ghcr.io/devcontainers/features/node:1": {
|
||||||
"version": "20"
|
"version": "20"
|
||||||
|
|||||||
2
.github/workflows/close-bugs-bot.yml
vendored
2
.github/workflows/close-bugs-bot.yml
vendored
@@ -7,7 +7,7 @@ jobs:
|
|||||||
stale:
|
stale:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/stale@v9
|
- uses: actions/stale@v10
|
||||||
with:
|
with:
|
||||||
close-issue-message: "This issue does not seem to be a problem with the runner application, it concerns the GitHub actions platform more generally. Could you please post your feedback on the [GitHub Community Support Forum](https://github.com/orgs/community/discussions/categories/actions) which is actively monitored. Using the forum ensures that we route your problem to the correct team. 😃"
|
close-issue-message: "This issue does not seem to be a problem with the runner application, it concerns the GitHub actions platform more generally. Could you please post your feedback on the [GitHub Community Support Forum](https://github.com/orgs/community/discussions/categories/actions) which is actively monitored. Using the forum ensures that we route your problem to the correct team. 😃"
|
||||||
exempt-issue-labels: "keep"
|
exempt-issue-labels: "keep"
|
||||||
|
|||||||
2
.github/workflows/close-features-bot.yml
vendored
2
.github/workflows/close-features-bot.yml
vendored
@@ -7,7 +7,7 @@ jobs:
|
|||||||
stale:
|
stale:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/stale@v9
|
- uses: actions/stale@v10
|
||||||
with:
|
with:
|
||||||
close-issue-message: "Thank you for your interest in the runner application and taking the time to provide your valuable feedback. We kindly ask you to redirect this feedback to the [GitHub Community Support Forum](https://github.com/orgs/community/discussions/categories/actions-and-packages) which our team actively monitors and would be a better place to start a discussion for new feature requests in GitHub Actions. For more information on this policy please [read our contribution guidelines](https://github.com/actions/runner#contribute). 😃"
|
close-issue-message: "Thank you for your interest in the runner application and taking the time to provide your valuable feedback. We kindly ask you to redirect this feedback to the [GitHub Community Support Forum](https://github.com/orgs/community/discussions/categories/actions-and-packages) which our team actively monitors and would be a better place to start a discussion for new feature requests in GitHub Actions. For more information on this policy please [read our contribution guidelines](https://github.com/actions/runner#contribute). 😃"
|
||||||
exempt-issue-labels: "keep"
|
exempt-issue-labels: "keep"
|
||||||
|
|||||||
211
.github/workflows/dependency-check.yml
vendored
Normal file
211
.github/workflows/dependency-check.yml
vendored
Normal file
@@ -0,0 +1,211 @@
|
|||||||
|
name: Dependency Status Check
|
||||||
|
|
||||||
|
on:
|
||||||
|
workflow_dispatch:
|
||||||
|
inputs:
|
||||||
|
check_type:
|
||||||
|
description: "Type of dependency check"
|
||||||
|
required: false
|
||||||
|
default: "all"
|
||||||
|
type: choice
|
||||||
|
options:
|
||||||
|
- all
|
||||||
|
- node
|
||||||
|
- dotnet
|
||||||
|
- docker
|
||||||
|
- npm
|
||||||
|
schedule:
|
||||||
|
- cron: "0 11 * * 1" # Weekly on Monday at 11 AM
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
dependency-status:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
outputs:
|
||||||
|
node20-status: ${{ steps.check-versions.outputs.node20-status }}
|
||||||
|
node24-status: ${{ steps.check-versions.outputs.node24-status }}
|
||||||
|
dotnet-status: ${{ steps.check-versions.outputs.dotnet-status }}
|
||||||
|
docker-status: ${{ steps.check-versions.outputs.docker-status }}
|
||||||
|
buildx-status: ${{ steps.check-versions.outputs.buildx-status }}
|
||||||
|
npm-vulnerabilities: ${{ steps.check-versions.outputs.npm-vulnerabilities }}
|
||||||
|
open-dependency-prs: ${{ steps.check-prs.outputs.open-dependency-prs }}
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v5
|
||||||
|
- name: Setup Node.js
|
||||||
|
uses: actions/setup-node@v4
|
||||||
|
with:
|
||||||
|
node-version: "20"
|
||||||
|
|
||||||
|
- name: Check dependency versions
|
||||||
|
id: check-versions
|
||||||
|
run: |
|
||||||
|
echo "## Dependency Status Report" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "Generated on: $(date)" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "" >> $GITHUB_STEP_SUMMARY
|
||||||
|
|
||||||
|
# Check Node versions
|
||||||
|
if [[ "${{ github.event.inputs.check_type }}" == "all" || "${{ github.event.inputs.check_type }}" == "node" ]]; then
|
||||||
|
echo "### Node.js Versions" >> $GITHUB_STEP_SUMMARY
|
||||||
|
|
||||||
|
VERSIONS_JSON=$(curl -s https://raw.githubusercontent.com/actions/node-versions/main/versions-manifest.json)
|
||||||
|
LATEST_NODE20=$(echo "$VERSIONS_JSON" | jq -r '.[] | select(.version | startswith("20.")) | .version' | head -1)
|
||||||
|
LATEST_NODE24=$(echo "$VERSIONS_JSON" | jq -r '.[] | select(.version | startswith("24.")) | .version' | head -1)
|
||||||
|
|
||||||
|
CURRENT_NODE20=$(grep "NODE20_VERSION=" src/Misc/externals.sh | cut -d'"' -f2)
|
||||||
|
CURRENT_NODE24=$(grep "NODE24_VERSION=" src/Misc/externals.sh | cut -d'"' -f2)
|
||||||
|
|
||||||
|
NODE20_STATUS="✅ up-to-date"
|
||||||
|
NODE24_STATUS="✅ up-to-date"
|
||||||
|
|
||||||
|
if [ "$CURRENT_NODE20" != "$LATEST_NODE20" ]; then
|
||||||
|
NODE20_STATUS="⚠️ outdated"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$CURRENT_NODE24" != "$LATEST_NODE24" ]; then
|
||||||
|
NODE24_STATUS="⚠️ outdated"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "| Version | Current | Latest | Status |" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "|---------|---------|--------|--------|" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "| Node 20 | $CURRENT_NODE20 | $LATEST_NODE20 | $NODE20_STATUS |" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "| Node 24 | $CURRENT_NODE24 | $LATEST_NODE24 | $NODE24_STATUS |" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "" >> $GITHUB_STEP_SUMMARY
|
||||||
|
|
||||||
|
echo "node20-status=$NODE20_STATUS" >> $GITHUB_OUTPUT
|
||||||
|
echo "node24-status=$NODE24_STATUS" >> $GITHUB_OUTPUT
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check .NET version
|
||||||
|
if [[ "${{ github.event.inputs.check_type }}" == "all" || "${{ github.event.inputs.check_type }}" == "dotnet" ]]; then
|
||||||
|
echo "### .NET SDK Version" >> $GITHUB_STEP_SUMMARY
|
||||||
|
|
||||||
|
current_dotnet_version=$(jq -r .sdk.version ./src/global.json)
|
||||||
|
current_major_minor=$(echo "$current_dotnet_version" | cut -d '.' -f 1,2)
|
||||||
|
latest_dotnet_version=$(curl -sb -H "Accept: application/json" "https://dotnetcli.blob.core.windows.net/dotnet/Sdk/$current_major_minor/latest.version")
|
||||||
|
|
||||||
|
DOTNET_STATUS="✅ up-to-date"
|
||||||
|
if [ "$current_dotnet_version" != "$latest_dotnet_version" ]; then
|
||||||
|
DOTNET_STATUS="⚠️ outdated"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "| Component | Current | Latest | Status |" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "|-----------|---------|--------|--------|" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "| .NET SDK | $current_dotnet_version | $latest_dotnet_version | $DOTNET_STATUS |" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "" >> $GITHUB_STEP_SUMMARY
|
||||||
|
|
||||||
|
echo "dotnet-status=$DOTNET_STATUS" >> $GITHUB_OUTPUT
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check Docker versions
|
||||||
|
if [[ "${{ github.event.inputs.check_type }}" == "all" || "${{ github.event.inputs.check_type }}" == "docker" ]]; then
|
||||||
|
echo "### Docker Versions" >> $GITHUB_STEP_SUMMARY
|
||||||
|
|
||||||
|
current_docker=$(grep "ARG DOCKER_VERSION=" ./images/Dockerfile | cut -d'=' -f2)
|
||||||
|
current_buildx=$(grep "ARG BUILDX_VERSION=" ./images/Dockerfile | cut -d'=' -f2)
|
||||||
|
|
||||||
|
latest_docker=$(curl -s https://download.docker.com/linux/static/stable/x86_64/ | grep -o 'docker-[0-9]*\.[0-9]*\.[0-9]*\.tgz' | sort -V | tail -n 1 | sed 's/docker-\(.*\)\.tgz/\1/')
|
||||||
|
latest_buildx=$(curl -s https://api.github.com/repos/docker/buildx/releases/latest | jq -r '.tag_name' | sed 's/^v//')
|
||||||
|
|
||||||
|
DOCKER_STATUS="✅ up-to-date"
|
||||||
|
BUILDX_STATUS="✅ up-to-date"
|
||||||
|
|
||||||
|
if [ "$current_docker" != "$latest_docker" ]; then
|
||||||
|
DOCKER_STATUS="⚠️ outdated"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$current_buildx" != "$latest_buildx" ]; then
|
||||||
|
BUILDX_STATUS="⚠️ outdated"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "| Component | Current | Latest | Status |" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "|-----------|---------|--------|--------|" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "| Docker | $current_docker | $latest_docker | $DOCKER_STATUS |" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "| Docker Buildx | $current_buildx | $latest_buildx | $BUILDX_STATUS |" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "" >> $GITHUB_STEP_SUMMARY
|
||||||
|
|
||||||
|
echo "docker-status=$DOCKER_STATUS" >> $GITHUB_OUTPUT
|
||||||
|
echo "buildx-status=$BUILDX_STATUS" >> $GITHUB_OUTPUT
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check npm vulnerabilities
|
||||||
|
if [[ "${{ github.event.inputs.check_type }}" == "all" || "${{ github.event.inputs.check_type }}" == "npm" ]]; then
|
||||||
|
echo "### NPM Security Audit" >> $GITHUB_STEP_SUMMARY
|
||||||
|
|
||||||
|
cd src/Misc/expressionFunc/hashFiles
|
||||||
|
npm install --silent
|
||||||
|
|
||||||
|
AUDIT_OUTPUT=""
|
||||||
|
AUDIT_EXIT_CODE=0
|
||||||
|
# Run npm audit and capture output and exit code
|
||||||
|
if ! AUDIT_OUTPUT=$(npm audit --json 2>&1); then
|
||||||
|
AUDIT_EXIT_CODE=$?
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check if output is valid JSON
|
||||||
|
if echo "$AUDIT_OUTPUT" | jq . >/dev/null 2>&1; then
|
||||||
|
VULN_COUNT=$(echo "$AUDIT_OUTPUT" | jq '.metadata.vulnerabilities.total // 0')
|
||||||
|
# Ensure VULN_COUNT is a number
|
||||||
|
VULN_COUNT=$(echo "$VULN_COUNT" | grep -o '[0-9]*' | head -1)
|
||||||
|
VULN_COUNT=${VULN_COUNT:-0}
|
||||||
|
|
||||||
|
NPM_STATUS="✅ no vulnerabilities"
|
||||||
|
if [ "$VULN_COUNT" -gt 0 ] 2>/dev/null; then
|
||||||
|
NPM_STATUS="⚠️ $VULN_COUNT vulnerabilities found"
|
||||||
|
|
||||||
|
# Get vulnerability details
|
||||||
|
HIGH_VULNS=$(echo "$AUDIT_OUTPUT" | jq '.metadata.vulnerabilities.high // 0')
|
||||||
|
CRITICAL_VULNS=$(echo "$AUDIT_OUTPUT" | jq '.metadata.vulnerabilities.critical // 0')
|
||||||
|
|
||||||
|
echo "| Severity | Count |" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "|----------|-------|" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "| Critical | $CRITICAL_VULNS |" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "| High | $HIGH_VULNS |" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "" >> $GITHUB_STEP_SUMMARY
|
||||||
|
else
|
||||||
|
echo "No npm vulnerabilities found ✅" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "" >> $GITHUB_STEP_SUMMARY
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
NPM_STATUS="❌ npm audit failed"
|
||||||
|
echo "npm audit failed to run or returned invalid JSON ❌" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "Exit code: $AUDIT_EXIT_CODE" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "Output: $AUDIT_OUTPUT" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "" >> $GITHUB_STEP_SUMMARY
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "npm-vulnerabilities=$NPM_STATUS" >> $GITHUB_OUTPUT
|
||||||
|
fi
|
||||||
|
|
||||||
|
- name: Check for open dependency PRs
|
||||||
|
id: check-prs
|
||||||
|
env:
|
||||||
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
run: |
|
||||||
|
echo "### Open Dependency PRs" >> $GITHUB_STEP_SUMMARY
|
||||||
|
|
||||||
|
# Get open PRs with dependency label
|
||||||
|
OPEN_PRS=$(gh pr list --label "dependencies" --state open --json number,title,url)
|
||||||
|
PR_COUNT=$(echo "$OPEN_PRS" | jq '. | length')
|
||||||
|
|
||||||
|
if [ "$PR_COUNT" -gt 0 ]; then
|
||||||
|
echo "Found $PR_COUNT open dependency PR(s):" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "$OPEN_PRS" | jq -r '.[] | "- [#\(.number)](\(.url)) \(.title)"' >> $GITHUB_STEP_SUMMARY
|
||||||
|
else
|
||||||
|
echo "No open dependency PRs found ✅" >> $GITHUB_STEP_SUMMARY
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "open-dependency-prs=$PR_COUNT" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
|
- name: Summary
|
||||||
|
run: |
|
||||||
|
echo "### Summary" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "- Check for open PRs with the \`dependency\` label before releases" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "- Review and merge dependency updates regularly" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "- Critical vulnerabilities should be addressed immediately" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "**Automated workflows run weekly to check for updates:**" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "- Node.js versions (Mondays at 6 AM)" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "- NPM audit fix (Mondays at 7 AM)" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "- .NET SDK updates (Mondays at midnight)" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "- Docker/Buildx updates (Mondays at midnight)" >> $GITHUB_STEP_SUMMARY
|
||||||
58
.github/workflows/docker-buildx-upgrade.yml
vendored
58
.github/workflows/docker-buildx-upgrade.yml
vendored
@@ -2,8 +2,8 @@ name: "Docker/Buildx Version Upgrade"
|
|||||||
|
|
||||||
on:
|
on:
|
||||||
schedule:
|
schedule:
|
||||||
- cron: '0 0 * * 1' # Run every Monday at midnight
|
- cron: "0 0 * * 1" # Run every Monday at midnight
|
||||||
workflow_dispatch: # Allow manual triggering
|
workflow_dispatch: # Allow manual triggering
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
check-versions:
|
check-versions:
|
||||||
@@ -35,7 +35,7 @@ jobs:
|
|||||||
echo "Failed to retrieve a valid Docker version"
|
echo "Failed to retrieve a valid Docker version"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
should_update=0
|
should_update=0
|
||||||
[ "$current_version" != "$latest_version" ] && should_update=1
|
[ "$current_version" != "$latest_version" ] && should_update=1
|
||||||
|
|
||||||
@@ -64,17 +64,17 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
docker_should_update="${{ steps.check_docker_version.outputs.SHOULD_UPDATE }}"
|
docker_should_update="${{ steps.check_docker_version.outputs.SHOULD_UPDATE }}"
|
||||||
buildx_should_update="${{ steps.check_buildx_version.outputs.SHOULD_UPDATE }}"
|
buildx_should_update="${{ steps.check_buildx_version.outputs.SHOULD_UPDATE }}"
|
||||||
|
|
||||||
# Show annotation if only Docker needs update
|
# Show annotation if only Docker needs update
|
||||||
if [[ "$docker_should_update" == "1" && "$buildx_should_update" == "0" ]]; then
|
if [[ "$docker_should_update" == "1" && "$buildx_should_update" == "0" ]]; then
|
||||||
echo "::warning ::Docker version (${{ steps.check_docker_version.outputs.LATEST_VERSION }}) needs update but Buildx is current. Only updating when both need updates."
|
echo "::warning ::Docker version (${{ steps.check_docker_version.outputs.LATEST_VERSION }}) needs update but Buildx is current. Only updating when both need updates."
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Show annotation if only Buildx needs update
|
# Show annotation if only Buildx needs update
|
||||||
if [[ "$docker_should_update" == "0" && "$buildx_should_update" == "1" ]]; then
|
if [[ "$docker_should_update" == "0" && "$buildx_should_update" == "1" ]]; then
|
||||||
echo "::warning ::Buildx version (${{ steps.check_buildx_version.outputs.LATEST_VERSION }}) needs update but Docker is current. Only updating when both need updates."
|
echo "::warning ::Buildx version (${{ steps.check_buildx_version.outputs.LATEST_VERSION }}) needs update but Docker is current. Only updating when both need updates."
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Show annotation when both are current
|
# Show annotation when both are current
|
||||||
if [[ "$docker_should_update" == "0" && "$buildx_should_update" == "0" ]]; then
|
if [[ "$docker_should_update" == "0" && "$buildx_should_update" == "0" ]]; then
|
||||||
echo "::warning ::Latest Docker version is ${{ steps.check_docker_version.outputs.LATEST_VERSION }} and Buildx version is ${{ steps.check_buildx_version.outputs.LATEST_VERSION }}. No updates needed."
|
echo "::warning ::Latest Docker version is ${{ steps.check_docker_version.outputs.LATEST_VERSION }} and Buildx version is ${{ steps.check_buildx_version.outputs.LATEST_VERSION }}. No updates needed."
|
||||||
@@ -90,25 +90,25 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
- name: Checkout repository
|
- name: Checkout repository
|
||||||
uses: actions/checkout@v5
|
uses: actions/checkout@v5
|
||||||
|
|
||||||
- name: Update Docker version
|
- name: Update Docker version
|
||||||
shell: bash
|
shell: bash
|
||||||
run: |
|
run: |
|
||||||
latest_version="${{ needs.check-versions.outputs.DOCKER_LATEST_VERSION }}"
|
latest_version="${{ needs.check-versions.outputs.DOCKER_LATEST_VERSION }}"
|
||||||
current_version="${{ needs.check-versions.outputs.DOCKER_CURRENT_VERSION }}"
|
current_version="${{ needs.check-versions.outputs.DOCKER_CURRENT_VERSION }}"
|
||||||
|
|
||||||
# Update version in Dockerfile
|
# Update version in Dockerfile
|
||||||
sed -i "s/ARG DOCKER_VERSION=$current_version/ARG DOCKER_VERSION=$latest_version/g" ./images/Dockerfile
|
sed -i "s/ARG DOCKER_VERSION=$current_version/ARG DOCKER_VERSION=$latest_version/g" ./images/Dockerfile
|
||||||
|
|
||||||
- name: Update Buildx version
|
- name: Update Buildx version
|
||||||
shell: bash
|
shell: bash
|
||||||
run: |
|
run: |
|
||||||
latest_version="${{ needs.check-versions.outputs.BUILDX_LATEST_VERSION }}"
|
latest_version="${{ needs.check-versions.outputs.BUILDX_LATEST_VERSION }}"
|
||||||
current_version="${{ needs.check-versions.outputs.BUILDX_CURRENT_VERSION }}"
|
current_version="${{ needs.check-versions.outputs.BUILDX_CURRENT_VERSION }}"
|
||||||
|
|
||||||
# Update version in Dockerfile
|
# Update version in Dockerfile
|
||||||
sed -i "s/ARG BUILDX_VERSION=$current_version/ARG BUILDX_VERSION=$latest_version/g" ./images/Dockerfile
|
sed -i "s/ARG BUILDX_VERSION=$current_version/ARG BUILDX_VERSION=$latest_version/g" ./images/Dockerfile
|
||||||
|
|
||||||
- name: Commit changes and create Pull Request
|
- name: Commit changes and create Pull Request
|
||||||
env:
|
env:
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
@@ -117,7 +117,7 @@ jobs:
|
|||||||
branch_name="feature/docker-buildx-upgrade"
|
branch_name="feature/docker-buildx-upgrade"
|
||||||
commit_message="Upgrade Docker to v${{ needs.check-versions.outputs.DOCKER_LATEST_VERSION }} and Buildx to v${{ needs.check-versions.outputs.BUILDX_LATEST_VERSION }}"
|
commit_message="Upgrade Docker to v${{ needs.check-versions.outputs.DOCKER_LATEST_VERSION }} and Buildx to v${{ needs.check-versions.outputs.BUILDX_LATEST_VERSION }}"
|
||||||
pr_title="Update Docker to v${{ needs.check-versions.outputs.DOCKER_LATEST_VERSION }} and Buildx to v${{ needs.check-versions.outputs.BUILDX_LATEST_VERSION }}"
|
pr_title="Update Docker to v${{ needs.check-versions.outputs.DOCKER_LATEST_VERSION }} and Buildx to v${{ needs.check-versions.outputs.BUILDX_LATEST_VERSION }}"
|
||||||
|
|
||||||
# Configure git
|
# Configure git
|
||||||
git config --global user.name "github-actions[bot]"
|
git config --global user.name "github-actions[bot]"
|
||||||
git config --global user.email "<41898282+github-actions[bot]@users.noreply.github.com>"
|
git config --global user.email "<41898282+github-actions[bot]@users.noreply.github.com>"
|
||||||
@@ -129,16 +129,38 @@ jobs:
|
|||||||
else
|
else
|
||||||
git checkout -b "$branch_name"
|
git checkout -b "$branch_name"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Commit and push changes
|
# Commit and push changes
|
||||||
git commit -a -m "$commit_message"
|
git commit -a -m "$commit_message"
|
||||||
git push --force origin "$branch_name"
|
git push --force origin "$branch_name"
|
||||||
|
|
||||||
|
# Create PR body using here-doc for proper formatting
|
||||||
|
cat > pr_body.txt << 'EOF'
|
||||||
|
Automated Docker and Buildx version update:
|
||||||
|
|
||||||
|
- Docker: ${{ needs.check-versions.outputs.DOCKER_CURRENT_VERSION }} → ${{ needs.check-versions.outputs.DOCKER_LATEST_VERSION }}
|
||||||
|
- Buildx: ${{ needs.check-versions.outputs.BUILDX_CURRENT_VERSION }} → ${{ needs.check-versions.outputs.BUILDX_LATEST_VERSION }}
|
||||||
|
|
||||||
|
This update ensures we're using the latest stable Docker and Buildx versions for security and performance improvements.
|
||||||
|
|
||||||
|
**Release notes:** https://docs.docker.com/engine/release-notes/
|
||||||
|
|
||||||
|
**Next steps:**
|
||||||
|
- Review the version changes
|
||||||
|
- Verify container builds work as expected
|
||||||
|
- Test multi-platform builds if applicable
|
||||||
|
- Merge when ready
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
Autogenerated by [Docker/Buildx Version Upgrade Workflow](https://github.com/actions/runner/blob/main/.github/workflows/docker-buildx-upgrade.yml)
|
||||||
|
EOF
|
||||||
|
|
||||||
# Create PR
|
# Create PR
|
||||||
pr_body="Upgrades Docker version from ${{ needs.check-versions.outputs.DOCKER_CURRENT_VERSION }} to ${{ needs.check-versions.outputs.DOCKER_LATEST_VERSION }} and Docker Buildx version from ${{ needs.check-versions.outputs.BUILDX_CURRENT_VERSION }} to ${{ needs.check-versions.outputs.BUILDX_LATEST_VERSION }}.\n\n"
|
|
||||||
pr_body+="Release notes: https://docs.docker.com/engine/release-notes/\n\n"
|
|
||||||
pr_body+="---\n\nAutogenerated by [Docker/Buildx Version Upgrade Workflow](https://github.com/actions/runner/blob/main/.github/workflows/docker-buildx-upgrade.yml)"
|
|
||||||
|
|
||||||
gh pr create -B main -H "$branch_name" \
|
gh pr create -B main -H "$branch_name" \
|
||||||
--title "$pr_title" \
|
--title "$pr_title" \
|
||||||
--body "$pr_body"
|
--label "dependencies" \
|
||||||
|
--label "dependencies-weekly-check" \
|
||||||
|
--label "dependencies-not-dependabot" \
|
||||||
|
--label "docker" \
|
||||||
|
--body-file pr_body.txt
|
||||||
|
|||||||
32
.github/workflows/dotnet-upgrade.yml
vendored
32
.github/workflows/dotnet-upgrade.yml
vendored
@@ -2,13 +2,13 @@ name: "DotNet SDK Upgrade"
|
|||||||
|
|
||||||
on:
|
on:
|
||||||
schedule:
|
schedule:
|
||||||
- cron: '0 0 * * 1'
|
- cron: "0 8 * * 1" # Weekly on Monday at 8 AM UTC (independent of Node.js/NPM)
|
||||||
workflow_dispatch:
|
workflow_dispatch:
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
dotnet-update:
|
dotnet-update:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
outputs:
|
outputs:
|
||||||
SHOULD_UPDATE: ${{ steps.fetch_latest_version.outputs.SHOULD_UPDATE }}
|
SHOULD_UPDATE: ${{ steps.fetch_latest_version.outputs.SHOULD_UPDATE }}
|
||||||
BRANCH_EXISTS: ${{ steps.fetch_latest_version.outputs.BRANCH_EXISTS }}
|
BRANCH_EXISTS: ${{ steps.fetch_latest_version.outputs.BRANCH_EXISTS }}
|
||||||
DOTNET_LATEST_MAJOR_MINOR_PATCH_VERSION: ${{ steps.fetch_latest_version.outputs.DOTNET_LATEST_MAJOR_MINOR_PATCH_VERSION }}
|
DOTNET_LATEST_MAJOR_MINOR_PATCH_VERSION: ${{ steps.fetch_latest_version.outputs.DOTNET_LATEST_MAJOR_MINOR_PATCH_VERSION }}
|
||||||
@@ -37,7 +37,7 @@ jobs:
|
|||||||
|
|
||||||
# check if git branch already exists for the upgrade
|
# check if git branch already exists for the upgrade
|
||||||
branch_already_exists=0
|
branch_already_exists=0
|
||||||
|
|
||||||
if git ls-remote --heads --exit-code origin refs/heads/feature/dotnetsdk-upgrade/${latest_patch_version};
|
if git ls-remote --heads --exit-code origin refs/heads/feature/dotnetsdk-upgrade/${latest_patch_version};
|
||||||
then
|
then
|
||||||
branch_already_exists=1
|
branch_already_exists=1
|
||||||
@@ -89,17 +89,17 @@ jobs:
|
|||||||
if: ${{ needs.dotnet-update.outputs.SHOULD_UPDATE == 1 && needs.dotnet-update.outputs.BRANCH_EXISTS == 0 }}
|
if: ${{ needs.dotnet-update.outputs.SHOULD_UPDATE == 1 && needs.dotnet-update.outputs.BRANCH_EXISTS == 0 }}
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v5
|
- uses: actions/checkout@v5
|
||||||
with:
|
with:
|
||||||
ref: feature/dotnetsdk-upgrade/${{ needs.dotnet-update.outputs.DOTNET_LATEST_MAJOR_MINOR_PATCH_VERSION }}
|
ref: feature/dotnetsdk-upgrade/${{ needs.dotnet-update.outputs.DOTNET_LATEST_MAJOR_MINOR_PATCH_VERSION }}
|
||||||
- name: Create Pull Request
|
- name: Create Pull Request
|
||||||
env:
|
env:
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
run: |
|
run: |
|
||||||
gh pr create -B main -H feature/dotnetsdk-upgrade/${{ needs.dotnet-update.outputs.DOTNET_LATEST_MAJOR_MINOR_PATCH_VERSION }} --title "Update dotnet sdk to latest version @${{ needs.dotnet-update.outputs.DOTNET_LATEST_MAJOR_MINOR_PATCH_VERSION }}" --body "
|
gh pr create -B main -H feature/dotnetsdk-upgrade/${{ needs.dotnet-update.outputs.DOTNET_LATEST_MAJOR_MINOR_PATCH_VERSION }} --title "Update dotnet sdk to latest version @${{ needs.dotnet-update.outputs.DOTNET_LATEST_MAJOR_MINOR_PATCH_VERSION }}" --label "dependencies" --label "dependencies-weekly-check" --label "dependencies-not-dependabot" --label "dotnet" --body "
|
||||||
https://dotnetcli.blob.core.windows.net/dotnet/Sdk/${{ needs.dotnet-update.outputs.DOTNET_CURRENT_MAJOR_MINOR_VERSION }}/latest.version
|
https://dotnetcli.blob.core.windows.net/dotnet/Sdk/${{ needs.dotnet-update.outputs.DOTNET_CURRENT_MAJOR_MINOR_VERSION }}/latest.version
|
||||||
|
|
||||||
|
|
||||||
---
|
|
||||||
|
---
|
||||||
Autogenerated by [DotNet SDK Upgrade Workflow](https://github.com/actions/runner/blob/main/.github/workflows/dotnet-upgrade.yml)"
|
|
||||||
|
Autogenerated by [DotNet SDK Upgrade Workflow](https://github.com/actions/runner/blob/main/.github/workflows/dotnet-upgrade.yml)"
|
||||||
|
|||||||
112
.github/workflows/node-upgrade.yml
vendored
Normal file
112
.github/workflows/node-upgrade.yml
vendored
Normal file
@@ -0,0 +1,112 @@
|
|||||||
|
name: Auto Update Node Version
|
||||||
|
|
||||||
|
on:
|
||||||
|
schedule:
|
||||||
|
- cron: "0 6 * * 1" # Weekly, every Monday
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
update-node:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v5
|
||||||
|
- name: Get latest Node versions
|
||||||
|
id: node-versions
|
||||||
|
run: |
|
||||||
|
set -e
|
||||||
|
echo "Fetching latest Node.js releases..."
|
||||||
|
# Get latest v20.x release
|
||||||
|
LATEST_NODE20=$(curl -s https://api.github.com/repos/nodejs/node/releases | \
|
||||||
|
jq -r '.[] | select(.tag_name | startswith("v20.")) | .tag_name' | \
|
||||||
|
head -1 | sed 's/^v//')
|
||||||
|
# Get latest v24.x release
|
||||||
|
LATEST_NODE24=$(curl -s https://api.github.com/repos/nodejs/node/releases | \
|
||||||
|
jq -r '.[] | select(.tag_name | startswith("v24.")) | .tag_name' | \
|
||||||
|
head -1 | sed 's/^v//')
|
||||||
|
echo "Found Node.js releases: 20=$LATEST_NODE20, 24=$LATEST_NODE24"
|
||||||
|
# Verify these versions are available in alpine_nodejs releases
|
||||||
|
echo "Verifying availability in alpine_nodejs..."
|
||||||
|
ALPINE_RELEASES=$(curl -s https://api.github.com/repos/actions/alpine_nodejs/releases | jq -r '.[].tag_name')
|
||||||
|
if ! echo "$ALPINE_RELEASES" | grep -q "^node20-$LATEST_NODE20$"; then
|
||||||
|
echo "::warning title=Node 20 Fallback::Node 20 version $LATEST_NODE20 not found in alpine_nodejs releases, using fallback"
|
||||||
|
LATEST_NODE20=$(echo "$ALPINE_RELEASES" | grep "^node20-" | head -1 | sed 's/^node20-//')
|
||||||
|
echo "Using latest available alpine_nodejs Node 20: $LATEST_NODE20"
|
||||||
|
fi
|
||||||
|
if ! echo "$ALPINE_RELEASES" | grep -q "^node24-$LATEST_NODE24$"; then
|
||||||
|
echo "::warning title=Node 24 Fallback::Node 24 version $LATEST_NODE24 not found in alpine_nodejs releases, using fallback"
|
||||||
|
LATEST_NODE24=$(echo "$ALPINE_RELEASES" | grep "^node24-" | head -1 | sed 's/^node24-//')
|
||||||
|
echo "Using latest available alpine_nodejs Node 24: $LATEST_NODE24"
|
||||||
|
fi
|
||||||
|
# Abort if no valid Node versions are found
|
||||||
|
if [ -z "$LATEST_NODE20" ] && [ -z "$LATEST_NODE24" ]; then
|
||||||
|
echo "::error title=Node Version Update::Could not find valid Node 20 or Node 24 version in alpine_nodejs releases. Aborting."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
# Check current versions in externals.sh
|
||||||
|
CURRENT_NODE20=$(grep "NODE20_VERSION=" src/Misc/externals.sh | cut -d'"' -f2)
|
||||||
|
CURRENT_NODE24=$(grep "NODE24_VERSION=" src/Misc/externals.sh | cut -d'"' -f2)
|
||||||
|
echo "current_node20=$CURRENT_NODE20" >> $GITHUB_OUTPUT
|
||||||
|
echo "current_node24=$CURRENT_NODE24" >> $GITHUB_OUTPUT
|
||||||
|
# Determine if updates are needed
|
||||||
|
NEEDS_UPDATE20="false"
|
||||||
|
NEEDS_UPDATE24="false"
|
||||||
|
if [ -n "$LATEST_NODE20" ] && [ "$CURRENT_NODE20" != "$LATEST_NODE20" ]; then
|
||||||
|
NEEDS_UPDATE20="true"
|
||||||
|
echo "::notice title=Node 20 Update Available::Current: $CURRENT_NODE20 → Latest: $LATEST_NODE20"
|
||||||
|
fi
|
||||||
|
if [ -n "$LATEST_NODE24" ] && [ "$CURRENT_NODE24" != "$LATEST_NODE24" ]; then
|
||||||
|
NEEDS_UPDATE24="true"
|
||||||
|
echo "::notice title=Node 24 Update Available::Current: $CURRENT_NODE24 → Latest: $LATEST_NODE24"
|
||||||
|
fi
|
||||||
|
if [ "$NEEDS_UPDATE20" == "false" ] && [ "$NEEDS_UPDATE24" == "false" ]; then
|
||||||
|
echo "::notice title=No Updates Needed::All Node.js versions are up to date"
|
||||||
|
fi
|
||||||
|
echo "latest_node20=$LATEST_NODE20" >> $GITHUB_OUTPUT
|
||||||
|
echo "latest_node24=$LATEST_NODE24" >> $GITHUB_OUTPUT
|
||||||
|
echo "needs_update20=$NEEDS_UPDATE20" >> $GITHUB_OUTPUT
|
||||||
|
echo "needs_update24=$NEEDS_UPDATE24" >> $GITHUB_OUTPUT
|
||||||
|
- name: Update externals.sh and create PR
|
||||||
|
if: steps.node-versions.outputs.needs_update20 == 'true' || steps.node-versions.outputs.needs_update24 == 'true'
|
||||||
|
env:
|
||||||
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
run: |
|
||||||
|
set -e
|
||||||
|
# Only update if a valid version is found
|
||||||
|
if [ "${{ steps.node-versions.outputs.needs_update20 }}" == "true" ] && [ -n "${{ steps.node-versions.outputs.latest_node20 }}" ]; then
|
||||||
|
sed -i 's/NODE20_VERSION="[^"]*"/NODE20_VERSION="${{ steps.node-versions.outputs.latest_node20 }}"/' src/Misc/externals.sh
|
||||||
|
fi
|
||||||
|
if [ "${{ steps.node-versions.outputs.needs_update24 }}" == "true" ] && [ -n "${{ steps.node-versions.outputs.latest_node24 }}" ]; then
|
||||||
|
sed -i 's/NODE24_VERSION="[^"]*"/NODE24_VERSION="${{ steps.node-versions.outputs.latest_node24 }}"/' src/Misc/externals.sh
|
||||||
|
fi
|
||||||
|
# Configure git
|
||||||
|
git config --global user.name "github-actions[bot]"
|
||||||
|
git config --global user.email "<41898282+github-actions[bot]@users.noreply.github.com>"
|
||||||
|
# Create branch and commit changes
|
||||||
|
branch_name="chore/update-node"
|
||||||
|
git checkout -b "$branch_name"
|
||||||
|
git commit -a -m "chore: update Node versions (20: ${{ steps.node-versions.outputs.latest_node20 }}, 24: ${{ steps.node-versions.outputs.latest_node24 }})"
|
||||||
|
git push --force origin "$branch_name"
|
||||||
|
# Create PR body using here-doc for proper formatting
|
||||||
|
cat > pr_body.txt << EOF
|
||||||
|
Automated Node.js version update:
|
||||||
|
|
||||||
|
- Node 20: ${{ steps.node-versions.outputs.current_node20 }} → ${{ steps.node-versions.outputs.latest_node20 }}
|
||||||
|
- Node 24: ${{ steps.node-versions.outputs.current_node24 }} → ${{ steps.node-versions.outputs.latest_node24 }}
|
||||||
|
|
||||||
|
This update ensures we're using the latest stable Node.js versions for security and performance improvements.
|
||||||
|
|
||||||
|
**Note**: When updating Node versions, remember to also create a new release of alpine_nodejs at the updated version following the instructions at: https://github.com/actions/alpine_nodejs
|
||||||
|
|
||||||
|
---
|
||||||
|
Autogenerated by [Node Version Upgrade Workflow](https://github.com/actions/runner/blob/main/.github/workflows/node-upgrade.yml)
|
||||||
|
EOF
|
||||||
|
# Create PR
|
||||||
|
gh pr create -B main -H "$branch_name" \
|
||||||
|
--title "chore: update Node versions" \
|
||||||
|
--label "dependencies" \
|
||||||
|
--label "dependencies-weekly-check" \
|
||||||
|
--label "dependencies-not-dependabot" \
|
||||||
|
--label "node" \
|
||||||
|
--label "javascript" \
|
||||||
|
--body-file pr_body.txt
|
||||||
|
echo "::notice title=PR Created::Successfully created Node.js version update PR on branch $branch_name"
|
||||||
235
.github/workflows/npm-audit-typescript.yml
vendored
Normal file
235
.github/workflows/npm-audit-typescript.yml
vendored
Normal file
@@ -0,0 +1,235 @@
|
|||||||
|
name: NPM Audit Fix with TypeScript Auto-Fix
|
||||||
|
|
||||||
|
on:
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
npm-audit-with-ts-fix:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v5
|
||||||
|
- name: Setup Node.js
|
||||||
|
uses: actions/setup-node@v4
|
||||||
|
with:
|
||||||
|
node-version: "20"
|
||||||
|
- name: NPM install and audit fix with TypeScript auto-repair
|
||||||
|
working-directory: src/Misc/expressionFunc/hashFiles
|
||||||
|
run: |
|
||||||
|
npm install
|
||||||
|
|
||||||
|
# Check for vulnerabilities first
|
||||||
|
echo "Checking for npm vulnerabilities..."
|
||||||
|
if npm audit --audit-level=moderate; then
|
||||||
|
echo "✅ No moderate or higher vulnerabilities found"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "⚠️ Vulnerabilities found, attempting npm audit fix..."
|
||||||
|
|
||||||
|
# Attempt audit fix and capture the result
|
||||||
|
if npm audit fix; then
|
||||||
|
echo "✅ npm audit fix completed successfully"
|
||||||
|
AUDIT_FIX_STATUS="success"
|
||||||
|
else
|
||||||
|
echo "⚠️ npm audit fix failed or had issues"
|
||||||
|
AUDIT_FIX_STATUS="failed"
|
||||||
|
|
||||||
|
# Try audit fix with --force as a last resort for critical/high vulns only
|
||||||
|
echo "Checking if critical/high vulnerabilities remain..."
|
||||||
|
if ! npm audit --audit-level=high; then
|
||||||
|
echo "🚨 Critical/high vulnerabilities remain, attempting --force fix..."
|
||||||
|
if npm audit fix --force; then
|
||||||
|
echo "⚠️ npm audit fix --force completed (may have breaking changes)"
|
||||||
|
AUDIT_FIX_STATUS="force-fixed"
|
||||||
|
else
|
||||||
|
echo "❌ npm audit fix --force also failed"
|
||||||
|
AUDIT_FIX_STATUS="force-failed"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo "✅ Only moderate/low vulnerabilities remain after failed fix"
|
||||||
|
AUDIT_FIX_STATUS="partial-success"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "AUDIT_FIX_STATUS=$AUDIT_FIX_STATUS" >> $GITHUB_ENV
|
||||||
|
|
||||||
|
# Try to fix TypeScript issues automatically
|
||||||
|
echo "Attempting to fix TypeScript compatibility issues..."
|
||||||
|
|
||||||
|
# Check if build fails
|
||||||
|
if ! npm run build 2>/dev/null; then
|
||||||
|
echo "Build failed, attempting automated fixes..."
|
||||||
|
|
||||||
|
# Common fix 1: Update @types/node to latest compatible version
|
||||||
|
echo "Trying to update @types/node to latest version..."
|
||||||
|
npm update @types/node
|
||||||
|
|
||||||
|
# Common fix 2: If that doesn't work, try installing a specific known-good version
|
||||||
|
if ! npm run build 2>/dev/null; then
|
||||||
|
echo "Trying specific @types/node version..."
|
||||||
|
# Try Node 20 compatible version
|
||||||
|
npm install --save-dev @types/node@^20.0.0
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Common fix 3: Clear node_modules and reinstall if still failing
|
||||||
|
if ! npm run build 2>/dev/null; then
|
||||||
|
echo "Clearing node_modules and reinstalling..."
|
||||||
|
rm -rf node_modules package-lock.json
|
||||||
|
npm install
|
||||||
|
|
||||||
|
# Re-run audit fix after clean install if it was successful before
|
||||||
|
if [[ "$AUDIT_FIX_STATUS" == "success" || "$AUDIT_FIX_STATUS" == "force-fixed" ]]; then
|
||||||
|
echo "Re-running npm audit fix after clean install..."
|
||||||
|
npm audit fix || echo "Audit fix failed on second attempt"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Common fix 4: Try updating TypeScript itself
|
||||||
|
if ! npm run build 2>/dev/null; then
|
||||||
|
echo "Trying to update TypeScript..."
|
||||||
|
npm update typescript
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Final check
|
||||||
|
if npm run build 2>/dev/null; then
|
||||||
|
echo "✅ Successfully fixed TypeScript issues automatically"
|
||||||
|
else
|
||||||
|
echo "⚠️ Could not automatically fix TypeScript issues"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo "✅ Build passes after audit fix"
|
||||||
|
fi
|
||||||
|
|
||||||
|
- name: Create PR if changes exist
|
||||||
|
env:
|
||||||
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
HUSKY: 0 # Disable husky hooks for automated commits
|
||||||
|
run: |
|
||||||
|
# Check if there are any changes
|
||||||
|
if [ -n "$(git status --porcelain)" ]; then
|
||||||
|
# Configure git
|
||||||
|
git config --global user.name "github-actions[bot]"
|
||||||
|
git config --global user.email "<41898282+github-actions[bot]@users.noreply.github.com>"
|
||||||
|
|
||||||
|
# Create branch and commit changes
|
||||||
|
branch_name="chore/npm-audit-fix-with-ts-repair"
|
||||||
|
git checkout -b "$branch_name"
|
||||||
|
|
||||||
|
# Commit with --no-verify to skip husky hooks
|
||||||
|
git commit -a -m "chore: npm audit fix with automated TypeScript compatibility fixes" --no-verify
|
||||||
|
git push --force origin "$branch_name"
|
||||||
|
|
||||||
|
# Check final build status and gather info about what was changed
|
||||||
|
build_status="✅ Build passes"
|
||||||
|
fixes_applied=""
|
||||||
|
cd src/Misc/expressionFunc/hashFiles
|
||||||
|
|
||||||
|
# Check what packages were updated
|
||||||
|
if git diff HEAD~1 package.json | grep -q "@types/node"; then
|
||||||
|
fixes_applied+="\n- Updated @types/node version for TypeScript compatibility"
|
||||||
|
fi
|
||||||
|
if git diff HEAD~1 package.json | grep -q "typescript"; then
|
||||||
|
fixes_applied+="\n- Updated TypeScript version"
|
||||||
|
fi
|
||||||
|
if git diff HEAD~1 package-lock.json | grep -q "resolved"; then
|
||||||
|
fixes_applied+="\n- Updated package dependencies via npm audit fix"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if ! npm run build 2>/dev/null; then
|
||||||
|
build_status="⚠️ Build fails - manual review required"
|
||||||
|
fi
|
||||||
|
cd - > /dev/null
|
||||||
|
|
||||||
|
# Create enhanced PR body using here-doc for proper formatting
|
||||||
|
audit_status_msg=""
|
||||||
|
case "$AUDIT_FIX_STATUS" in
|
||||||
|
"success")
|
||||||
|
audit_status_msg="✅ **Audit Fix**: Completed successfully"
|
||||||
|
;;
|
||||||
|
"partial-success")
|
||||||
|
audit_status_msg="⚠️ **Audit Fix**: Partial success (only moderate/low vulnerabilities remain)"
|
||||||
|
;;
|
||||||
|
"force-fixed")
|
||||||
|
audit_status_msg="⚠️ **Audit Fix**: Completed with --force (may have breaking changes)"
|
||||||
|
;;
|
||||||
|
"failed"|"force-failed")
|
||||||
|
audit_status_msg="❌ **Audit Fix**: Failed to resolve vulnerabilities"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
audit_status_msg="❓ **Audit Fix**: Status unknown"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
if [[ "$build_status" == *"fails"* ]]; then
|
||||||
|
cat > pr_body.txt << EOF
|
||||||
|
Automated npm audit fix with TypeScript auto-repair for hashFiles dependencies.
|
||||||
|
|
||||||
|
**Build Status**: ⚠️ Build fails - manual review required
|
||||||
|
$audit_status_msg
|
||||||
|
|
||||||
|
This workflow attempts to automatically fix TypeScript compatibility issues that may arise from npm audit fixes.
|
||||||
|
|
||||||
|
⚠️ **Manual Review Required**: The build is currently failing after automated fixes were attempted.
|
||||||
|
|
||||||
|
Common issues and solutions:
|
||||||
|
- Check for TypeScript version compatibility with Node.js types
|
||||||
|
- Review breaking changes in updated dependencies
|
||||||
|
- Consider pinning problematic dependency versions temporarily
|
||||||
|
- Review tsconfig.json for compatibility settings
|
||||||
|
|
||||||
|
**Automated Fix Strategy**:
|
||||||
|
1. Run npm audit fix with proper error handling
|
||||||
|
2. Update @types/node to latest compatible version
|
||||||
|
3. Try Node 20 specific @types/node version if needed
|
||||||
|
4. Clean reinstall dependencies if conflicts persist
|
||||||
|
5. Update TypeScript compiler if necessary
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
Autogenerated by [NPM Audit Fix with TypeScript Auto-Fix Workflow](https://github.com/actions/runner/blob/main/.github/workflows/npm-audit-ts-fix.yml)
|
||||||
|
EOF
|
||||||
|
else
|
||||||
|
cat > pr_body.txt << EOF
|
||||||
|
Automated npm audit fix with TypeScript auto-repair for hashFiles dependencies.
|
||||||
|
|
||||||
|
**Build Status**: ✅ Build passes
|
||||||
|
$audit_status_msg
|
||||||
|
|
||||||
|
This workflow attempts to automatically fix TypeScript compatibility issues that may arise from npm audit fixes.
|
||||||
|
|
||||||
|
✅ **Ready to Merge**: All automated fixes were successful and the build passes.
|
||||||
|
|
||||||
|
**Automated Fix Strategy**:
|
||||||
|
1. Run npm audit fix with proper error handling
|
||||||
|
2. Update @types/node to latest compatible version
|
||||||
|
3. Try Node 20 specific @types/node version if needed
|
||||||
|
4. Clean reinstall dependencies if conflicts persist
|
||||||
|
5. Update TypeScript compiler if necessary
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
Autogenerated by [NPM Audit Fix with TypeScript Auto-Fix Workflow](https://github.com/actions/runner/blob/main/.github/workflows/npm-audit-ts-fix.yml)
|
||||||
|
EOF
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -n "$fixes_applied" ]; then
|
||||||
|
# Add the fixes applied section to the file
|
||||||
|
sed -i "/This workflow attempts/a\\
|
||||||
|
\\
|
||||||
|
**Automated Fixes Applied**:$fixes_applied" pr_body.txt
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Create PR with appropriate labels
|
||||||
|
labels="dependencies,dependencies-not-dependabot,typescript,npm,security"
|
||||||
|
if [[ "$build_status" == *"fails"* ]]; then
|
||||||
|
labels="dependencies,dependencies-not-dependabot,typescript,npm,security,needs-manual-review"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Create PR
|
||||||
|
gh pr create -B main -H "$branch_name" \
|
||||||
|
--title "chore: npm audit fix with TypeScript auto-repair" \
|
||||||
|
--label "$labels" \
|
||||||
|
--body-file pr_body.txt
|
||||||
|
else
|
||||||
|
echo "No changes to commit"
|
||||||
|
fi
|
||||||
137
.github/workflows/npm-audit.yml
vendored
Normal file
137
.github/workflows/npm-audit.yml
vendored
Normal file
@@ -0,0 +1,137 @@
|
|||||||
|
name: NPM Audit Fix
|
||||||
|
|
||||||
|
on:
|
||||||
|
schedule:
|
||||||
|
- cron: "0 7 * * 1" # Weekly on Monday at 7 AM UTC
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
npm-audit:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v5
|
||||||
|
|
||||||
|
- name: Setup Node.js
|
||||||
|
uses: actions/setup-node@v4
|
||||||
|
with:
|
||||||
|
node-version: "20"
|
||||||
|
|
||||||
|
- name: NPM install and audit fix
|
||||||
|
working-directory: src/Misc/expressionFunc/hashFiles
|
||||||
|
run: |
|
||||||
|
npm install
|
||||||
|
|
||||||
|
# Check what vulnerabilities exist
|
||||||
|
echo "=== Checking current vulnerabilities ==="
|
||||||
|
npm audit || true
|
||||||
|
|
||||||
|
# Apply audit fix --force to get security updates
|
||||||
|
echo "=== Applying npm audit fix --force ==="
|
||||||
|
npm audit fix --force
|
||||||
|
|
||||||
|
# Test if build still works and set status
|
||||||
|
echo "=== Testing build compatibility ==="
|
||||||
|
if npm run all; then
|
||||||
|
echo "✅ Build successful after audit fix"
|
||||||
|
echo "AUDIT_FIX_STATUS=success" >> $GITHUB_ENV
|
||||||
|
else
|
||||||
|
echo "❌ Build failed after audit fix - will create PR with fix instructions"
|
||||||
|
echo "AUDIT_FIX_STATUS=build_failed" >> $GITHUB_ENV
|
||||||
|
fi
|
||||||
|
|
||||||
|
- name: Create PR if changes exist
|
||||||
|
env:
|
||||||
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
run: |
|
||||||
|
# Check if there are any changes
|
||||||
|
if [ -n "$(git status --porcelain)" ]; then
|
||||||
|
# Configure git
|
||||||
|
git config --global user.name "github-actions[bot]"
|
||||||
|
git config --global user.email "41898282+github-actions[bot]@users.noreply.github.com"
|
||||||
|
|
||||||
|
# Create branch and commit changes
|
||||||
|
branch_name="chore/npm-audit-fix-$(date +%Y%m%d)"
|
||||||
|
git checkout -b "$branch_name"
|
||||||
|
git add .
|
||||||
|
git commit -m "chore: npm audit fix for hashFiles dependencies" --no-verify
|
||||||
|
git push origin "$branch_name"
|
||||||
|
|
||||||
|
# Create PR body based on what actually happened
|
||||||
|
if [ "$AUDIT_FIX_STATUS" = "success" ]; then
|
||||||
|
cat > pr_body.txt << 'EOF'
|
||||||
|
Automated npm audit fix for security vulnerabilities in hashFiles dependencies.
|
||||||
|
|
||||||
|
**✅ Full Fix Applied Successfully**
|
||||||
|
This update addresses npm security advisories and ensures dependencies are secure and up-to-date.
|
||||||
|
|
||||||
|
**Changes made:**
|
||||||
|
- Applied `npm audit fix --force` to resolve security vulnerabilities
|
||||||
|
- Updated package-lock.json with security patches
|
||||||
|
- Verified build compatibility with `npm run all`
|
||||||
|
|
||||||
|
**Next steps:**
|
||||||
|
- Review the dependency changes
|
||||||
|
- Verify the hashFiles functionality still works as expected
|
||||||
|
- Merge when ready
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
Autogenerated by [NPM Audit Fix Workflow](https://github.com/actions/runner/blob/main/.github/workflows/npm-audit.yml)
|
||||||
|
EOF
|
||||||
|
elif [ "$AUDIT_FIX_STATUS" = "build_failed" ]; then
|
||||||
|
cat > pr_body.txt << 'EOF'
|
||||||
|
Automated npm audit fix for security vulnerabilities in hashFiles dependencies.
|
||||||
|
|
||||||
|
**⚠️ Security Fixes Applied - Build Issues Need Manual Resolution**
|
||||||
|
This update applies important security patches but causes build failures that require manual fixes.
|
||||||
|
|
||||||
|
**Changes made:**
|
||||||
|
- Applied `npm audit fix --force` to resolve security vulnerabilities
|
||||||
|
- Updated package-lock.json with security patches
|
||||||
|
|
||||||
|
**⚠️ Build Issues Detected:**
|
||||||
|
The build fails after applying security fixes, likely due to TypeScript compatibility issues with updated `@types/node`.
|
||||||
|
|
||||||
|
**Required Manual Fixes:**
|
||||||
|
1. Review TypeScript compilation errors in the build output
|
||||||
|
2. Update TypeScript configuration if needed
|
||||||
|
3. Consider pinning `@types/node` to a compatible version
|
||||||
|
4. Run `npm run all` locally to verify fixes
|
||||||
|
|
||||||
|
**Next steps:**
|
||||||
|
- **DO NOT merge until build issues are resolved**
|
||||||
|
- Apply manual fixes for TypeScript compatibility
|
||||||
|
- Test the hashFiles functionality still works as expected
|
||||||
|
- Merge when build passes
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
Autogenerated by [NPM Audit Fix Workflow](https://github.com/actions/runner/blob/main/.github/workflows/npm-audit.yml)
|
||||||
|
EOF
|
||||||
|
else
|
||||||
|
# Fallback case
|
||||||
|
cat > pr_body.txt << 'EOF'
|
||||||
|
Automated npm audit attempted for security vulnerabilities in hashFiles dependencies.
|
||||||
|
|
||||||
|
**ℹ️ No Changes Applied**
|
||||||
|
No security vulnerabilities were found or no changes were needed.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
Autogenerated by [NPM Audit Fix Workflow](https://github.com/actions/runner/blob/main/.github/workflows/npm-audit.yml)
|
||||||
|
EOF
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Create PR
|
||||||
|
gh pr create -B main -H "$branch_name" \
|
||||||
|
--title "chore: npm audit fix for hashFiles dependencies" \
|
||||||
|
--label "dependencies" \
|
||||||
|
--label "dependencies-weekly-check" \
|
||||||
|
--label "dependencies-not-dependabot" \
|
||||||
|
--label "npm" \
|
||||||
|
--label "typescript" \
|
||||||
|
--label "security" \
|
||||||
|
--body-file pr_body.txt
|
||||||
|
else
|
||||||
|
echo "✅ No changes to commit - npm audit fix did not modify any files"
|
||||||
|
fi
|
||||||
8
.github/workflows/release.yml
vendored
8
.github/workflows/release.yml
vendored
@@ -16,7 +16,7 @@ jobs:
|
|||||||
# Make sure ./releaseVersion match ./src/runnerversion
|
# Make sure ./releaseVersion match ./src/runnerversion
|
||||||
# Query GitHub release ensure version is not used
|
# Query GitHub release ensure version is not used
|
||||||
- name: Check version
|
- name: Check version
|
||||||
uses: actions/github-script@v7.0.1
|
uses: actions/github-script@v8.0.0
|
||||||
with:
|
with:
|
||||||
github-token: ${{secrets.GITHUB_TOKEN}}
|
github-token: ${{secrets.GITHUB_TOKEN}}
|
||||||
script: |
|
script: |
|
||||||
@@ -171,7 +171,7 @@ jobs:
|
|||||||
# Create ReleaseNote file
|
# Create ReleaseNote file
|
||||||
- name: Create ReleaseNote
|
- name: Create ReleaseNote
|
||||||
id: releaseNote
|
id: releaseNote
|
||||||
uses: actions/github-script@v7.0.1
|
uses: actions/github-script@v8.0.0
|
||||||
with:
|
with:
|
||||||
github-token: ${{secrets.GITHUB_TOKEN}}
|
github-token: ${{secrets.GITHUB_TOKEN}}
|
||||||
script: |
|
script: |
|
||||||
@@ -300,7 +300,7 @@ jobs:
|
|||||||
|
|
||||||
- name: Compute image version
|
- name: Compute image version
|
||||||
id: image
|
id: image
|
||||||
uses: actions/github-script@v7.0.1
|
uses: actions/github-script@v8.0.0
|
||||||
with:
|
with:
|
||||||
script: |
|
script: |
|
||||||
const fs = require('fs');
|
const fs = require('fs');
|
||||||
@@ -338,7 +338,7 @@ jobs:
|
|||||||
org.opencontainers.image.licenses=MIT
|
org.opencontainers.image.licenses=MIT
|
||||||
|
|
||||||
- name: Generate attestation
|
- name: Generate attestation
|
||||||
uses: actions/attest-build-provenance@v2
|
uses: actions/attest-build-provenance@v3
|
||||||
with:
|
with:
|
||||||
subject-name: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}
|
subject-name: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}
|
||||||
subject-digest: ${{ steps.build-and-push.outputs.digest }}
|
subject-digest: ${{ steps.build-and-push.outputs.digest }}
|
||||||
|
|||||||
2
.github/workflows/stale-bot.yml
vendored
2
.github/workflows/stale-bot.yml
vendored
@@ -7,7 +7,7 @@ jobs:
|
|||||||
stale:
|
stale:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/stale@v9
|
- uses: actions/stale@v10
|
||||||
with:
|
with:
|
||||||
stale-issue-message: "This issue is stale because it has been open 365 days with no activity. Remove stale label or comment or this will be closed in 15 days."
|
stale-issue-message: "This issue is stale because it has been open 365 days with no activity. Remove stale label or comment or this will be closed in 15 days."
|
||||||
close-issue-message: "This issue was closed because it has been stalled for 15 days with no activity."
|
close-issue-message: "This issue was closed because it has been stalled for 15 days with no activity."
|
||||||
|
|||||||
@@ -1,6 +1 @@
|
|||||||
#!/usr/bin/env sh
|
cd src/Misc/expressionFunc/hashFiles && npx lint-staged
|
||||||
. "$(dirname -- "$0")/_/husky.sh"
|
|
||||||
|
|
||||||
cd src/Misc/expressionFunc/hashFiles
|
|
||||||
|
|
||||||
npx lint-staged
|
|
||||||
|
|||||||
31
README.md
31
README.md
@@ -12,33 +12,28 @@ The runner is the application that runs a job from a GitHub Actions workflow. It
|
|||||||
|
|
||||||
For more information about installing and using self-hosted runners, see [Adding self-hosted runners](https://help.github.com/en/actions/automating-your-workflow-with-github-actions/adding-self-hosted-runners) and [Using self-hosted runners in a workflow](https://help.github.com/en/actions/automating-your-workflow-with-github-actions/using-self-hosted-runners-in-a-workflow)
|
For more information about installing and using self-hosted runners, see [Adding self-hosted runners](https://help.github.com/en/actions/automating-your-workflow-with-github-actions/adding-self-hosted-runners) and [Using self-hosted runners in a workflow](https://help.github.com/en/actions/automating-your-workflow-with-github-actions/using-self-hosted-runners-in-a-workflow)
|
||||||
|
|
||||||
## Download and Install
|
Runner releases:
|
||||||
|
|
||||||
 **Windows**: [Prerequisites](docs/start/envwin.md) | [Download](https://github.com/actions/runner/releases)
|
 [Pre-reqs](docs/start/envwin.md) | [Download](https://github.com/actions/runner/releases)
|
||||||
|
|
||||||
 **macOS**: [Prerequisites](docs/start/envosx.md) | [Download](https://github.com/actions/runner/releases)
|
 [Pre-reqs](docs/start/envosx.md) | [Download](https://github.com/actions/runner/releases)
|
||||||
|
|
||||||
 **Linux**: [Prerequisites](docs/start/envlinux.md) | [Download](https://github.com/actions/runner/releases)
|
 [Pre-reqs](docs/start/envlinux.md) | [Download](https://github.com/actions/runner/releases)
|
||||||
|
|
||||||
## Documentation and Resources
|
### Note
|
||||||
|
|
||||||
- 📚 **[Complete Documentation Index](docs/README.md)** - Comprehensive guide to all documentation
|
Thank you for your interest in this GitHub repo, however, right now we are not taking contributions.
|
||||||
- 📖 **[Contributing Guide](docs/contribute.md)** - Development setup, building, and testing
|
|
||||||
- 🔧 **[Automation Scripts](docs/automate.md)** - Automate runner setup and configuration
|
|
||||||
- 🛠️ **[Troubleshooting Guides](docs/checks/README.md)** - Common issues and solutions
|
|
||||||
- 🏗️ **[Architecture Decision Records](docs/adrs/README.md)** - Important architectural decisions
|
|
||||||
- ⚙️ **Platform Prerequisites:** [Linux](docs/start/envlinux.md) | [Windows](docs/start/envwin.md) | [macOS](docs/start/envosx.md)
|
|
||||||
|
|
||||||
## Support and Community
|
We continue to focus our resources on strategic areas that help our customers be successful while making developers' lives easier. While GitHub Actions remains a key part of this vision, we are allocating resources towards other areas of Actions and are not taking contributions to this repository at this time. The GitHub public roadmap is the best place to follow along for any updates on features we’re working on and what stage they’re in.
|
||||||
|
|
||||||
Thank you for your interest in this repository. Please note our current contribution and support guidelines:
|
We are taking the following steps to better direct requests related to GitHub Actions, including:
|
||||||
|
|
||||||
**Bug Reports:** You are welcome to report bugs in this repository through Issues.
|
1. We will be directing questions and support requests to our [Community Discussions area](https://github.com/orgs/community/discussions/categories/actions)
|
||||||
|
|
||||||
**Feature Requests:** Please submit feature and enhancement requests on the [GitHub Community Discussions](https://github.com/orgs/community/discussions/categories/actions) page.
|
2. High Priority bugs can be reported through Community Discussions or you can report these to our support team https://support.github.com/contact/bug-report.
|
||||||
|
|
||||||
**Support Questions:** For help and support, please use our [Community Discussions area](https://github.com/orgs/community/discussions/categories/actions).
|
3. Security Issues should be handled as per our [security.md](security.md)
|
||||||
|
|
||||||
**Security Issues:** Please report security vulnerabilities following our [security policy](security.md).
|
We will still provide security updates for this project and fix major breaking changes during this time.
|
||||||
|
|
||||||
**High Priority Issues:** Critical bugs can be reported through Community Discussions or our [support team](https://support.github.com/contact/bug-report).
|
You are welcome to still raise bugs in this repo.
|
||||||
|
|||||||
@@ -1,61 +0,0 @@
|
|||||||
# GitHub Actions Runner Documentation
|
|
||||||
|
|
||||||
Welcome to the GitHub Actions Runner documentation. This guide will help you get started with self-hosted runners, contribute to the project, and troubleshoot common issues.
|
|
||||||
|
|
||||||
## 🚀 Getting Started
|
|
||||||
|
|
||||||
### Installation and Setup
|
|
||||||
- **[Linux Prerequisites](start/envlinux.md)** - Complete setup guide for Linux systems
|
|
||||||
- **[Windows Prerequisites](start/envwin.md)** - Complete setup guide for Windows systems
|
|
||||||
- **[macOS Prerequisites](start/envosx.md)** - Complete setup guide for macOS systems
|
|
||||||
|
|
||||||
### Quick Start
|
|
||||||
1. Download the [latest runner release](https://github.com/actions/runner/releases)
|
|
||||||
2. Follow the platform-specific prerequisites guide above
|
|
||||||
3. Configure your runner with `./config.sh` (Linux/macOS) or `.\config.cmd` (Windows)
|
|
||||||
4. Start the runner with `./run.sh` (Linux/macOS) or `.\run.cmd` (Windows)
|
|
||||||
|
|
||||||
## 🔧 Administration and Automation
|
|
||||||
|
|
||||||
- **[Automation Scripts](automate.md)** - Automate runner deployment and management
|
|
||||||
- **[Troubleshooting Guides](checks/)** - Common issues and solutions
|
|
||||||
|
|
||||||
## 🏗️ Development and Contributing
|
|
||||||
|
|
||||||
- **[Contributing Guide](contribute.md)** - Development setup, building, and testing
|
|
||||||
- **[Architecture Decision Records](adrs/README.md)** - Important architectural decisions and design patterns
|
|
||||||
|
|
||||||
## 📋 Reference Materials
|
|
||||||
|
|
||||||
### System Checks and Troubleshooting
|
|
||||||
- **[Network Connectivity](checks/network.md)** - Troubleshoot network issues
|
|
||||||
- **[Git Configuration](checks/git.md)** - Git-related problems
|
|
||||||
- **[Actions Troubleshooting](checks/actions.md)** - Action-specific issues
|
|
||||||
- **[SSL Certificate Issues](checks/sslcert.md)** - Certificate and TLS problems
|
|
||||||
- **[Node.js Issues](checks/nodejs.md)** - Node.js runtime problems
|
|
||||||
- **[Internet Connectivity](checks/internet.md)** - General connectivity issues
|
|
||||||
|
|
||||||
### Development Resources
|
|
||||||
- **[Visual Studio Code Setup](contribute/vscode.md)** - IDE configuration for development
|
|
||||||
- **[Design Documentation](design/)** - Technical design documents
|
|
||||||
|
|
||||||
## 🆘 Getting Help
|
|
||||||
|
|
||||||
### Community Support
|
|
||||||
- **[GitHub Community Discussions](https://github.com/orgs/community/discussions/categories/actions)** - Ask questions and get help from the community
|
|
||||||
- **[GitHub Support](https://support.github.com/contact/bug-report)** - Report critical bugs or get professional support
|
|
||||||
|
|
||||||
### Reporting Issues
|
|
||||||
- **Bug Reports**: Open an issue in this repository
|
|
||||||
- **Feature Requests**: Use [GitHub Community Discussions](https://github.com/orgs/community/discussions/categories/actions-and-packages)
|
|
||||||
- **Security Issues**: Follow our [security policy](../security.md)
|
|
||||||
|
|
||||||
## 📖 Additional Resources
|
|
||||||
|
|
||||||
- **[GitHub Actions Documentation](https://docs.github.com/en/actions)** - Official GitHub Actions documentation
|
|
||||||
- **[Self-hosted Runners Guide](https://docs.github.com/en/actions/hosting-your-own-runners)** - GitHub's official self-hosted runner documentation
|
|
||||||
- **[Runner Releases](https://github.com/actions/runner/releases)** - Download the latest runner versions
|
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
> **Note**: This documentation is maintained by the GitHub Actions team and the community. If you find any issues or have suggestions for improvement, please open an issue or contribute a pull request.
|
|
||||||
@@ -76,76 +76,3 @@ Repo level one-liner. NOTE: replace with yourorg/yourrepo (repo level) or just
|
|||||||
```bash
|
```bash
|
||||||
curl -s https://raw.githubusercontent.com/actions/runner/main/scripts/delete.sh | bash -s yourorg/yourrepo runnername
|
curl -s https://raw.githubusercontent.com/actions/runner/main/scripts/delete.sh | bash -s yourorg/yourrepo runnername
|
||||||
```
|
```
|
||||||
|
|
||||||
## Troubleshooting
|
|
||||||
|
|
||||||
### Common Issues
|
|
||||||
|
|
||||||
#### Permission Denied
|
|
||||||
```bash
|
|
||||||
# Ensure scripts have execute permissions
|
|
||||||
chmod +x ./config.sh ./run.sh
|
|
||||||
```
|
|
||||||
|
|
||||||
#### PAT Token Issues
|
|
||||||
```bash
|
|
||||||
# Verify your PAT has the correct scopes:
|
|
||||||
# - repo (for repository-level runners)
|
|
||||||
# - admin:org (for organization-level runners)
|
|
||||||
export RUNNER_CFG_PAT=your_token_here
|
|
||||||
echo $RUNNER_CFG_PAT # Verify it's set
|
|
||||||
```
|
|
||||||
|
|
||||||
#### Network Connectivity
|
|
||||||
```bash
|
|
||||||
# Test GitHub connectivity
|
|
||||||
curl -H "Authorization: token $RUNNER_CFG_PAT" https://api.github.com/user
|
|
||||||
|
|
||||||
# For GitHub Enterprise Server
|
|
||||||
curl -H "Authorization: token $RUNNER_CFG_PAT" https://your-github-enterprise/api/v3/user
|
|
||||||
```
|
|
||||||
|
|
||||||
#### Service Installation Fails
|
|
||||||
```bash
|
|
||||||
# Check if running as appropriate user
|
|
||||||
whoami
|
|
||||||
|
|
||||||
# For Linux - ensure systemd is available
|
|
||||||
systemctl --version
|
|
||||||
|
|
||||||
# For macOS - ensure launchd is available
|
|
||||||
launchctl version
|
|
||||||
```
|
|
||||||
|
|
||||||
#### Runner Registration Fails
|
|
||||||
```bash
|
|
||||||
# Check if runner already exists
|
|
||||||
curl -H "Authorization: token $RUNNER_CFG_PAT" \
|
|
||||||
"https://api.github.com/repos/OWNER/REPO/actions/runners"
|
|
||||||
|
|
||||||
# Remove existing runner if needed
|
|
||||||
./config.sh remove --token $RUNNER_CFG_PAT
|
|
||||||
```
|
|
||||||
|
|
||||||
### Getting Help
|
|
||||||
|
|
||||||
- **Configuration Issues**: Check the [Prerequisites](start/envlinux.md) for your platform
|
|
||||||
- **Network Problems**: Review [network troubleshooting guide](checks/network.md)
|
|
||||||
- **General Support**: Visit [GitHub Community Discussions](https://github.com/orgs/community/discussions/categories/actions)
|
|
||||||
|
|
||||||
### Advanced Examples
|
|
||||||
|
|
||||||
#### Organization-level Runner with Custom Labels
|
|
||||||
```bash
|
|
||||||
export RUNNER_CFG_PAT=your_org_pat
|
|
||||||
curl -s https://raw.githubusercontent.com/actions/runner/main/scripts/create-latest-svc.sh | \
|
|
||||||
bash -s -- -s myorg -n prod-runner-1 -l production,linux,docker
|
|
||||||
```
|
|
||||||
|
|
||||||
#### Repository-level Runner for GitHub Enterprise
|
|
||||||
```bash
|
|
||||||
export RUNNER_CFG_PAT=your_ghe_pat
|
|
||||||
curl -s https://raw.githubusercontent.com/actions/runner/main/scripts/create-latest-svc.sh | \
|
|
||||||
bash -s -- -s myorg/myrepo -g github.company.com -n build-server -u builder
|
|
||||||
```
|
|
||||||
```
|
|
||||||
|
|||||||
@@ -1,66 +0,0 @@
|
|||||||
# Troubleshooting Guides
|
|
||||||
|
|
||||||
This directory contains troubleshooting guides for common issues you might encounter when setting up or running GitHub Actions self-hosted runners.
|
|
||||||
|
|
||||||
## Quick Reference
|
|
||||||
|
|
||||||
| Issue Type | Guide | Description |
|
|
||||||
|------------|-------|-------------|
|
|
||||||
| 🌐 **Network** | [network.md](network.md) | Connection issues, proxy, firewall problems |
|
|
||||||
| 🔒 **SSL/TLS** | [sslcert.md](sslcert.md) | Certificate and TLS handshake issues |
|
|
||||||
| 📦 **Git** | [git.md](git.md) | Git configuration and repository access |
|
|
||||||
| ⚡ **Actions** | [actions.md](actions.md) | Action-specific runtime issues |
|
|
||||||
| 🟢 **Node.js** | [nodejs.md](nodejs.md) | Node.js runtime and npm issues |
|
|
||||||
| 🌍 **Internet** | [internet.md](internet.md) | General internet connectivity |
|
|
||||||
|
|
||||||
## Common First Steps
|
|
||||||
|
|
||||||
Before diving into specific guides, try these general troubleshooting steps:
|
|
||||||
|
|
||||||
### 1. Check Basic Connectivity
|
|
||||||
```bash
|
|
||||||
# Test GitHub API access
|
|
||||||
curl -I https://api.github.com/
|
|
||||||
|
|
||||||
# For GitHub Enterprise Server
|
|
||||||
curl -I https://your-github-enterprise.com/api/v3/
|
|
||||||
```
|
|
||||||
|
|
||||||
### 2. Verify Runner Status
|
|
||||||
```bash
|
|
||||||
# Check if runner service is running
|
|
||||||
./svc.sh status
|
|
||||||
|
|
||||||
# View recent logs
|
|
||||||
tail -f _diag/Runner_*.log
|
|
||||||
```
|
|
||||||
|
|
||||||
### 3. Test Runner Configuration
|
|
||||||
```bash
|
|
||||||
# Re-run configuration
|
|
||||||
./config.sh
|
|
||||||
|
|
||||||
# Test connection without running
|
|
||||||
./run.sh --check
|
|
||||||
```
|
|
||||||
|
|
||||||
## Getting Additional Help
|
|
||||||
|
|
||||||
If these guides don't resolve your issue:
|
|
||||||
|
|
||||||
1. **Search existing issues** in the [runner repository](https://github.com/actions/runner/issues)
|
|
||||||
2. **Check GitHub Status** at [githubstatus.com](https://githubstatus.com)
|
|
||||||
3. **Ask the community** in [GitHub Community Discussions](https://github.com/orgs/community/discussions/categories/actions)
|
|
||||||
4. **Contact support** for critical issues via [GitHub Support](https://support.github.com/contact)
|
|
||||||
|
|
||||||
## Contributing
|
|
||||||
|
|
||||||
Found a solution to a common problem not covered here? Consider contributing:
|
|
||||||
|
|
||||||
1. Create a new `.md` file for the issue type
|
|
||||||
2. Follow the format of existing guides
|
|
||||||
3. Submit a pull request with your improvements
|
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
💡 **Tip**: Always check the `_diag/` directory for detailed log files when troubleshooting issues.
|
|
||||||
@@ -1,24 +1,5 @@
|
|||||||
# Contributions
|
# Contributions
|
||||||
|
|
||||||
## Table of Contents
|
|
||||||
|
|
||||||
- [Getting Started](#getting-started)
|
|
||||||
- [Issues](#issues)
|
|
||||||
- [Enhancements and Feature Requests](#enhancements-and-feature-requests)
|
|
||||||
- [Required Dev Dependencies](#required-dev-dependencies)
|
|
||||||
- [Quickstart: Run a Job from a Real Repository](#quickstart-run-a-job-from-a-real-repository)
|
|
||||||
- [Development Life Cycle](#development-life-cycle)
|
|
||||||
- [Clone Repository](#clone-repository)
|
|
||||||
- [Build Layout](#build-layout)
|
|
||||||
- [Test Layout](#test-layout)
|
|
||||||
- [Configure Runner](#configure-runner)
|
|
||||||
- [Run Runner](#run-runner)
|
|
||||||
- [View Logs](#view-logs)
|
|
||||||
- [Editors](#editors)
|
|
||||||
- [Styling](#styling)
|
|
||||||
|
|
||||||
## Getting Started
|
|
||||||
|
|
||||||
We welcome contributions in the form of issues and pull requests. We view the contributions and the process as the same for github and external contributors. Please note the runner typically requires changes across the entire system and we aim for issues in the runner to be entirely self contained and fixable here. Therefore, we will primarily handle bug issues opened in this repo and we kindly request you to create all feature and enhancement requests on the [GitHub Feedback](https://github.com/community/community/discussions/categories/actions-and-packages) page.
|
We welcome contributions in the form of issues and pull requests. We view the contributions and the process as the same for github and external contributors. Please note the runner typically requires changes across the entire system and we aim for issues in the runner to be entirely self contained and fixable here. Therefore, we will primarily handle bug issues opened in this repo and we kindly request you to create all feature and enhancement requests on the [GitHub Feedback](https://github.com/community/community/discussions/categories/actions-and-packages) page.
|
||||||
|
|
||||||
> IMPORTANT: Building your own runner is critical for the dev inner loop process when contributing changes. However, only runners built and distributed by GitHub (releases) are supported in production. Be aware that workflows and orchestrations run service side with the runner being a remote process to run steps. For that reason, the service can pull the runner forward so customizations can be lost.
|
> IMPORTANT: Building your own runner is critical for the dev inner loop process when contributing changes. However, only runners built and distributed by GitHub (releases) are supported in production. Be aware that workflows and orchestrations run service side with the runner being a remote process to run steps. For that reason, the service can pull the runner forward so customizations can be lost.
|
||||||
@@ -143,8 +124,8 @@ cd runner/_layout
|
|||||||
./config.(sh/cmd) # configure your custom runner
|
./config.(sh/cmd) # configure your custom runner
|
||||||
```
|
```
|
||||||
|
|
||||||
You will need the name of your repository and a runner registration token.
|
You will need your the name of your repository and a runner registration token.
|
||||||
Check the [Quickstart section](#quickstart-run-a-job-from-a-real-repository) if you don't know how to get this token.
|
Check [Quickstart](##Quickstart:-Run-a-job-from-a-real-repository) if you don't know how to get this token.
|
||||||
|
|
||||||
These can also be passed down as arguments to `config.(sh/cmd)`:
|
These can also be passed down as arguments to `config.(sh/cmd)`:
|
||||||
```bash
|
```bash
|
||||||
|
|||||||
217
docs/dependency-management.md
Normal file
217
docs/dependency-management.md
Normal file
@@ -0,0 +1,217 @@
|
|||||||
|
# Runner Dependency Management Process
|
||||||
|
|
||||||
|
## Overview
|
||||||
|
|
||||||
|
This document outlines the automated dependency management process for the GitHub Actions Runner, designed to ensure we maintain up-to-date and secure dependencies while providing predictable release cycles.
|
||||||
|
|
||||||
|
## Release Schedule
|
||||||
|
|
||||||
|
- **Monthly Runner Releases**: New runner versions are released monthly
|
||||||
|
- **Weekly Dependency Checks**: Automated workflows check for dependency updates every Monday
|
||||||
|
- **Security Patches**: Critical security vulnerabilities are addressed immediately outside the regular schedule
|
||||||
|
|
||||||
|
## Automated Workflows
|
||||||
|
|
||||||
|
**Note**: These workflows are implemented across separate PRs for easier review and independent deployment. Each workflow includes comprehensive error handling and security-focused vulnerability detection.
|
||||||
|
|
||||||
|
### 1. Foundation Labels
|
||||||
|
|
||||||
|
- **Workflow**: `.github/workflows/setup-labels.yml` (PR #4024)
|
||||||
|
- **Purpose**: Creates consistent dependency labels for all automation workflows
|
||||||
|
- **Labels**: `dependencies`, `security`, `typescript`, `needs-manual-review`
|
||||||
|
- **Prerequisite**: Must be merged before other workflows for proper labeling
|
||||||
|
|
||||||
|
### 2. Node.js Version Updates
|
||||||
|
|
||||||
|
- **Workflow**: `.github/workflows/node-upgrade.yml`
|
||||||
|
- **Schedule**: Mondays at 6:00 AM UTC
|
||||||
|
- **Purpose**: Updates Node.js 20 and 24 versions in `src/Misc/externals.sh`
|
||||||
|
- **Source**: [nodejs.org](https://nodejs.org) and [actions/alpine_nodejs](https://github.com/actions/alpine_nodejs)
|
||||||
|
- **Priority**: First (NPM depends on current Node.js versions)
|
||||||
|
|
||||||
|
### 3. NPM Security Audit
|
||||||
|
|
||||||
|
- **Primary Workflow**: `.github/workflows/npm-audit.yml` ("NPM Audit Fix")
|
||||||
|
- **Schedule**: Mondays at 7:00 AM UTC
|
||||||
|
- **Purpose**: Automated security vulnerability detection and basic fixes
|
||||||
|
- **Location**: `src/Misc/expressionFunc/hashFiles/`
|
||||||
|
- **Features**: npm audit, security patch application, PR creation
|
||||||
|
- **Dependency**: Runs after Node.js updates for optimal compatibility
|
||||||
|
|
||||||
|
- **Fallback Workflow**: `.github/workflows/npm-audit-typescript.yml` ("NPM Audit Fix with TypeScript Auto-Fix")
|
||||||
|
- **Trigger**: Manual dispatch only
|
||||||
|
- **Purpose**: Manual security audit with TypeScript compatibility fixes
|
||||||
|
- **Use Case**: When scheduled workflow fails or needs custom intervention
|
||||||
|
- **Features**: Enhanced TypeScript auto-repair, graduated security response
|
||||||
|
- **How to Use**:
|
||||||
|
1. If the scheduled "NPM Audit Fix" workflow fails, go to Actions tab
|
||||||
|
2. Select "NPM Audit Fix with TypeScript Auto-Fix" workflow
|
||||||
|
3. Click "Run workflow" and optionally specify fix level (auto/manual)
|
||||||
|
4. Review the generated PR for TypeScript compatibility issues
|
||||||
|
|
||||||
|
### 4. .NET SDK Updates
|
||||||
|
|
||||||
|
- **Workflow**: `.github/workflows/dotnet-upgrade.yml`
|
||||||
|
- **Schedule**: Mondays at midnight UTC
|
||||||
|
- **Purpose**: Updates .NET SDK and package versions with build validation
|
||||||
|
- **Features**: Global.json updates, NuGet package management, compatibility checking
|
||||||
|
- **Independence**: Runs independently of Node.js/NPM updates
|
||||||
|
|
||||||
|
### 5. Docker/Buildx Updates
|
||||||
|
|
||||||
|
- **Workflow**: `.github/workflows/docker-buildx-upgrade.yml` ("Docker/Buildx Version Upgrade")
|
||||||
|
- **Schedule**: Mondays at midnight UTC
|
||||||
|
- **Purpose**: Updates Docker and Docker Buildx versions with multi-platform validation
|
||||||
|
- **Features**: Container security scanning, multi-architecture build testing
|
||||||
|
- **Independence**: Runs independently of other dependency updates
|
||||||
|
|
||||||
|
### 6. Dependency Monitoring
|
||||||
|
|
||||||
|
- **Workflow**: `.github/workflows/dependency-check.yml` ("Dependency Status Check")
|
||||||
|
- **Schedule**: Mondays at 11:00 AM UTC
|
||||||
|
- **Purpose**: Comprehensive status report of all dependencies with security audit
|
||||||
|
- **Features**: Multi-dependency checking, npm audit status, build validation, choice of specific component checks
|
||||||
|
- **Summary**: Runs last to capture results from all morning dependency updates
|
||||||
|
|
||||||
|
## Release Process Integration
|
||||||
|
|
||||||
|
### Pre-Release Checklist
|
||||||
|
|
||||||
|
Before each monthly runner release:
|
||||||
|
|
||||||
|
1. **Check Dependency PRs**:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
# List all open dependency PRs
|
||||||
|
gh pr list --label "dependencies" --state open
|
||||||
|
|
||||||
|
# List only automated weekly dependency updates
|
||||||
|
gh pr list --label "dependencies-weekly-check" --state open
|
||||||
|
|
||||||
|
# List only custom dependency automation (not dependabot)
|
||||||
|
gh pr list --label "dependencies-not-dependabot" --state open
|
||||||
|
```
|
||||||
|
|
||||||
|
2. **Run Manual Dependency Check**:
|
||||||
|
- Go to Actions tab → "Dependency Status Check" → "Run workflow"
|
||||||
|
- Review the summary for any outdated dependencies
|
||||||
|
|
||||||
|
3. **Review and Merge Updates**:
|
||||||
|
- Prioritize security-related updates
|
||||||
|
- Test dependency updates in development environment
|
||||||
|
- Merge approved dependency PRs
|
||||||
|
|
||||||
|
### Vulnerability Response
|
||||||
|
|
||||||
|
#### Critical Security Vulnerabilities
|
||||||
|
|
||||||
|
- **Response Time**: Within 24 hours
|
||||||
|
- **Process**:
|
||||||
|
1. Assess impact on runner security
|
||||||
|
2. Create hotfix branch if runner data security is affected
|
||||||
|
3. Expedite patch release if necessary
|
||||||
|
4. Document in security advisory if applicable
|
||||||
|
|
||||||
|
#### Non-Critical Vulnerabilities
|
||||||
|
|
||||||
|
- **Response Time**: Next monthly release
|
||||||
|
- **Process**:
|
||||||
|
1. Evaluate if vulnerability affects runner functionality
|
||||||
|
2. Include fix in regular dependency update cycle
|
||||||
|
3. Document in release notes
|
||||||
|
|
||||||
|
## Monitoring and Alerts
|
||||||
|
|
||||||
|
### GitHub Actions Workflow Status
|
||||||
|
|
||||||
|
- All dependency workflows create PRs with the `dependencies` label
|
||||||
|
- Failed workflows should be investigated immediately
|
||||||
|
- Weekly dependency status reports are generated automatically
|
||||||
|
|
||||||
|
### Manual Checks
|
||||||
|
|
||||||
|
You can manually trigger dependency checks:
|
||||||
|
|
||||||
|
- **Full Status**: Run "Dependency Status Check" workflow
|
||||||
|
- **Specific Component**: Use the dropdown to check individual dependencies
|
||||||
|
|
||||||
|
## Dependency Labels
|
||||||
|
|
||||||
|
All automated dependency PRs are tagged with labels for easy filtering and management:
|
||||||
|
|
||||||
|
### Primary Labels
|
||||||
|
|
||||||
|
- **`dependencies`**: All automated dependency-related PRs
|
||||||
|
- **`dependencies-weekly-check`**: Automated weekly dependency updates from scheduled workflows
|
||||||
|
- **`dependencies-not-dependabot`**: Custom dependency automation (not created by dependabot)
|
||||||
|
- **`security`**: Security vulnerability fixes and patches
|
||||||
|
- **`typescript`**: TypeScript compatibility and type definition updates
|
||||||
|
- **`needs-manual-review`**: Complex updates requiring human verification
|
||||||
|
|
||||||
|
### Technology-Specific Labels
|
||||||
|
|
||||||
|
- **`node`**: Node.js version updates
|
||||||
|
- **`javascript`**: JavaScript runtime and tooling updates
|
||||||
|
- **`npm`**: NPM package and security updates
|
||||||
|
- **`dotnet`**: .NET SDK and NuGet package updates
|
||||||
|
- **`docker`**: Docker and container tooling updates
|
||||||
|
|
||||||
|
### Workflow-Specific Branches
|
||||||
|
|
||||||
|
- **Node.js updates**: `chore/update-node` branch
|
||||||
|
- **NPM security fixes**: `chore/npm-audit-fix-YYYYMMDD` and `chore/npm-audit-fix-with-ts-repair` branches
|
||||||
|
- **NuGet/.NET updates**: `feature/dotnetsdk-upgrade/{version}` branches
|
||||||
|
- **Docker updates**: `feature/docker-buildx-upgrade` branch
|
||||||
|
|
||||||
|
## Special Considerations
|
||||||
|
|
||||||
|
### Node.js Updates
|
||||||
|
|
||||||
|
When updating Node.js versions, remember to:
|
||||||
|
|
||||||
|
1. Create a corresponding release in [actions/alpine_nodejs](https://github.com/actions/alpine_nodejs)
|
||||||
|
2. Follow the alpine_nodejs getting started guide
|
||||||
|
3. Test container builds with new Node versions
|
||||||
|
|
||||||
|
### .NET SDK Updates
|
||||||
|
|
||||||
|
- Only patch versions are auto-updated within the same major.minor version
|
||||||
|
- Major/minor version updates require manual review and testing
|
||||||
|
|
||||||
|
### Docker Updates
|
||||||
|
|
||||||
|
- Updates include both Docker Engine and Docker Buildx
|
||||||
|
- Verify compatibility with runner container workflows
|
||||||
|
|
||||||
|
## Troubleshooting
|
||||||
|
|
||||||
|
### Common Issues
|
||||||
|
|
||||||
|
1. **NPM Audit Workflow Fails**:
|
||||||
|
- Check if `package.json` exists in `src/Misc/expressionFunc/hashFiles/`
|
||||||
|
- Verify Node.js setup step succeeded
|
||||||
|
|
||||||
|
2. **Version Detection Fails**:
|
||||||
|
- Check if upstream APIs are available
|
||||||
|
- Verify parsing logic for version extraction
|
||||||
|
|
||||||
|
3. **PR Creation Fails**:
|
||||||
|
- Ensure `GITHUB_TOKEN` has sufficient permissions
|
||||||
|
- Check if branch already exists
|
||||||
|
|
||||||
|
### Contact
|
||||||
|
|
||||||
|
For questions about the dependency management process:
|
||||||
|
|
||||||
|
- Create an issue with the `dependencies` label
|
||||||
|
- Review existing dependency management workflows
|
||||||
|
- Consult the runner team for security-related concerns
|
||||||
|
|
||||||
|
## Metrics and KPIs
|
||||||
|
|
||||||
|
Track these metrics to measure dependency management effectiveness:
|
||||||
|
|
||||||
|
- Number of open dependency PRs at release time
|
||||||
|
- Time to merge dependency updates
|
||||||
|
- Number of security vulnerabilities by severity
|
||||||
|
- Release cycle adherence (monthly target)
|
||||||
@@ -6,21 +6,10 @@
|
|||||||
|
|
||||||
Please see "[Supported architectures and operating systems for self-hosted runners](https://docs.github.com/en/actions/reference/runners/self-hosted-runners#linux)."
|
Please see "[Supported architectures and operating systems for self-hosted runners](https://docs.github.com/en/actions/reference/runners/self-hosted-runners#linux)."
|
||||||
|
|
||||||
## Quick Setup
|
## Install .Net Core 3.x Linux Dependencies
|
||||||
|
|
||||||
The `./config.sh` script will automatically check and guide you through installing .NET dependencies:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
./config.sh
|
|
||||||
# If dependencies are missing, run:
|
|
||||||
./bin/installdependencies.sh
|
|
||||||
```
|
|
||||||
|
|
||||||
## Install .NET Core Linux Dependencies
|
|
||||||
|
|
||||||
The `./config.sh` will check .NET Core dependencies during runner configuration.
|
|
||||||
You might see something like this which indicates a dependency is missing:
|
|
||||||
|
|
||||||
|
The `./config.sh` will check .Net Core 3.x dependencies during runner configuration.
|
||||||
|
You might see something like this which indicate a dependency's missing.
|
||||||
```bash
|
```bash
|
||||||
./config.sh
|
./config.sh
|
||||||
libunwind.so.8 => not found
|
libunwind.so.8 => not found
|
||||||
@@ -28,87 +17,34 @@ You might see something like this which indicates a dependency is missing:
|
|||||||
Dependencies is missing for Dotnet Core 6.0
|
Dependencies is missing for Dotnet Core 6.0
|
||||||
Execute ./bin/installdependencies.sh to install any missing Dotnet Core 6.0 dependencies.
|
Execute ./bin/installdependencies.sh to install any missing Dotnet Core 6.0 dependencies.
|
||||||
```
|
```
|
||||||
|
|
||||||
You can easily correct the problem by executing `./bin/installdependencies.sh`.
|
You can easily correct the problem by executing `./bin/installdependencies.sh`.
|
||||||
The `installdependencies.sh` script should install all required dependencies on all supported Linux versions
|
The `installdependencies.sh` script should install all required dependencies on all supported Linux versions
|
||||||
|
> Note: The `installdependencies.sh` script will try to use the default package management mechanism on your Linux flavor (ex. `yum`/`apt-get`/`apt`).
|
||||||
|
|
||||||
> **Note:** The `installdependencies.sh` script will try to use the default package management mechanism on your Linux flavor (ex. `yum`/`apt-get`/`apt`).
|
### Full dependencies list
|
||||||
|
|
||||||
## Manual Dependency Installation
|
Debian based OS (Debian, Ubuntu, Linux Mint)
|
||||||
|
|
||||||
If the automatic installation doesn't work, you can manually install dependencies using your package manager:
|
|
||||||
|
|
||||||
### Debian based OS (Debian, Ubuntu, Linux Mint)
|
|
||||||
|
|
||||||
```bash
|
|
||||||
sudo apt-get update
|
|
||||||
sudo apt-get install -y liblttng-ust1 libkrb5-3 zlib1g libssl1.1 libicu66
|
|
||||||
```
|
|
||||||
|
|
||||||
**Required packages:**
|
|
||||||
- liblttng-ust1 or liblttng-ust0
|
- liblttng-ust1 or liblttng-ust0
|
||||||
- libkrb5-3
|
- libkrb5-3
|
||||||
- zlib1g
|
- zlib1g
|
||||||
- libssl1.1, libssl1.0.2 or libssl1.0.0
|
- libssl1.1, libssl1.0.2 or libssl1.0.0
|
||||||
- libicu63, libicu60, libicu57 or libicu55
|
- libicu63, libicu60, libicu57 or libicu55
|
||||||
|
|
||||||
### Fedora based OS (Fedora, Red Hat Enterprise Linux, CentOS, Oracle Linux 7)
|
Fedora based OS (Fedora, Red Hat Enterprise Linux, CentOS, Oracle Linux 7)
|
||||||
|
|
||||||
```bash
|
|
||||||
sudo yum install -y lttng-ust openssl-libs krb5-libs zlib libicu
|
|
||||||
# Or for newer systems:
|
|
||||||
sudo dnf install -y lttng-ust openssl-libs krb5-libs zlib libicu
|
|
||||||
```
|
|
||||||
|
|
||||||
**Required packages:**
|
|
||||||
- lttng-ust
|
- lttng-ust
|
||||||
- openssl-libs
|
- openssl-libs
|
||||||
- krb5-libs
|
- krb5-libs
|
||||||
- zlib
|
- zlib
|
||||||
- libicu
|
- libicu
|
||||||
|
|
||||||
### SUSE based OS (OpenSUSE, SUSE Enterprise)
|
SUSE based OS (OpenSUSE, SUSE Enterprise)
|
||||||
|
|
||||||
```bash
|
|
||||||
sudo zypper install -y lttng-ust libopenssl1_1 krb5 zlib libicu60_2
|
|
||||||
```
|
|
||||||
|
|
||||||
**Required packages:**
|
|
||||||
- lttng-ust
|
- lttng-ust
|
||||||
- libopenssl1_1
|
- libopenssl1_1
|
||||||
- krb5
|
- krb5
|
||||||
- zlib
|
- zlib
|
||||||
- libicu60_2
|
- libicu60_2
|
||||||
|
|
||||||
## Troubleshooting
|
## [More .Net Core Prerequisites Information](https://docs.microsoft.com/en-us/dotnet/core/linux-prerequisites?tabs=netcore2x)
|
||||||
|
|
||||||
### Common Issues
|
|
||||||
|
|
||||||
**Permission denied errors:**
|
|
||||||
```bash
|
|
||||||
sudo chmod +x ./config.sh ./run.sh
|
|
||||||
```
|
|
||||||
|
|
||||||
**Missing dependencies after installation:**
|
|
||||||
```bash
|
|
||||||
# Check what's missing
|
|
||||||
ldd ./bin/Runner.Listener
|
|
||||||
# Reinstall dependencies
|
|
||||||
./bin/installdependencies.sh
|
|
||||||
```
|
|
||||||
|
|
||||||
**SSL/TLS errors:**
|
|
||||||
```bash
|
|
||||||
# Update certificates
|
|
||||||
sudo apt-get update && sudo apt-get install ca-certificates
|
|
||||||
# Or for RHEL/CentOS:
|
|
||||||
sudo yum update ca-certificates
|
|
||||||
```
|
|
||||||
|
|
||||||
### Getting Help
|
|
||||||
|
|
||||||
- Check our [troubleshooting guide](../checks/README.md)
|
|
||||||
- Search [GitHub Community Discussions](https://github.com/orgs/community/discussions/categories/actions)
|
|
||||||
- Review [common network issues](../checks/network.md)
|
|
||||||
|
|
||||||
## [More .NET Core Prerequisites Information](https://docs.microsoft.com/en-us/dotnet/core/linux-prerequisites?tabs=netcore2x)
|
|
||||||
|
|||||||
@@ -1,136 +1,9 @@
|
|||||||
|
|
||||||
|
|
||||||
#  macOS System Prerequisites
|
#  macOS/OS X System Prerequisites
|
||||||
|
|
||||||
## Supported Versions
|
## Supported Versions
|
||||||
|
|
||||||
Please see "[Supported architectures and operating systems for self-hosted runners](https://docs.github.com/en/actions/reference/runners/self-hosted-runners#macos)."
|
Please see "[Supported architectures and operating systems for self-hosted runners](https://docs.github.com/en/actions/reference/runners/self-hosted-runners#macos)."
|
||||||
|
|
||||||
## Quick Setup
|
## [More .Net Core Prerequisites Information](https://docs.microsoft.com/en-us/dotnet/core/macos-prerequisites?tabs=netcore30)
|
||||||
|
|
||||||
1. **Download** the latest runner from [releases](https://github.com/actions/runner/releases)
|
|
||||||
2. **Extract** the downloaded archive: `tar xzf actions-runner-osx-x64-*.tar.gz`
|
|
||||||
3. **Run** `./config.sh` to configure the runner
|
|
||||||
4. **Install** as a service: `sudo ./svc.sh install` and `sudo ./svc.sh start`
|
|
||||||
|
|
||||||
## System Requirements
|
|
||||||
|
|
||||||
### macOS Version
|
|
||||||
- macOS 10.15 (Catalina) or later
|
|
||||||
- Both Intel (x64) and Apple Silicon (ARM64) are supported
|
|
||||||
|
|
||||||
### Required Tools
|
|
||||||
|
|
||||||
#### Homebrew (Recommended)
|
|
||||||
Install Homebrew for easy package management:
|
|
||||||
```bash
|
|
||||||
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
|
|
||||||
```
|
|
||||||
|
|
||||||
#### Development Tools
|
|
||||||
```bash
|
|
||||||
# Install Xcode Command Line Tools
|
|
||||||
xcode-select --install
|
|
||||||
|
|
||||||
# Install essential development tools via Homebrew
|
|
||||||
brew install git curl wget
|
|
||||||
```
|
|
||||||
|
|
||||||
### .NET Runtime
|
|
||||||
- .NET 6.0 runtime (automatically included with the runner)
|
|
||||||
|
|
||||||
## Setup Steps
|
|
||||||
|
|
||||||
### 1. Download and Extract
|
|
||||||
```bash
|
|
||||||
# Create runner directory
|
|
||||||
mkdir ~/actions-runner && cd ~/actions-runner
|
|
||||||
|
|
||||||
# Download latest release (replace with actual version)
|
|
||||||
curl -O -L https://github.com/actions/runner/releases/download/v2.xyz.z/actions-runner-osx-x64-2.xyz.z.tar.gz
|
|
||||||
|
|
||||||
# Extract
|
|
||||||
tar xzf ./actions-runner-osx-x64-2.xyz.z.tar.gz
|
|
||||||
```
|
|
||||||
|
|
||||||
### 2. Configure
|
|
||||||
```bash
|
|
||||||
./config.sh --url https://github.com/YOUR_ORG/YOUR_REPO --token YOUR_TOKEN
|
|
||||||
```
|
|
||||||
|
|
||||||
### 3. Run as Service (macOS)
|
|
||||||
```bash
|
|
||||||
# Install as launchd service
|
|
||||||
sudo ./svc.sh install
|
|
||||||
|
|
||||||
# Start the service
|
|
||||||
sudo ./svc.sh start
|
|
||||||
|
|
||||||
# Check status
|
|
||||||
sudo ./svc.sh status
|
|
||||||
```
|
|
||||||
|
|
||||||
### 4. Run Interactively (Alternative)
|
|
||||||
```bash
|
|
||||||
./run.sh
|
|
||||||
```
|
|
||||||
|
|
||||||
## macOS-Specific Considerations
|
|
||||||
|
|
||||||
### Security & Privacy
|
|
||||||
- Allow the runner executable through macOS Gatekeeper
|
|
||||||
- Grant necessary permissions in System Preferences > Security & Privacy
|
|
||||||
|
|
||||||
### Code Signing
|
|
||||||
For repositories that build macOS applications:
|
|
||||||
```bash
|
|
||||||
# Install certificates for code signing
|
|
||||||
security import developer_certificates.p12 -k ~/Library/Keychains/login.keychain
|
|
||||||
```
|
|
||||||
|
|
||||||
### Xcode Integration
|
|
||||||
If building iOS/macOS apps:
|
|
||||||
```bash
|
|
||||||
# Install Xcode from App Store or developer portal
|
|
||||||
# Set Xcode path
|
|
||||||
sudo xcode-select -s /Applications/Xcode.app/Contents/Developer
|
|
||||||
```
|
|
||||||
|
|
||||||
## Troubleshooting
|
|
||||||
|
|
||||||
### Common Issues
|
|
||||||
|
|
||||||
**Permission Denied:**
|
|
||||||
```bash
|
|
||||||
chmod +x ./config.sh ./run.sh ./svc.sh
|
|
||||||
```
|
|
||||||
|
|
||||||
**Gatekeeper Issues:**
|
|
||||||
```bash
|
|
||||||
# Allow unsigned binary to run
|
|
||||||
sudo spctl --master-disable
|
|
||||||
# Or specifically allow the runner
|
|
||||||
sudo spctl --add ./bin/Runner.Listener
|
|
||||||
```
|
|
||||||
|
|
||||||
**Service Not Starting:**
|
|
||||||
```bash
|
|
||||||
# Check system logs
|
|
||||||
sudo ./svc.sh status
|
|
||||||
tail -f ~/Library/Logs/Runner_*.log
|
|
||||||
```
|
|
||||||
|
|
||||||
**Path Issues:**
|
|
||||||
```bash
|
|
||||||
# Ensure proper PATH in your shell profile
|
|
||||||
echo 'export PATH="/usr/local/bin:$PATH"' >> ~/.zshrc
|
|
||||||
source ~/.zshrc
|
|
||||||
```
|
|
||||||
|
|
||||||
### Getting Help
|
|
||||||
|
|
||||||
- Check our [troubleshooting guide](../checks/README.md)
|
|
||||||
- Review [common network issues](../checks/network.md)
|
|
||||||
- Search [GitHub Community Discussions](https://github.com/orgs/community/discussions/categories/actions)
|
|
||||||
|
|
||||||
## [More .NET Prerequisites Information](https://docs.microsoft.com/en-us/dotnet/core/macos-prerequisites?tabs=netcore30)
|
|
||||||
|
|||||||
@@ -4,92 +4,4 @@
|
|||||||
|
|
||||||
Please see "[Supported architectures and operating systems for self-hosted runners](https://docs.github.com/en/actions/reference/runners/self-hosted-runners#windows)."
|
Please see "[Supported architectures and operating systems for self-hosted runners](https://docs.github.com/en/actions/reference/runners/self-hosted-runners#windows)."
|
||||||
|
|
||||||
## Quick Setup
|
## [More .NET Core Prerequisites Information](https://docs.microsoft.com/en-us/dotnet/core/windows-prerequisites?tabs=netcore30)
|
||||||
|
|
||||||
1. **Download** the latest runner from [releases](https://github.com/actions/runner/releases)
|
|
||||||
2. **Extract** the downloaded archive to your desired directory
|
|
||||||
3. **Run** `config.cmd` as Administrator to configure the runner
|
|
||||||
4. **Install** as a service (optional): `svc.sh install` and `svc.sh start`
|
|
||||||
|
|
||||||
## System Requirements
|
|
||||||
|
|
||||||
### .NET Runtime
|
|
||||||
- .NET 6.0 runtime (automatically installed with the runner)
|
|
||||||
- Windows PowerShell 5.1 or PowerShell Core 6.0+
|
|
||||||
|
|
||||||
### Windows Features
|
|
||||||
Windows runners require the following components:
|
|
||||||
|
|
||||||
```powershell
|
|
||||||
# Enable required Windows features (run as Administrator)
|
|
||||||
Enable-WindowsOptionalFeature -Online -FeatureName Microsoft-Windows-Subsystem-Linux
|
|
||||||
```
|
|
||||||
|
|
||||||
### Visual Studio Build Tools (For builds requiring compilation)
|
|
||||||
For repositories that need to compile code, install:
|
|
||||||
|
|
||||||
- **Visual Studio 2017 or newer** [Install here](https://visualstudio.microsoft.com)
|
|
||||||
- **Visual Studio 2022 17.3 Preview or later** (for ARM64) [Install here](https://docs.microsoft.com/en-us/visualstudio/releases/2022/release-notes-preview)
|
|
||||||
|
|
||||||
### Git for Windows
|
|
||||||
- **Git for Windows** [Install here](https://git-scm.com/downloads) (required for repository operations)
|
|
||||||
|
|
||||||
## Common Setup Steps
|
|
||||||
|
|
||||||
### 1. Create Runner Directory
|
|
||||||
```cmd
|
|
||||||
mkdir C:\actions-runner
|
|
||||||
cd C:\actions-runner
|
|
||||||
```
|
|
||||||
|
|
||||||
### 2. Download and Extract
|
|
||||||
```powershell
|
|
||||||
# Download latest release
|
|
||||||
Invoke-WebRequest -Uri "https://github.com/actions/runner/releases/download/v2.xyz.z/actions-runner-win-x64-2.xyz.z.zip" -OutFile "actions-runner.zip"
|
|
||||||
# Extract
|
|
||||||
Expand-Archive -Path "actions-runner.zip" -DestinationPath "."
|
|
||||||
```
|
|
||||||
|
|
||||||
### 3. Configure
|
|
||||||
```cmd
|
|
||||||
.\config.cmd --url https://github.com/YOUR_ORG/YOUR_REPO --token YOUR_TOKEN
|
|
||||||
```
|
|
||||||
|
|
||||||
### 4. Run as Service
|
|
||||||
```cmd
|
|
||||||
# Install service
|
|
||||||
.\svc.sh install
|
|
||||||
# Start service
|
|
||||||
.\svc.sh start
|
|
||||||
```
|
|
||||||
|
|
||||||
## Troubleshooting
|
|
||||||
|
|
||||||
### Common Issues
|
|
||||||
|
|
||||||
**PowerShell Execution Policy:**
|
|
||||||
```powershell
|
|
||||||
Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope CurrentUser
|
|
||||||
```
|
|
||||||
|
|
||||||
**Windows Defender/Antivirus:**
|
|
||||||
- Add runner directory to antivirus exclusions
|
|
||||||
- Exclude `Runner.Listener.exe` and `Runner.Worker.exe`
|
|
||||||
|
|
||||||
**Firewall Issues:**
|
|
||||||
```powershell
|
|
||||||
# Allow runner through Windows Firewall
|
|
||||||
New-NetFirewallRule -DisplayName "GitHub Actions Runner" -Direction Inbound -Protocol TCP -LocalPort 443 -Action Allow
|
|
||||||
```
|
|
||||||
|
|
||||||
**Permission Issues:**
|
|
||||||
- Run `config.cmd` as Administrator
|
|
||||||
- Ensure the runner user has "Log on as a service" rights
|
|
||||||
|
|
||||||
### Getting Help
|
|
||||||
|
|
||||||
- Check our [troubleshooting guide](../checks/README.md)
|
|
||||||
- Review [common issues](../checks/actions.md)
|
|
||||||
- Search [GitHub Community Discussions](https://github.com/orgs/community/discussions/categories/actions)
|
|
||||||
|
|
||||||
## [More .NET Prerequisites Information](https://docs.microsoft.com/en-us/dotnet/core/windows-prerequisites?tabs=netcore30)
|
|
||||||
|
|||||||
@@ -5,8 +5,8 @@ ARG TARGETOS
|
|||||||
ARG TARGETARCH
|
ARG TARGETARCH
|
||||||
ARG RUNNER_VERSION
|
ARG RUNNER_VERSION
|
||||||
ARG RUNNER_CONTAINER_HOOKS_VERSION=0.7.0
|
ARG RUNNER_CONTAINER_HOOKS_VERSION=0.7.0
|
||||||
ARG DOCKER_VERSION=28.3.2
|
ARG DOCKER_VERSION=28.4.0
|
||||||
ARG BUILDX_VERSION=0.26.1
|
ARG BUILDX_VERSION=0.28.0
|
||||||
|
|
||||||
RUN apt update -y && apt install curl unzip -y
|
RUN apt update -y && apt install curl unzip -y
|
||||||
|
|
||||||
|
|||||||
1084
src/Misc/expressionFunc/hashFiles/package-lock.json
generated
1084
src/Misc/expressionFunc/hashFiles/package-lock.json
generated
File diff suppressed because it is too large
Load Diff
@@ -10,7 +10,7 @@
|
|||||||
"lint": "eslint src/**/*.ts",
|
"lint": "eslint src/**/*.ts",
|
||||||
"pack": "ncc build -o ../../layoutbin/hashFiles",
|
"pack": "ncc build -o ../../layoutbin/hashFiles",
|
||||||
"all": "npm run format && npm run lint && npm run build && npm run pack",
|
"all": "npm run format && npm run lint && npm run build && npm run pack",
|
||||||
"prepare": "cd ../../../../ && husky install"
|
"prepare": "cd ../../../../ && husky"
|
||||||
},
|
},
|
||||||
"repository": {
|
"repository": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
@@ -36,15 +36,15 @@
|
|||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@types/node": "^20.6.2",
|
"@types/node": "^20.6.2",
|
||||||
"@typescript-eslint/eslint-plugin": "^6.7.2",
|
"@typescript-eslint/eslint-plugin": "^6.21.0",
|
||||||
"@typescript-eslint/parser": "^6.7.2",
|
"@typescript-eslint/parser": "^6.7.2",
|
||||||
"@vercel/ncc": "^0.38.0",
|
"@vercel/ncc": "^0.38.3",
|
||||||
"eslint": "^8.47.0",
|
"eslint": "^8.47.0",
|
||||||
"eslint-plugin-github": "^4.10.0",
|
"eslint-plugin-github": "^4.10.2",
|
||||||
"eslint-plugin-prettier": "^5.0.0",
|
"eslint-plugin-prettier": "^5.0.0",
|
||||||
"husky": "^8.0.3",
|
"husky": "^9.1.7",
|
||||||
"lint-staged": "^15.5.0",
|
"lint-staged": "^15.5.0",
|
||||||
"prettier": "^3.0.3",
|
"prettier": "^3.0.3",
|
||||||
"typescript": "^5.2.2"
|
"typescript": "^5.9.2"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -6,8 +6,8 @@ NODE_URL=https://nodejs.org/dist
|
|||||||
NODE_ALPINE_URL=https://github.com/actions/alpine_nodejs/releases/download
|
NODE_ALPINE_URL=https://github.com/actions/alpine_nodejs/releases/download
|
||||||
# When you update Node versions you must also create a new release of alpine_nodejs at that updated version.
|
# When you update Node versions you must also create a new release of alpine_nodejs at that updated version.
|
||||||
# Follow the instructions here: https://github.com/actions/alpine_nodejs?tab=readme-ov-file#getting-started
|
# Follow the instructions here: https://github.com/actions/alpine_nodejs?tab=readme-ov-file#getting-started
|
||||||
NODE20_VERSION="20.19.4"
|
NODE20_VERSION="20.19.5"
|
||||||
NODE24_VERSION="24.5.0"
|
NODE24_VERSION="24.7.0"
|
||||||
|
|
||||||
get_abs_path() {
|
get_abs_path() {
|
||||||
# exploits the fact that pwd will print abs path when no args
|
# exploits the fact that pwd will print abs path when no args
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
SECONDS=0
|
SECONDS=0
|
||||||
while [[ $SECONDS != $1 ]]; do
|
while [[ $SECONDS -lt $1 ]]; do
|
||||||
:
|
:
|
||||||
done
|
done
|
||||||
|
|||||||
@@ -23,6 +23,8 @@ namespace GitHub.Runner.Common
|
|||||||
|
|
||||||
Task<TaskAgentMessage> GetRunnerMessageAsync(Guid? sessionId, TaskAgentStatus status, string version, string os, string architecture, bool disableUpdate, CancellationToken token);
|
Task<TaskAgentMessage> GetRunnerMessageAsync(Guid? sessionId, TaskAgentStatus status, string version, string os, string architecture, bool disableUpdate, CancellationToken token);
|
||||||
|
|
||||||
|
Task AcknowledgeRunnerRequestAsync(string runnerRequestId, Guid? sessionId, TaskAgentStatus status, string version, string os, string architecture, CancellationToken token);
|
||||||
|
|
||||||
Task UpdateConnectionIfNeeded(Uri serverUri, VssCredentials credentials);
|
Task UpdateConnectionIfNeeded(Uri serverUri, VssCredentials credentials);
|
||||||
|
|
||||||
Task ForceRefreshConnection(VssCredentials credentials);
|
Task ForceRefreshConnection(VssCredentials credentials);
|
||||||
@@ -67,10 +69,17 @@ namespace GitHub.Runner.Common
|
|||||||
var brokerSession = RetryRequest<TaskAgentMessage>(
|
var brokerSession = RetryRequest<TaskAgentMessage>(
|
||||||
async () => await _brokerHttpClient.GetRunnerMessageAsync(sessionId, version, status, os, architecture, disableUpdate, cancellationToken), cancellationToken, shouldRetry: ShouldRetryException);
|
async () => await _brokerHttpClient.GetRunnerMessageAsync(sessionId, version, status, os, architecture, disableUpdate, cancellationToken), cancellationToken, shouldRetry: ShouldRetryException);
|
||||||
|
|
||||||
|
|
||||||
return brokerSession;
|
return brokerSession;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public async Task AcknowledgeRunnerRequestAsync(string runnerRequestId, Guid? sessionId, TaskAgentStatus status, string version, string os, string architecture, CancellationToken cancellationToken)
|
||||||
|
{
|
||||||
|
CheckConnection();
|
||||||
|
|
||||||
|
// No retries
|
||||||
|
await _brokerHttpClient.AcknowledgeRunnerRequestAsync(runnerRequestId, sessionId, version, status, os, architecture, cancellationToken);
|
||||||
|
}
|
||||||
|
|
||||||
public async Task DeleteSessionAsync(CancellationToken cancellationToken)
|
public async Task DeleteSessionAsync(CancellationToken cancellationToken)
|
||||||
{
|
{
|
||||||
CheckConnection();
|
CheckConnection();
|
||||||
|
|||||||
@@ -53,6 +53,9 @@ namespace GitHub.Runner.Common
|
|||||||
[DataMember(EmitDefaultValue = false)]
|
[DataMember(EmitDefaultValue = false)]
|
||||||
public bool UseV2Flow { get; set; }
|
public bool UseV2Flow { get; set; }
|
||||||
|
|
||||||
|
[DataMember(EmitDefaultValue = false)]
|
||||||
|
public bool UseRunnerAdminFlow { get; set; }
|
||||||
|
|
||||||
[DataMember(EmitDefaultValue = false)]
|
[DataMember(EmitDefaultValue = false)]
|
||||||
public string ServerUrlV2 { get; set; }
|
public string ServerUrlV2 { get; set; }
|
||||||
|
|
||||||
|
|||||||
@@ -169,6 +169,7 @@ namespace GitHub.Runner.Common
|
|||||||
public static readonly string AllowRunnerContainerHooks = "DistributedTask.AllowRunnerContainerHooks";
|
public static readonly string AllowRunnerContainerHooks = "DistributedTask.AllowRunnerContainerHooks";
|
||||||
public static readonly string AddCheckRunIdToJobContext = "actions_add_check_run_id_to_job_context";
|
public static readonly string AddCheckRunIdToJobContext = "actions_add_check_run_id_to_job_context";
|
||||||
public static readonly string DisplayHelpfulActionsDownloadErrors = "actions_display_helpful_actions_download_errors";
|
public static readonly string DisplayHelpfulActionsDownloadErrors = "actions_display_helpful_actions_download_errors";
|
||||||
|
public static readonly string ContainerActionRunnerTemp = "actions_container_action_runner_temp";
|
||||||
}
|
}
|
||||||
|
|
||||||
// Node version migration related constants
|
// Node version migration related constants
|
||||||
|
|||||||
@@ -70,7 +70,7 @@ namespace GitHub.Runner.Common
|
|||||||
|
|
||||||
protected async Task RetryRequest(Func<Task> func,
|
protected async Task RetryRequest(Func<Task> func,
|
||||||
CancellationToken cancellationToken,
|
CancellationToken cancellationToken,
|
||||||
int maxRetryAttemptsCount = 5,
|
int maxAttempts = 5,
|
||||||
Func<Exception, bool> shouldRetry = null
|
Func<Exception, bool> shouldRetry = null
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
@@ -79,31 +79,31 @@ namespace GitHub.Runner.Common
|
|||||||
await func();
|
await func();
|
||||||
return Unit.Value;
|
return Unit.Value;
|
||||||
}
|
}
|
||||||
await RetryRequest<Unit>(wrappedFunc, cancellationToken, maxRetryAttemptsCount, shouldRetry);
|
await RetryRequest<Unit>(wrappedFunc, cancellationToken, maxAttempts, shouldRetry);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected async Task<T> RetryRequest<T>(Func<Task<T>> func,
|
protected async Task<T> RetryRequest<T>(Func<Task<T>> func,
|
||||||
CancellationToken cancellationToken,
|
CancellationToken cancellationToken,
|
||||||
int maxRetryAttemptsCount = 5,
|
int maxAttempts = 5,
|
||||||
Func<Exception, bool> shouldRetry = null
|
Func<Exception, bool> shouldRetry = null
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
var retryCount = 0;
|
var attempt = 0;
|
||||||
while (true)
|
while (true)
|
||||||
{
|
{
|
||||||
retryCount++;
|
attempt++;
|
||||||
cancellationToken.ThrowIfCancellationRequested();
|
cancellationToken.ThrowIfCancellationRequested();
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
return await func();
|
return await func();
|
||||||
}
|
}
|
||||||
// TODO: Add handling of non-retriable exceptions: https://github.com/github/actions-broker/issues/122
|
// TODO: Add handling of non-retriable exceptions: https://github.com/github/actions-broker/issues/122
|
||||||
catch (Exception ex) when (retryCount < maxRetryAttemptsCount && (shouldRetry == null || shouldRetry(ex)))
|
catch (Exception ex) when (attempt < maxAttempts && (shouldRetry == null || shouldRetry(ex)))
|
||||||
{
|
{
|
||||||
Trace.Error("Catch exception during request");
|
Trace.Error("Catch exception during request");
|
||||||
Trace.Error(ex);
|
Trace.Error(ex);
|
||||||
var backOff = BackoffTimerHelper.GetRandomBackoff(TimeSpan.FromSeconds(5), TimeSpan.FromSeconds(15));
|
var backOff = BackoffTimerHelper.GetRandomBackoff(TimeSpan.FromSeconds(5), TimeSpan.FromSeconds(15));
|
||||||
Trace.Warning($"Back off {backOff.TotalSeconds} seconds before next retry. {maxRetryAttemptsCount - retryCount} attempt left.");
|
Trace.Warning($"Back off {backOff.TotalSeconds} seconds before next retry. {maxAttempts - attempt} attempt left.");
|
||||||
await Task.Delay(backOff, cancellationToken);
|
await Task.Delay(backOff, cancellationToken);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -23,7 +23,7 @@ namespace GitHub.Runner.Listener
|
|||||||
private RunnerSettings _settings;
|
private RunnerSettings _settings;
|
||||||
private ITerminal _term;
|
private ITerminal _term;
|
||||||
private TimeSpan _getNextMessageRetryInterval;
|
private TimeSpan _getNextMessageRetryInterval;
|
||||||
private TaskAgentStatus runnerStatus = TaskAgentStatus.Online;
|
private TaskAgentStatus _runnerStatus = TaskAgentStatus.Online;
|
||||||
private CancellationTokenSource _getMessagesTokenSource;
|
private CancellationTokenSource _getMessagesTokenSource;
|
||||||
private VssCredentials _creds;
|
private VssCredentials _creds;
|
||||||
private VssCredentials _credsV2;
|
private VssCredentials _credsV2;
|
||||||
@@ -258,7 +258,7 @@ namespace GitHub.Runner.Listener
|
|||||||
public void OnJobStatus(object sender, JobStatusEventArgs e)
|
public void OnJobStatus(object sender, JobStatusEventArgs e)
|
||||||
{
|
{
|
||||||
Trace.Info("Received job status event. JobState: {0}", e.Status);
|
Trace.Info("Received job status event. JobState: {0}", e.Status);
|
||||||
runnerStatus = e.Status;
|
_runnerStatus = e.Status;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
_getMessagesTokenSource?.Cancel();
|
_getMessagesTokenSource?.Cancel();
|
||||||
@@ -291,7 +291,7 @@ namespace GitHub.Runner.Listener
|
|||||||
}
|
}
|
||||||
|
|
||||||
message = await _brokerServer.GetRunnerMessageAsync(_session.SessionId,
|
message = await _brokerServer.GetRunnerMessageAsync(_session.SessionId,
|
||||||
runnerStatus,
|
_runnerStatus,
|
||||||
BuildConstants.RunnerPackage.Version,
|
BuildConstants.RunnerPackage.Version,
|
||||||
VarUtil.OS,
|
VarUtil.OS,
|
||||||
VarUtil.OSArchitecture,
|
VarUtil.OSArchitecture,
|
||||||
@@ -417,6 +417,21 @@ namespace GitHub.Runner.Listener
|
|||||||
await Task.CompletedTask;
|
await Task.CompletedTask;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public async Task AcknowledgeMessageAsync(string runnerRequestId, CancellationToken cancellationToken)
|
||||||
|
{
|
||||||
|
using var timeoutCts = new CancellationTokenSource(TimeSpan.FromSeconds(5)); // Short timeout
|
||||||
|
using var linkedCts = CancellationTokenSource.CreateLinkedTokenSource(cancellationToken, timeoutCts.Token);
|
||||||
|
Trace.Info($"Acknowledging runner request '{runnerRequestId}'.");
|
||||||
|
await _brokerServer.AcknowledgeRunnerRequestAsync(
|
||||||
|
runnerRequestId,
|
||||||
|
_session.SessionId,
|
||||||
|
_runnerStatus,
|
||||||
|
BuildConstants.RunnerPackage.Version,
|
||||||
|
VarUtil.OS,
|
||||||
|
VarUtil.OSArchitecture,
|
||||||
|
linkedCts.Token);
|
||||||
|
}
|
||||||
|
|
||||||
private bool IsGetNextMessageExceptionRetriable(Exception ex)
|
private bool IsGetNextMessageExceptionRetriable(Exception ex)
|
||||||
{
|
{
|
||||||
if (ex is TaskAgentNotFoundException ||
|
if (ex is TaskAgentNotFoundException ||
|
||||||
|
|||||||
@@ -153,8 +153,8 @@ namespace GitHub.Runner.Listener.Configuration
|
|||||||
registerToken = await GetRunnerTokenAsync(command, inputUrl, "registration");
|
registerToken = await GetRunnerTokenAsync(command, inputUrl, "registration");
|
||||||
GitHubAuthResult authResult = await GetTenantCredential(inputUrl, registerToken, Constants.RunnerEvent.Register);
|
GitHubAuthResult authResult = await GetTenantCredential(inputUrl, registerToken, Constants.RunnerEvent.Register);
|
||||||
runnerSettings.ServerUrl = authResult.TenantUrl;
|
runnerSettings.ServerUrl = authResult.TenantUrl;
|
||||||
runnerSettings.UseV2Flow = authResult.UseV2Flow;
|
runnerSettings.UseRunnerAdminFlow = authResult.UseRunnerAdminFlow;
|
||||||
Trace.Info($"Using V2 flow: {runnerSettings.UseV2Flow}");
|
Trace.Info($"Using runner-admin flow: {runnerSettings.UseRunnerAdminFlow}");
|
||||||
creds = authResult.ToVssCredentials();
|
creds = authResult.ToVssCredentials();
|
||||||
Trace.Info("cred retrieved via GitHub auth");
|
Trace.Info("cred retrieved via GitHub auth");
|
||||||
}
|
}
|
||||||
@@ -211,7 +211,7 @@ namespace GitHub.Runner.Listener.Configuration
|
|||||||
string poolName = null;
|
string poolName = null;
|
||||||
TaskAgentPool agentPool = null;
|
TaskAgentPool agentPool = null;
|
||||||
List<TaskAgentPool> agentPools;
|
List<TaskAgentPool> agentPools;
|
||||||
if (runnerSettings.UseV2Flow)
|
if (runnerSettings.UseRunnerAdminFlow)
|
||||||
{
|
{
|
||||||
agentPools = await _dotcomServer.GetRunnerGroupsAsync(runnerSettings.GitHubUrl, registerToken);
|
agentPools = await _dotcomServer.GetRunnerGroupsAsync(runnerSettings.GitHubUrl, registerToken);
|
||||||
}
|
}
|
||||||
@@ -259,7 +259,7 @@ namespace GitHub.Runner.Listener.Configuration
|
|||||||
var userLabels = command.GetLabels();
|
var userLabels = command.GetLabels();
|
||||||
_term.WriteLine();
|
_term.WriteLine();
|
||||||
List<TaskAgent> agents;
|
List<TaskAgent> agents;
|
||||||
if (runnerSettings.UseV2Flow)
|
if (runnerSettings.UseRunnerAdminFlow)
|
||||||
{
|
{
|
||||||
agents = await _dotcomServer.GetRunnerByNameAsync(runnerSettings.GitHubUrl, registerToken, runnerSettings.AgentName);
|
agents = await _dotcomServer.GetRunnerByNameAsync(runnerSettings.GitHubUrl, registerToken, runnerSettings.AgentName);
|
||||||
}
|
}
|
||||||
@@ -280,7 +280,7 @@ namespace GitHub.Runner.Listener.Configuration
|
|||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
if (runnerSettings.UseV2Flow)
|
if (runnerSettings.UseRunnerAdminFlow)
|
||||||
{
|
{
|
||||||
var runner = await _dotcomServer.ReplaceRunnerAsync(runnerSettings.PoolId, agent, runnerSettings.GitHubUrl, registerToken, publicKeyXML);
|
var runner = await _dotcomServer.ReplaceRunnerAsync(runnerSettings.PoolId, agent, runnerSettings.GitHubUrl, registerToken, publicKeyXML);
|
||||||
runnerSettings.ServerUrlV2 = runner.RunnerAuthorization.ServerUrl;
|
runnerSettings.ServerUrlV2 = runner.RunnerAuthorization.ServerUrl;
|
||||||
@@ -330,10 +330,11 @@ namespace GitHub.Runner.Listener.Configuration
|
|||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
if (runnerSettings.UseV2Flow)
|
if (runnerSettings.UseRunnerAdminFlow)
|
||||||
{
|
{
|
||||||
var runner = await _dotcomServer.AddRunnerAsync(runnerSettings.PoolId, agent, runnerSettings.GitHubUrl, registerToken, publicKeyXML);
|
var runner = await _dotcomServer.AddRunnerAsync(runnerSettings.PoolId, agent, runnerSettings.GitHubUrl, registerToken, publicKeyXML);
|
||||||
runnerSettings.ServerUrlV2 = runner.RunnerAuthorization.ServerUrl;
|
runnerSettings.ServerUrlV2 = runner.RunnerAuthorization.ServerUrl;
|
||||||
|
runnerSettings.UseV2Flow = true; // if we are using runner admin, we also need to hit broker
|
||||||
|
|
||||||
agent.Id = runner.Id;
|
agent.Id = runner.Id;
|
||||||
agent.Authorization = new TaskAgentAuthorization()
|
agent.Authorization = new TaskAgentAuthorization()
|
||||||
@@ -400,13 +401,26 @@ namespace GitHub.Runner.Listener.Configuration
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
||||||
throw new NotSupportedException("Message queue listen OAuth token.");
|
throw new NotSupportedException("Message queue listen OAuth token.");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// allow the server to override the serverUrlV2 and useV2Flow
|
||||||
|
if (agent.Properties.TryGetValue("ServerUrlV2", out string serverUrlV2) &&
|
||||||
|
!string.IsNullOrEmpty(serverUrlV2))
|
||||||
|
{
|
||||||
|
Trace.Info($"Service enforced serverUrlV2: {serverUrlV2}");
|
||||||
|
runnerSettings.ServerUrlV2 = serverUrlV2;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (agent.Properties.TryGetValue("UseV2Flow", out bool useV2Flow) && useV2Flow)
|
||||||
|
{
|
||||||
|
Trace.Info($"Service enforced useV2Flow: {useV2Flow}");
|
||||||
|
runnerSettings.UseV2Flow = useV2Flow;
|
||||||
|
}
|
||||||
|
|
||||||
// Testing agent connection, detect any potential connection issue, like local clock skew that cause OAuth token expired.
|
// Testing agent connection, detect any potential connection issue, like local clock skew that cause OAuth token expired.
|
||||||
|
|
||||||
if (!runnerSettings.UseV2Flow)
|
if (!runnerSettings.UseV2Flow && !runnerSettings.UseRunnerAdminFlow)
|
||||||
{
|
{
|
||||||
var credMgr = HostContext.GetService<ICredentialManager>();
|
var credMgr = HostContext.GetService<ICredentialManager>();
|
||||||
VssCredentials credential = credMgr.LoadCredentials(allowAuthUrlV2: false);
|
VssCredentials credential = credMgr.LoadCredentials(allowAuthUrlV2: false);
|
||||||
@@ -429,20 +443,6 @@ namespace GitHub.Runner.Listener.Configuration
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// allow the server to override the serverUrlV2 and useV2Flow
|
|
||||||
if (agent.Properties.TryGetValue("ServerUrlV2", out string serverUrlV2) &&
|
|
||||||
!string.IsNullOrEmpty(serverUrlV2))
|
|
||||||
{
|
|
||||||
Trace.Info($"Service enforced serverUrlV2: {serverUrlV2}");
|
|
||||||
runnerSettings.ServerUrlV2 = serverUrlV2;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (agent.Properties.TryGetValue("UseV2Flow", out bool useV2Flow) && useV2Flow)
|
|
||||||
{
|
|
||||||
Trace.Info($"Service enforced useV2Flow: {useV2Flow}");
|
|
||||||
runnerSettings.UseV2Flow = useV2Flow;
|
|
||||||
}
|
|
||||||
|
|
||||||
_term.WriteSection("Runner settings");
|
_term.WriteSection("Runner settings");
|
||||||
|
|
||||||
// We will Combine() what's stored with root. Defaults to string a relative path
|
// We will Combine() what's stored with root. Defaults to string a relative path
|
||||||
@@ -538,7 +538,7 @@ namespace GitHub.Runner.Listener.Configuration
|
|||||||
{
|
{
|
||||||
RunnerSettings settings = _store.GetSettings();
|
RunnerSettings settings = _store.GetSettings();
|
||||||
|
|
||||||
if (settings.UseV2Flow)
|
if (settings.UseRunnerAdminFlow)
|
||||||
{
|
{
|
||||||
var deletionToken = await GetRunnerTokenAsync(command, settings.GitHubUrl, "remove");
|
var deletionToken = await GetRunnerTokenAsync(command, settings.GitHubUrl, "remove");
|
||||||
await _dotcomServer.DeleteRunnerAsync(settings.GitHubUrl, deletionToken, settings.AgentId);
|
await _dotcomServer.DeleteRunnerAsync(settings.GitHubUrl, deletionToken, settings.AgentId);
|
||||||
|
|||||||
@@ -89,7 +89,7 @@ namespace GitHub.Runner.Listener.Configuration
|
|||||||
public string Token { get; set; }
|
public string Token { get; set; }
|
||||||
|
|
||||||
[DataMember(Name = "use_v2_flow")]
|
[DataMember(Name = "use_v2_flow")]
|
||||||
public bool UseV2Flow { get; set; }
|
public bool UseRunnerAdminFlow { get; set; }
|
||||||
|
|
||||||
public VssCredentials ToVssCredentials()
|
public VssCredentials ToVssCredentials()
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -32,6 +32,7 @@ namespace GitHub.Runner.Listener
|
|||||||
Task DeleteSessionAsync();
|
Task DeleteSessionAsync();
|
||||||
Task<TaskAgentMessage> GetNextMessageAsync(CancellationToken token);
|
Task<TaskAgentMessage> GetNextMessageAsync(CancellationToken token);
|
||||||
Task DeleteMessageAsync(TaskAgentMessage message);
|
Task DeleteMessageAsync(TaskAgentMessage message);
|
||||||
|
Task AcknowledgeMessageAsync(string runnerRequestId, CancellationToken cancellationToken);
|
||||||
|
|
||||||
Task RefreshListenerTokenAsync();
|
Task RefreshListenerTokenAsync();
|
||||||
void OnJobStatus(object sender, JobStatusEventArgs e);
|
void OnJobStatus(object sender, JobStatusEventArgs e);
|
||||||
@@ -52,7 +53,7 @@ namespace GitHub.Runner.Listener
|
|||||||
private readonly TimeSpan _sessionConflictRetryLimit = TimeSpan.FromMinutes(4);
|
private readonly TimeSpan _sessionConflictRetryLimit = TimeSpan.FromMinutes(4);
|
||||||
private readonly TimeSpan _clockSkewRetryLimit = TimeSpan.FromMinutes(30);
|
private readonly TimeSpan _clockSkewRetryLimit = TimeSpan.FromMinutes(30);
|
||||||
private readonly Dictionary<string, int> _sessionCreationExceptionTracker = new();
|
private readonly Dictionary<string, int> _sessionCreationExceptionTracker = new();
|
||||||
private TaskAgentStatus runnerStatus = TaskAgentStatus.Online;
|
private TaskAgentStatus _runnerStatus = TaskAgentStatus.Online;
|
||||||
private CancellationTokenSource _getMessagesTokenSource;
|
private CancellationTokenSource _getMessagesTokenSource;
|
||||||
private VssCredentials _creds;
|
private VssCredentials _creds;
|
||||||
private VssCredentials _credsV2;
|
private VssCredentials _credsV2;
|
||||||
@@ -217,7 +218,7 @@ namespace GitHub.Runner.Listener
|
|||||||
public void OnJobStatus(object sender, JobStatusEventArgs e)
|
public void OnJobStatus(object sender, JobStatusEventArgs e)
|
||||||
{
|
{
|
||||||
Trace.Info("Received job status event. JobState: {0}", e.Status);
|
Trace.Info("Received job status event. JobState: {0}", e.Status);
|
||||||
runnerStatus = e.Status;
|
_runnerStatus = e.Status;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
_getMessagesTokenSource?.Cancel();
|
_getMessagesTokenSource?.Cancel();
|
||||||
@@ -250,7 +251,7 @@ namespace GitHub.Runner.Listener
|
|||||||
message = await _runnerServer.GetAgentMessageAsync(_settings.PoolId,
|
message = await _runnerServer.GetAgentMessageAsync(_settings.PoolId,
|
||||||
_session.SessionId,
|
_session.SessionId,
|
||||||
_lastMessageId,
|
_lastMessageId,
|
||||||
runnerStatus,
|
_runnerStatus,
|
||||||
BuildConstants.RunnerPackage.Version,
|
BuildConstants.RunnerPackage.Version,
|
||||||
VarUtil.OS,
|
VarUtil.OS,
|
||||||
VarUtil.OSArchitecture,
|
VarUtil.OSArchitecture,
|
||||||
@@ -274,7 +275,7 @@ namespace GitHub.Runner.Listener
|
|||||||
}
|
}
|
||||||
|
|
||||||
message = await _brokerServer.GetRunnerMessageAsync(_session.SessionId,
|
message = await _brokerServer.GetRunnerMessageAsync(_session.SessionId,
|
||||||
runnerStatus,
|
_runnerStatus,
|
||||||
BuildConstants.RunnerPackage.Version,
|
BuildConstants.RunnerPackage.Version,
|
||||||
VarUtil.OS,
|
VarUtil.OS,
|
||||||
VarUtil.OSArchitecture,
|
VarUtil.OSArchitecture,
|
||||||
@@ -437,6 +438,21 @@ namespace GitHub.Runner.Listener
|
|||||||
await _brokerServer.ForceRefreshConnection(_credsV2);
|
await _brokerServer.ForceRefreshConnection(_credsV2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public async Task AcknowledgeMessageAsync(string runnerRequestId, CancellationToken cancellationToken)
|
||||||
|
{
|
||||||
|
using var timeoutCts = new CancellationTokenSource(TimeSpan.FromSeconds(5)); // Short timeout
|
||||||
|
using var linkedCts = CancellationTokenSource.CreateLinkedTokenSource(cancellationToken, timeoutCts.Token);
|
||||||
|
Trace.Info($"Acknowledging runner request '{runnerRequestId}'.");
|
||||||
|
await _brokerServer.AcknowledgeRunnerRequestAsync(
|
||||||
|
runnerRequestId,
|
||||||
|
_session.SessionId,
|
||||||
|
_runnerStatus,
|
||||||
|
BuildConstants.RunnerPackage.Version,
|
||||||
|
VarUtil.OS,
|
||||||
|
VarUtil.OSArchitecture,
|
||||||
|
linkedCts.Token);
|
||||||
|
}
|
||||||
|
|
||||||
private TaskAgentMessage DecryptMessage(TaskAgentMessage message)
|
private TaskAgentMessage DecryptMessage(TaskAgentMessage message)
|
||||||
{
|
{
|
||||||
if (_session.EncryptionKey == null ||
|
if (_session.EncryptionKey == null ||
|
||||||
|
|||||||
@@ -654,22 +654,42 @@ namespace GitHub.Runner.Listener
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
var messageRef = StringUtil.ConvertFromJson<RunnerJobRequestRef>(message.Body);
|
var messageRef = StringUtil.ConvertFromJson<RunnerJobRequestRef>(message.Body);
|
||||||
Pipelines.AgentJobRequestMessage jobRequestMessage = null;
|
|
||||||
|
|
||||||
// Create connection
|
// Acknowledge (best-effort)
|
||||||
var credMgr = HostContext.GetService<ICredentialManager>();
|
if (messageRef.ShouldAcknowledge) // Temporary feature flag
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
await _listener.AcknowledgeMessageAsync(messageRef.RunnerRequestId, messageQueueLoopTokenSource.Token);
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
Trace.Error($"Best-effort acknowledge failed for request '{messageRef.RunnerRequestId}'");
|
||||||
|
Trace.Error(ex);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Pipelines.AgentJobRequestMessage jobRequestMessage = null;
|
||||||
if (string.IsNullOrEmpty(messageRef.RunServiceUrl))
|
if (string.IsNullOrEmpty(messageRef.RunServiceUrl))
|
||||||
{
|
{
|
||||||
|
// Connect
|
||||||
|
var credMgr = HostContext.GetService<ICredentialManager>();
|
||||||
var creds = credMgr.LoadCredentials(allowAuthUrlV2: false);
|
var creds = credMgr.LoadCredentials(allowAuthUrlV2: false);
|
||||||
var actionsRunServer = HostContext.CreateService<IActionsRunServer>();
|
var actionsRunServer = HostContext.CreateService<IActionsRunServer>();
|
||||||
await actionsRunServer.ConnectAsync(new Uri(settings.ServerUrl), creds);
|
await actionsRunServer.ConnectAsync(new Uri(settings.ServerUrl), creds);
|
||||||
|
|
||||||
|
// Get job message
|
||||||
jobRequestMessage = await actionsRunServer.GetJobMessageAsync(messageRef.RunnerRequestId, messageQueueLoopTokenSource.Token);
|
jobRequestMessage = await actionsRunServer.GetJobMessageAsync(messageRef.RunnerRequestId, messageQueueLoopTokenSource.Token);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
// Connect
|
||||||
|
var credMgr = HostContext.GetService<ICredentialManager>();
|
||||||
var credsV2 = credMgr.LoadCredentials(allowAuthUrlV2: true);
|
var credsV2 = credMgr.LoadCredentials(allowAuthUrlV2: true);
|
||||||
var runServer = HostContext.CreateService<IRunServer>();
|
var runServer = HostContext.CreateService<IRunServer>();
|
||||||
await runServer.ConnectAsync(new Uri(messageRef.RunServiceUrl), credsV2);
|
await runServer.ConnectAsync(new Uri(messageRef.RunServiceUrl), credsV2);
|
||||||
|
|
||||||
|
// Get job message
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
jobRequestMessage = await runServer.GetJobMessageAsync(messageRef.RunnerRequestId, messageRef.BillingOwnerId, messageQueueLoopTokenSource.Token);
|
jobRequestMessage = await runServer.GetJobMessageAsync(messageRef.RunnerRequestId, messageRef.BillingOwnerId, messageQueueLoopTokenSource.Token);
|
||||||
@@ -698,7 +718,10 @@ namespace GitHub.Runner.Listener
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Dispatch
|
||||||
jobDispatcher.Run(jobRequestMessage, runOnce);
|
jobDispatcher.Run(jobRequestMessage, runOnce);
|
||||||
|
|
||||||
|
// Run once?
|
||||||
if (runOnce)
|
if (runOnce)
|
||||||
{
|
{
|
||||||
Trace.Info("One time used runner received job message.");
|
Trace.Info("One time used runner received job message.");
|
||||||
|
|||||||
@@ -10,6 +10,9 @@ namespace GitHub.Runner.Listener
|
|||||||
|
|
||||||
[DataMember(Name = "runner_request_id")]
|
[DataMember(Name = "runner_request_id")]
|
||||||
public string RunnerRequestId { get; set; }
|
public string RunnerRequestId { get; set; }
|
||||||
|
|
||||||
|
[DataMember(Name = "should_acknowledge")]
|
||||||
|
public bool ShouldAcknowledge { get; set; }
|
||||||
|
|
||||||
[DataMember(Name = "run_service_url")]
|
[DataMember(Name = "run_service_url")]
|
||||||
public string RunServiceUrl { get; set; }
|
public string RunServiceUrl { get; set; }
|
||||||
|
|||||||
@@ -11,5 +11,10 @@ namespace GitHub.Runner.Worker
|
|||||||
var isContainerHooksPathSet = !string.IsNullOrEmpty(Environment.GetEnvironmentVariable(Constants.Hooks.ContainerHooksPath));
|
var isContainerHooksPathSet = !string.IsNullOrEmpty(Environment.GetEnvironmentVariable(Constants.Hooks.ContainerHooksPath));
|
||||||
return isContainerHookFeatureFlagSet && isContainerHooksPathSet;
|
return isContainerHookFeatureFlagSet && isContainerHooksPathSet;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static bool IsContainerActionRunnerTempEnabled(Variables variables)
|
||||||
|
{
|
||||||
|
return variables?.GetBoolean(Constants.Runner.Features.ContainerActionRunnerTemp) ?? false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -191,11 +191,19 @@ namespace GitHub.Runner.Worker.Handlers
|
|||||||
ArgUtil.Directory(tempWorkflowDirectory, nameof(tempWorkflowDirectory));
|
ArgUtil.Directory(tempWorkflowDirectory, nameof(tempWorkflowDirectory));
|
||||||
|
|
||||||
container.MountVolumes.Add(new MountVolume("/var/run/docker.sock", "/var/run/docker.sock"));
|
container.MountVolumes.Add(new MountVolume("/var/run/docker.sock", "/var/run/docker.sock"));
|
||||||
|
if (FeatureManager.IsContainerActionRunnerTempEnabled(ExecutionContext.Global.Variables))
|
||||||
|
{
|
||||||
|
container.MountVolumes.Add(new MountVolume(tempDirectory, "/github/runner_temp"));
|
||||||
|
}
|
||||||
container.MountVolumes.Add(new MountVolume(tempHomeDirectory, "/github/home"));
|
container.MountVolumes.Add(new MountVolume(tempHomeDirectory, "/github/home"));
|
||||||
container.MountVolumes.Add(new MountVolume(tempWorkflowDirectory, "/github/workflow"));
|
container.MountVolumes.Add(new MountVolume(tempWorkflowDirectory, "/github/workflow"));
|
||||||
container.MountVolumes.Add(new MountVolume(tempFileCommandDirectory, "/github/file_commands"));
|
container.MountVolumes.Add(new MountVolume(tempFileCommandDirectory, "/github/file_commands"));
|
||||||
container.MountVolumes.Add(new MountVolume(defaultWorkingDirectory, "/github/workspace"));
|
container.MountVolumes.Add(new MountVolume(defaultWorkingDirectory, "/github/workspace"));
|
||||||
|
|
||||||
|
if (FeatureManager.IsContainerActionRunnerTempEnabled(ExecutionContext.Global.Variables))
|
||||||
|
{
|
||||||
|
container.AddPathTranslateMapping(tempDirectory, "/github/runner_temp");
|
||||||
|
}
|
||||||
container.AddPathTranslateMapping(tempHomeDirectory, "/github/home");
|
container.AddPathTranslateMapping(tempHomeDirectory, "/github/home");
|
||||||
container.AddPathTranslateMapping(tempWorkflowDirectory, "/github/workflow");
|
container.AddPathTranslateMapping(tempWorkflowDirectory, "/github/workflow");
|
||||||
container.AddPathTranslateMapping(tempFileCommandDirectory, "/github/file_commands");
|
container.AddPathTranslateMapping(tempFileCommandDirectory, "/github/file_commands");
|
||||||
|
|||||||
@@ -79,6 +79,7 @@ namespace GitHub.Actions.RunService.WebApi
|
|||||||
{
|
{
|
||||||
queryParams.Add("status", status.Value.ToString());
|
queryParams.Add("status", status.Value.ToString());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (runnerVersion != null)
|
if (runnerVersion != null)
|
||||||
{
|
{
|
||||||
queryParams.Add("runnerVersion", runnerVersion);
|
queryParams.Add("runnerVersion", runnerVersion);
|
||||||
@@ -142,7 +143,6 @@ namespace GitHub.Actions.RunService.WebApi
|
|||||||
}
|
}
|
||||||
|
|
||||||
public async Task<TaskAgentSession> CreateSessionAsync(
|
public async Task<TaskAgentSession> CreateSessionAsync(
|
||||||
|
|
||||||
TaskAgentSession session,
|
TaskAgentSession session,
|
||||||
CancellationToken cancellationToken = default)
|
CancellationToken cancellationToken = default)
|
||||||
{
|
{
|
||||||
@@ -191,6 +191,76 @@ namespace GitHub.Actions.RunService.WebApi
|
|||||||
throw new Exception($"Failed to delete broker session: {result.Error}");
|
throw new Exception($"Failed to delete broker session: {result.Error}");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public async Task AcknowledgeRunnerRequestAsync(
|
||||||
|
string runnerRequestId,
|
||||||
|
Guid? sessionId,
|
||||||
|
string runnerVersion,
|
||||||
|
TaskAgentStatus? status,
|
||||||
|
string os = null,
|
||||||
|
string architecture = null,
|
||||||
|
CancellationToken cancellationToken = default)
|
||||||
|
{
|
||||||
|
// URL
|
||||||
|
var requestUri = new Uri(Client.BaseAddress, "acknowledge");
|
||||||
|
|
||||||
|
// Query parameters
|
||||||
|
List<KeyValuePair<string, string>> queryParams = new List<KeyValuePair<string, string>>();
|
||||||
|
if (sessionId != null)
|
||||||
|
{
|
||||||
|
queryParams.Add("sessionId", sessionId.Value.ToString());
|
||||||
|
}
|
||||||
|
if (status != null)
|
||||||
|
{
|
||||||
|
queryParams.Add("status", status.Value.ToString());
|
||||||
|
}
|
||||||
|
if (runnerVersion != null)
|
||||||
|
{
|
||||||
|
queryParams.Add("runnerVersion", runnerVersion);
|
||||||
|
}
|
||||||
|
if (os != null)
|
||||||
|
{
|
||||||
|
queryParams.Add("os", os);
|
||||||
|
}
|
||||||
|
if (architecture != null)
|
||||||
|
{
|
||||||
|
queryParams.Add("architecture", architecture);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Body
|
||||||
|
var payload = new Dictionary<string, string>
|
||||||
|
{
|
||||||
|
["runnerRequestId"] = runnerRequestId,
|
||||||
|
};
|
||||||
|
var requestContent = new ObjectContent<Dictionary<string, string>>(payload, new VssJsonMediaTypeFormatter(true));
|
||||||
|
|
||||||
|
// POST
|
||||||
|
var result = await SendAsync<object>(
|
||||||
|
new HttpMethod("POST"),
|
||||||
|
requestUri: requestUri,
|
||||||
|
queryParameters: queryParams,
|
||||||
|
content: requestContent,
|
||||||
|
readErrorBody: true,
|
||||||
|
cancellationToken: cancellationToken);
|
||||||
|
|
||||||
|
if (result.IsSuccess)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (TryParseErrorBody(result.ErrorBody, out BrokerError brokerError))
|
||||||
|
{
|
||||||
|
switch (brokerError.ErrorKind)
|
||||||
|
{
|
||||||
|
case BrokerErrorKind.RunnerNotFound:
|
||||||
|
throw new RunnerNotFoundException(brokerError.Message);
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
throw new Exception($"Failed to acknowledge runner request. Request to {requestUri} failed with status: {result.StatusCode}. Error message {result.Error}");
|
||||||
|
}
|
||||||
|
|
||||||
private static bool TryParseErrorBody(string errorBody, out BrokerError error)
|
private static bool TryParseErrorBody(string errorBody, out BrokerError error)
|
||||||
{
|
{
|
||||||
if (!string.IsNullOrEmpty(errorBody))
|
if (!string.IsNullOrEmpty(errorBody))
|
||||||
|
|||||||
@@ -17,7 +17,7 @@ LAYOUT_DIR="$SCRIPT_DIR/../_layout"
|
|||||||
DOWNLOAD_DIR="$SCRIPT_DIR/../_downloads/netcore2x"
|
DOWNLOAD_DIR="$SCRIPT_DIR/../_downloads/netcore2x"
|
||||||
PACKAGE_DIR="$SCRIPT_DIR/../_package"
|
PACKAGE_DIR="$SCRIPT_DIR/../_package"
|
||||||
DOTNETSDK_ROOT="$SCRIPT_DIR/../_dotnetsdk"
|
DOTNETSDK_ROOT="$SCRIPT_DIR/../_dotnetsdk"
|
||||||
DOTNETSDK_VERSION="8.0.412"
|
DOTNETSDK_VERSION="8.0.413"
|
||||||
DOTNETSDK_INSTALLDIR="$DOTNETSDK_ROOT/$DOTNETSDK_VERSION"
|
DOTNETSDK_INSTALLDIR="$DOTNETSDK_ROOT/$DOTNETSDK_VERSION"
|
||||||
RUNNER_VERSION=$(cat runnerversion)
|
RUNNER_VERSION=$(cat runnerversion)
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"sdk": {
|
"sdk": {
|
||||||
"version": "8.0.412"
|
"version": "8.0.413"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user