From 8a76641d20b16e2540ff3ee00630d6ec149efd14 Mon Sep 17 00:00:00 2001 From: "Mr.k" Date: Mon, 10 Jun 2024 23:18:45 +0300 Subject: [PATCH 1/2] Simplify 'Close Old Issues' Workflow by using 'actions/stale' GitHub Action (#2055) --- .github/workflows/close-old-issues.yaml | 89 +++---------------------- 1 file changed, 9 insertions(+), 80 deletions(-) diff --git a/.github/workflows/close-old-issues.yaml b/.github/workflows/close-old-issues.yaml index a37180c5..733a5707 100644 --- a/.github/workflows/close-old-issues.yaml +++ b/.github/workflows/close-old-issues.yaml @@ -4,91 +4,20 @@ on: schedule: - cron: '0 0 * * *' # Run daily workflow_dispatch: # This line enables manual triggering + jobs: close-issues: runs-on: ubuntu-latest permissions: issues: write # Ensure necessary permissions for issues - + pull-requests: none + contents: none steps: - name: Close inactive issues - uses: actions/github-script@v7 + uses: actions/stale@v9.0.0 with: - github-token: ${{ secrets.GITHUB_TOKEN }} - script: | - const octokit = github; - - // Get the repository owner and name - const { owner, repo } = context.repo; - - // Define the inactivity period (14 days) - const inactivityPeriod = new Date(); - inactivityPeriod.setDate(inactivityPeriod.getDate() - 14); - - const labelKeepIssue = 'Keep Issue Open'; - - try { - // Get all open issues with pagination - for await (const response of octokit.paginate.iterator(octokit.rest.issues.listForRepo, { - owner, - repo, - state: 'open', - })) { - const issues = response.data; - - // Close issues inactive for more than the inactivity period - for (const issue of issues) { - let closeIssue = true; - - // Get all Labels of issue, and compared each label with the labelKeepIssue const variable - try { - const respondIssueLabels = await octokit.request("GET /repos/{owner}/{repo}/issues/{issue_number}/labels", { - owner: owner, - repo: repo, - issue_number: issue.number - }); - const labels = respondIssueLabels.data; - - for (let i = 0; i < labels.length; i++) { - const label = labels[i] - if (label.name === labelKeepIssue) { - console.log(`Issue #${issue.number} will not be closed`); - closeIssue = false; - break; // Break from the loop, no need to check the remaining Labels. - } - } - } catch (error) { - console.error(`Error while Fetching Labels for Issue #${issue.number}, Error: ${error}`); - } - - if (!closeIssue) { - continue; // Skip the next bit of code - } - - const lastCommentDate = issue.updated_at; - if (new Date(lastCommentDate) < inactivityPeriod) { - try { - // Close the issue - await octokit.rest.issues.update({ - owner, - repo, - issue_number: issue.number, - state: 'closed', - }); - - // Add a comment - await octokit.rest.issues.createComment({ - owner, - repo, - issue_number: issue.number, - body: 'Closed due to inactivity', - }); - } catch (error) { - console.error(`Error updating or commenting on issue #${issue.number}: ${error}`); - } - } - } - } - } catch (error) { - console.error(`Error fetching issues: ${error}`); - } + exempt-issue-labels: "Keep Issue Open" + days-before-issue-close: 14 + close-issue-message: "This issue was closed because it has been inactive for 14 days" + debug-only: false # Make this field equal true if you want to test your configuration if it works or not + repo-token: ${{ secrets.GITHUB_TOKEN }} From 1325ef54b8825c913111010117fbf3bd63a9ad81 Mon Sep 17 00:00:00 2001 From: ChrisTitusTech Date: Mon, 10 Jun 2024 20:19:12 +0000 Subject: [PATCH 2/2] Compile Winutil --- winutil.ps1 | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/winutil.ps1 b/winutil.ps1 index dab68f20..4d519304 100644 --- a/winutil.ps1 +++ b/winutil.ps1 @@ -10,7 +10,7 @@ Author : Chris Titus @christitustech Runspace Author: @DeveloperDurp GitHub : https://github.com/ChrisTitusTech - Version : 24.06.06 + Version : 24.06.10 #> param ( [switch]$Debug, @@ -47,7 +47,7 @@ Add-Type -AssemblyName System.Windows.Forms # Variable to sync between runspaces $sync = [Hashtable]::Synchronized(@{}) $sync.PSScriptRoot = $PSScriptRoot -$sync.version = "24.06.06" +$sync.version = "24.06.10" $sync.configs = @{} $sync.ProcessRunning = $false