mirror of
https://github.com/scylladb/scylladb.git
synced 2026-05-22 15:52:13 +00:00
Pin all external GitHub Actions to full commit SHAs and upgrade to their latest major versions to reduce supply chain attack surface: - actions/checkout: v3/v4/v5 -> v6.0.2 - actions/github-script: v7 -> v8.0.0 - actions/setup-python: v5 -> v6.2.0 - actions/upload-artifact: v4 -> v7.0.0 - astral-sh/setup-uv: v6 -> v8.0.0 - mheap/github-action-required-labels: v5.5.2 (pinned) - redhat-plumbers-in-action/differential-shellcheck: v5.5.6 (pinned) - codespell-project/actions-codespell: v2.2 (pinned, was @master) Set FORCE_JAVASCRIPT_ACTIONS_TO_NODE24=true in all 21 workflows that use JavaScript-based actions to opt into the Node.js 24 runtime now. This resolves the deprecation warning: "Node.js 20 actions are deprecated. Please check if updated versions of these actions are available that support Node.js 24. Actions will be forced to run with Node.js 24 by default starting June 2nd, 2026. Node.js 20 will be removed from the runner on September 16th, 2026." See: https://github.blog/changelog/2025-09-19-deprecation-of-node-20-on-github-actions-runners/ scylladb/github-automation references are intentionally left at @main as they are org-internal reusable workflows. Fixes: SCYLLADB-1410 Backport: Backport is required for live branches that run GH actions: 2026.1, 2025.4, 2025.1 and 2024.1 Closes scylladb/scylladb#29421
62 lines
2.6 KiB
YAML
62 lines
2.6 KiB
YAML
name: Urgent Issue Reminder
|
|
|
|
on:
|
|
schedule:
|
|
- cron: '10 8 * * *' # Runs daily at 8 AM
|
|
|
|
env:
|
|
FORCE_JAVASCRIPT_ACTIONS_TO_NODE24: true
|
|
|
|
jobs:
|
|
reminder:
|
|
runs-on: ubuntu-latest
|
|
|
|
steps:
|
|
- name: Send reminders
|
|
uses: actions/github-script@ed597411d8f924073f98dfc5c65a23a2325f34cd # v8.0.0
|
|
with:
|
|
script: |
|
|
const labelFilters = ['P0', 'P1', 'Field-Tier1','status/release blocker', 'status/regression'];
|
|
const excludingLabelFilters = ['documentation'];
|
|
const daysInactive = 7;
|
|
const now = new Date();
|
|
|
|
// Fetch open issues
|
|
const issues = await github.rest.issues.listForRepo({
|
|
owner: context.repo.owner,
|
|
repo: context.repo.repo,
|
|
state: 'open'
|
|
});
|
|
console.log("Looking for issues with labels:"+labelFilters+", excluding labels:"+excludingLabelFilters+ ", inactive for more than "+daysInactive+" days.");
|
|
for (const issue of issues.data) {
|
|
// Check if issue has any of the specified labels
|
|
const hasFilteredLabel = issue.labels.some(label => labelFilters.includes(label.name));
|
|
const hasExcludingLabel = issue.labels.some(label => excludingLabelFilters.includes(label.name));
|
|
if (hasExcludingLabel) continue;
|
|
if (!hasFilteredLabel) continue;
|
|
|
|
// Check for inactivity
|
|
const lastUpdated = new Date(issue.updated_at);
|
|
const diffInDays = (now - lastUpdated) / (1000 * 60 * 60 * 24);
|
|
console.log("Issue #"+issue.number+"; Days inactive:"+diffInDays);
|
|
if (diffInDays > daysInactive) {
|
|
if (issue.assignees.length > 0) {
|
|
console.log("==>> Alert about issue #"+issue.number);
|
|
const assigneesLogins = issue.assignees.map(assignee => `@${assignee.login}`).join(', ');
|
|
await github.rest.issues.createComment({
|
|
owner: context.repo.owner,
|
|
repo: context.repo.repo,
|
|
issue_number: issue.number,
|
|
body: `${assigneesLogins}, This urgent issue had no activity for more than ${daysInactive} days. Please check its status.\n CC @mykaul @dani-tweig`
|
|
});
|
|
} else {
|
|
await github.rest.issues.createComment({
|
|
owner: context.repo.owner,
|
|
repo: context.repo.repo,
|
|
issue_number: issue.number,
|
|
body: `This urgent issue had no activity for more than ${daysInactive} days. Please check its status.\n CC @mykaul @dani-tweig`
|
|
});
|
|
}
|
|
}
|
|
}
|