mirror of
https://github.com/coollabsio/coolify.git
synced 2026-03-11 08:55:47 +00:00
Merge branch 'v4.x' into next
This commit is contained in:
commit
78aea9a7ec
5 changed files with 104 additions and 86 deletions
|
|
@ -1,86 +0,0 @@
|
||||||
name: Remove Labels and Assignees on Issue Close
|
|
||||||
|
|
||||||
on:
|
|
||||||
issues:
|
|
||||||
types: [closed]
|
|
||||||
pull_request:
|
|
||||||
types: [closed]
|
|
||||||
pull_request_target:
|
|
||||||
types: [closed]
|
|
||||||
|
|
||||||
permissions:
|
|
||||||
issues: write
|
|
||||||
pull-requests: write
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
remove-labels-and-assignees:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: Remove labels and assignees
|
|
||||||
uses: actions/github-script@v7
|
|
||||||
with:
|
|
||||||
github-token: ${{ secrets.GITHUB_TOKEN }}
|
|
||||||
script: |
|
|
||||||
const { owner, repo } = context.repo;
|
|
||||||
|
|
||||||
async function processIssue(issueNumber, isFromPR = false, prBaseBranch = null) {
|
|
||||||
try {
|
|
||||||
if (isFromPR && prBaseBranch !== 'v4.x') {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
const { data: currentLabels } = await github.rest.issues.listLabelsOnIssue({
|
|
||||||
owner,
|
|
||||||
repo,
|
|
||||||
issue_number: issueNumber
|
|
||||||
});
|
|
||||||
|
|
||||||
const labelsToKeep = currentLabels
|
|
||||||
.filter(label => label.name === '⏱︎ Stale')
|
|
||||||
.map(label => label.name);
|
|
||||||
|
|
||||||
await github.rest.issues.setLabels({
|
|
||||||
owner,
|
|
||||||
repo,
|
|
||||||
issue_number: issueNumber,
|
|
||||||
labels: labelsToKeep
|
|
||||||
});
|
|
||||||
|
|
||||||
const { data: issue } = await github.rest.issues.get({
|
|
||||||
owner,
|
|
||||||
repo,
|
|
||||||
issue_number: issueNumber
|
|
||||||
});
|
|
||||||
|
|
||||||
if (issue.assignees && issue.assignees.length > 0) {
|
|
||||||
await github.rest.issues.removeAssignees({
|
|
||||||
owner,
|
|
||||||
repo,
|
|
||||||
issue_number: issueNumber,
|
|
||||||
assignees: issue.assignees.map(assignee => assignee.login)
|
|
||||||
});
|
|
||||||
}
|
|
||||||
} catch (error) {
|
|
||||||
if (error.status !== 404) {
|
|
||||||
console.error(`Error processing issue ${issueNumber}:`, error);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (context.eventName === 'issues') {
|
|
||||||
await processIssue(context.payload.issue.number);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (context.eventName === 'pull_request' || context.eventName === 'pull_request_target') {
|
|
||||||
const pr = context.payload.pull_request;
|
|
||||||
await processIssue(pr.number);
|
|
||||||
if (pr.merged && pr.base.ref === 'v4.x' && pr.body) {
|
|
||||||
const issueReferences = pr.body.match(/#(\d+)/g);
|
|
||||||
if (issueReferences) {
|
|
||||||
for (const reference of issueReferences) {
|
|
||||||
const issueNumber = parseInt(reference.substring(1));
|
|
||||||
await processIssue(issueNumber, true, pr.base.ref);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
@ -8,6 +8,7 @@ on:
|
||||||
- .github/workflows/coolify-helper-next.yml
|
- .github/workflows/coolify-helper-next.yml
|
||||||
- .github/workflows/coolify-realtime.yml
|
- .github/workflows/coolify-realtime.yml
|
||||||
- .github/workflows/coolify-realtime-next.yml
|
- .github/workflows/coolify-realtime-next.yml
|
||||||
|
- .github/workflows/pr-quality.yaml
|
||||||
- docker/coolify-helper/Dockerfile
|
- docker/coolify-helper/Dockerfile
|
||||||
- docker/coolify-realtime/Dockerfile
|
- docker/coolify-realtime/Dockerfile
|
||||||
- docker/testing-host/Dockerfile
|
- docker/testing-host/Dockerfile
|
||||||
|
|
|
||||||
1
.github/workflows/coolify-staging-build.yml
vendored
1
.github/workflows/coolify-staging-build.yml
vendored
|
|
@ -11,6 +11,7 @@ on:
|
||||||
- .github/workflows/coolify-helper-next.yml
|
- .github/workflows/coolify-helper-next.yml
|
||||||
- .github/workflows/coolify-realtime.yml
|
- .github/workflows/coolify-realtime.yml
|
||||||
- .github/workflows/coolify-realtime-next.yml
|
- .github/workflows/coolify-realtime-next.yml
|
||||||
|
- .github/workflows/pr-quality.yaml
|
||||||
- docker/coolify-helper/Dockerfile
|
- docker/coolify-helper/Dockerfile
|
||||||
- docker/coolify-realtime/Dockerfile
|
- docker/coolify-realtime/Dockerfile
|
||||||
- docker/testing-host/Dockerfile
|
- docker/testing-host/Dockerfile
|
||||||
|
|
|
||||||
6
.github/workflows/generate-changelog.yml
vendored
6
.github/workflows/generate-changelog.yml
vendored
|
|
@ -3,6 +3,12 @@ name: Generate Changelog
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
branches: [ v4.x ]
|
branches: [ v4.x ]
|
||||||
|
paths-ignore:
|
||||||
|
- .github/workflows/coolify-helper.yml
|
||||||
|
- .github/workflows/coolify-helper-next.yml
|
||||||
|
- .github/workflows/coolify-realtime.yml
|
||||||
|
- .github/workflows/coolify-realtime-next.yml
|
||||||
|
- .github/workflows/pr-quality.yaml
|
||||||
workflow_dispatch:
|
workflow_dispatch:
|
||||||
|
|
||||||
permissions:
|
permissions:
|
||||||
|
|
|
||||||
96
.github/workflows/pr-quality.yaml
vendored
Normal file
96
.github/workflows/pr-quality.yaml
vendored
Normal file
|
|
@ -0,0 +1,96 @@
|
||||||
|
name: PR Quality
|
||||||
|
|
||||||
|
permissions:
|
||||||
|
contents: read
|
||||||
|
issues: read
|
||||||
|
pull-requests: write
|
||||||
|
|
||||||
|
on:
|
||||||
|
pull_request_target:
|
||||||
|
types: [opened, reopened]
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
pr-quality:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: peakoss/anti-slop@v0
|
||||||
|
with:
|
||||||
|
# General Settings
|
||||||
|
max-failures: 3
|
||||||
|
|
||||||
|
# PR Branch Checks
|
||||||
|
allowed-target-branches: "next"
|
||||||
|
blocked-target-branches: ""
|
||||||
|
allowed-source-branches: ""
|
||||||
|
blocked-source-branches: |
|
||||||
|
main
|
||||||
|
master
|
||||||
|
v4.x
|
||||||
|
next
|
||||||
|
|
||||||
|
# PR Quality Checks
|
||||||
|
max-negative-reactions: 0
|
||||||
|
require-maintainer-can-modify: true
|
||||||
|
|
||||||
|
# PR Title Checks
|
||||||
|
require-conventional-title: true
|
||||||
|
|
||||||
|
# PR Description Checks
|
||||||
|
require-description: true
|
||||||
|
max-description-length: 0
|
||||||
|
max-emoji-count: 2
|
||||||
|
require-pr-template: true
|
||||||
|
require-linked-issue: false
|
||||||
|
blocked-terms: "STRAWBERRY"
|
||||||
|
blocked-issue-numbers: 8154
|
||||||
|
|
||||||
|
# Commit Message Checks
|
||||||
|
require-conventional-commits: false
|
||||||
|
blocked-commit-authors: "claude,copilot"
|
||||||
|
|
||||||
|
# File Checks
|
||||||
|
allowed-file-extensions: ""
|
||||||
|
allowed-paths: ""
|
||||||
|
blocked-paths: |
|
||||||
|
README.md
|
||||||
|
SECURITY.md
|
||||||
|
LICENSE
|
||||||
|
CODE_OF_CONDUCT.md
|
||||||
|
templates/service-templates-latest.json
|
||||||
|
templates/service-templates.json
|
||||||
|
require-final-newline: true
|
||||||
|
|
||||||
|
# User Health Checks
|
||||||
|
min-repo-merged-prs: 0
|
||||||
|
min-repo-merge-ratio: 0
|
||||||
|
min-global-merge-ratio: 30
|
||||||
|
global-merge-ratio-exclude-own: false
|
||||||
|
min-account-age: 10
|
||||||
|
|
||||||
|
# Exemptions
|
||||||
|
exempt-author-association: "OWNER,MEMBER,COLLABORATOR"
|
||||||
|
exempt-users: ""
|
||||||
|
exempt-bots: |
|
||||||
|
actions-user
|
||||||
|
dependabot[bot]
|
||||||
|
renovate[bot]
|
||||||
|
github-actions[bot]
|
||||||
|
exempt-draft-prs: false
|
||||||
|
exempt-label: "quality/exempt"
|
||||||
|
exempt-pr-label: ""
|
||||||
|
exempt-milestones: ""
|
||||||
|
exempt-pr-milestones: ""
|
||||||
|
exempt-all-milestones: false
|
||||||
|
exempt-all-pr-milestones: false
|
||||||
|
|
||||||
|
# PR Success Actions
|
||||||
|
success-add-pr-labels: "quality/verified"
|
||||||
|
|
||||||
|
# PR Failure Actions
|
||||||
|
close-pr: true
|
||||||
|
lock-pr: false
|
||||||
|
delete-branch: false
|
||||||
|
failure-pr-message: "This PR did not pass quality checks so it will be closed. If you believe this is a mistake please let us know."
|
||||||
|
failure-remove-pr-labels: ""
|
||||||
|
failure-remove-all-pr-labels: true
|
||||||
|
failure-add-pr-labels: "quality/rejected"
|
||||||
Loading…
Reference in a new issue