Add workflow to create/update issues on New script merge
This commit is contained in:
parent
ca1203753c
commit
b14bb9158e
165
.github/workflows/update_issue.yml
generated
vendored
Normal file
165
.github/workflows/update_issue.yml
generated
vendored
Normal file
@ -0,0 +1,165 @@
|
||||
name: Update Issue on PR Merge
|
||||
|
||||
on:
|
||||
pull_request:
|
||||
types: [closed]
|
||||
branches:
|
||||
- main
|
||||
|
||||
permissions:
|
||||
issues: write
|
||||
pull-requests: read
|
||||
|
||||
jobs:
|
||||
update_issues:
|
||||
if: github.event.pull_request.merged == true && github.repository == 'community-scripts/ProxmoxVED'
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- name: Checkout repository
|
||||
uses: actions/checkout@v4
|
||||
|
||||
- name: Extract Script Names from Changed Files
|
||||
id: extract_scripts
|
||||
env:
|
||||
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||
run: |
|
||||
CHANGED_FILES=$(gh pr diff ${{ github.event.pull_request.number }} --repo ${{ github.repository }} --name-only)
|
||||
|
||||
SCRIPT_NAMES=()
|
||||
|
||||
while IFS= read -r FILE; do
|
||||
if [[ $FILE =~ ^ct/(.+)\.sh$ ]]; then
|
||||
SCRIPT_NAME="${BASH_REMATCH[1]}"
|
||||
if [[ ! " ${SCRIPT_NAMES[@]} " =~ " ${SCRIPT_NAME} " ]]; then
|
||||
SCRIPT_NAMES+=("$SCRIPT_NAME")
|
||||
fi
|
||||
elif [[ $FILE =~ ^install/(.+)-install\.sh$ ]]; then
|
||||
SCRIPT_NAME="${BASH_REMATCH[1]}"
|
||||
if [[ ! " ${SCRIPT_NAMES[@]} " =~ " ${SCRIPT_NAME} " ]]; then
|
||||
SCRIPT_NAMES+=("$SCRIPT_NAME")
|
||||
fi
|
||||
fi
|
||||
done <<< "$CHANGED_FILES"
|
||||
|
||||
if [ ${#SCRIPT_NAMES[@]} -eq 0 ]; then
|
||||
echo "No script files found in PR"
|
||||
echo "script_names=[]" >> $GITHUB_OUTPUT
|
||||
exit 0
|
||||
fi
|
||||
|
||||
JSON_NAMES=$(printf '%s\n' "${SCRIPT_NAMES[@]}" | jq -R . | jq -s .)
|
||||
echo "script_names=$JSON_NAMES" >> $GITHUB_OUTPUT
|
||||
echo "Found script names: ${SCRIPT_NAMES[*]}"
|
||||
|
||||
- name: Process Each Script
|
||||
if: steps.extract_scripts.outputs.script_names != '[]'
|
||||
uses: actions/github-script@v7
|
||||
env:
|
||||
PR_AUTHOR: ${{ github.event.pull_request.user.login }}
|
||||
SCRIPT_NAMES: ${{ steps.extract_scripts.outputs.script_names }}
|
||||
with:
|
||||
script: |
|
||||
const scriptNames = JSON.parse(process.env.SCRIPT_NAMES);
|
||||
const prAuthor = process.env.PR_AUTHOR;
|
||||
const message = `@${prAuthor} This PR got merged now and is in the testing phase, it will be migrated to ProxmoxVE when testing is completed`;
|
||||
const labelName = 'Ready For Testing';
|
||||
|
||||
for (const scriptName of scriptNames) {
|
||||
console.log(`Processing script: ${scriptName}`);
|
||||
|
||||
const { data: issues } = await github.rest.issues.listForRepo({
|
||||
owner: context.repo.owner,
|
||||
repo: context.repo.repo,
|
||||
state: 'open',
|
||||
per_page: 100
|
||||
});
|
||||
|
||||
const scriptNameLower = scriptName.toLowerCase();
|
||||
let existingIssue = issues.find(issue =>
|
||||
!issue.pull_request && issue.title.toLowerCase() === scriptNameLower
|
||||
);
|
||||
|
||||
if (!existingIssue) {
|
||||
const { data: searchResults } = await github.rest.search.issuesAndPullRequests({
|
||||
q: `repo:${context.repo.owner}/${context.repo.repo} is:issue is:open ${scriptName}`,
|
||||
per_page: 100
|
||||
});
|
||||
|
||||
existingIssue = searchResults.items.find(issue =>
|
||||
issue.title.toLowerCase() === scriptNameLower
|
||||
);
|
||||
}
|
||||
|
||||
if (existingIssue) {
|
||||
console.log(`Found existing issue #${existingIssue.number}: ${existingIssue.title}`);
|
||||
|
||||
await github.rest.issues.createComment({
|
||||
owner: context.repo.owner,
|
||||
repo: context.repo.repo,
|
||||
issue_number: existingIssue.number,
|
||||
body: message
|
||||
});
|
||||
|
||||
const { data: labels } = await github.rest.issues.listLabelsOnIssue({
|
||||
owner: context.repo.owner,
|
||||
repo: context.repo.repo,
|
||||
issue_number: existingIssue.number
|
||||
});
|
||||
|
||||
const hasLabel = labels.some(label => label.name === labelName);
|
||||
|
||||
if (!hasLabel) {
|
||||
await github.rest.issues.addLabels({
|
||||
owner: context.repo.owner,
|
||||
repo: context.repo.repo,
|
||||
issue_number: existingIssue.number,
|
||||
labels: [labelName]
|
||||
});
|
||||
console.log(`Added "${labelName}" label to issue #${existingIssue.number}`);
|
||||
} else {
|
||||
console.log(`Issue #${existingIssue.number} already has "${labelName}" label`);
|
||||
}
|
||||
} else {
|
||||
console.log(`No existing issue found for "${scriptName}", creating new issue`);
|
||||
|
||||
const scriptType = 'CT (LXC Container)';
|
||||
|
||||
const formattedName = scriptName
|
||||
.split(/[-_]/)
|
||||
.map(word => word.charAt(0).toUpperCase() + word.slice(1).toLowerCase())
|
||||
.join(' ');
|
||||
|
||||
const issueBody = `# 🛠️ **New Script**
|
||||
Create an Issue when you want to merge a new Script. The name of the Issue must be the same as your APP.sh file. (Example: SnipeIT, snipeit.sh; Alpine-Docker, alpine-docker.sh)
|
||||
|
||||
### Name of the Script
|
||||
|
||||
${formattedName}
|
||||
|
||||
### Script Type
|
||||
|
||||
${scriptType}
|
||||
|
||||
### 📋 Script Details
|
||||
|
||||
This script has been merged and is ready for testing. ${message}`;
|
||||
|
||||
const { data: newIssue } = await github.rest.issues.create({
|
||||
owner: context.repo.owner,
|
||||
repo: context.repo.repo,
|
||||
title: scriptName,
|
||||
body: issueBody,
|
||||
labels: ['task', labelName]
|
||||
});
|
||||
|
||||
console.log(`Created new issue #${newIssue.number}: ${newIssue.title}`);
|
||||
|
||||
await github.rest.issues.createComment({
|
||||
owner: context.repo.owner,
|
||||
repo: context.repo.repo,
|
||||
issue_number: newIssue.number,
|
||||
body: message
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user