-
-
Notifications
You must be signed in to change notification settings - Fork 158
107 lines (97 loc) · 3.64 KB
/
issue-triage.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
name: Ads - Triage OWASP Top 10 LLM Apps Issues
on:
issues:
types: [opened, labeled, reopened]
env:
BOARD_NAME: "OWASP Top 10 for LLM Applications"
OWNER: ${{ github.repository_owner }}
REPO: ${{ github.event.repository.name }}
ISSUE: ${{ github.event.issue.number }}
PROJECT_TECH_LEAD: "GangGreenTemperTatum"
LLM01_LEAD: "leondz"
LLM02_LEAD: "kenhuangus"
LLM03_LEAD: "GangGreenTemperTatum"
LLM04_LEAD: "kenhuangus"
LLM05_LEAD: "jsotiro"
LLM06_LEAD: "GangGreenTemperTatum"
LLM07_LEAD: "rot169"
LLM08_LEAD: "virtualsteve-star"
LLM09_LEAD: "jsotiro"
LLM10_LEAD: "GangGreenTemperTatum"
PR_LEAD: "faceplate27"
POSTMASTER: "TBC"
TRANSLATIONS: "talesh"
DATA_GATHERING: "emmanuelgjr"
DESIGN: "rossja"
DIAGRAMS: "TBC"
WEB_DEVS: "mkfnch,rossja,GangGreenTemperTatum"
SEC_GOVERNANCE: "subzer0girl2"
jobs:
welcomes:
runs-on: ubuntu-latest
if: contains(github.event.issue.labels.*.name, 'opened')
steps:
- name: Checkout repository
uses: actions/checkout@v2
- uses: actions/github-script@v7
with:
script: |
github.rest.issues.createComment({
issue_number: context.issue.number,
owner: context.repo.owner,
repo: context.repo.repo,
body: '👋 Thanks for reporting! Please ensure labels are applied appropriately to the issue so that the workflow automation can triage this to the correct member of the core team'
})
triage:
runs-on: ubuntu-latest
if: contains(github.event.issue.labels.*.name, 'labeled')
steps:
- name: Checkout repository
uses: actions/checkout@v2
- uses: actions/github-script@v7
with:
script: |
try {
const issue = context.payload.issue;
const labels = issue.labels.map(label => label.name);
const assignees = [];
// Label-to-assignee mappings
const labelAssigneeMap = {
'bug': [${{ env.PROJECT_TECH_LEAD }}],
'extension': [${{ env.PROJECT_TECH_LEAD }}],
'llm-other': [${{ env.PROJECT_TECH_LEAD }}],
'diagram': [${{ env.PROJECT_TECH_LEAD }}],
'pdf': [${{ env.DESIGN }}],
'website': [${{ env.WEB_DEVS }}],
'llm-01': [${{ env.LLM01_LEAD }}],
'llm-02': [${{ env.LLM02_LEAD }}],
'llm-03': [${{ env.LLM03_LEAD }}],
'llm-04': [${{ env.LLM04_LEAD }}],
'llm-05': [${{ env.LLM05_LEAD }}],
'llm-06': [${{ env.LLM06_LEAD }}],
'llm-07': [${{ env.LLM07_LEAD }}],
'llm-08': [${{ env.LLM08_LEAD }}],
'llm-09': [${{ env.LLM09_LEAD }}],
'llm-10': [${{ env.LLM10_LEAD }}]
};
// Check labels and assign based on mappings
labels.forEach(label => {
if (labelAssigneeMap[label]) {
assignees.push(...labelAssigneeMap[label]);
}
});
// Remove duplicates from assignees list
// const uniqueAssignees = [...new Set(assignees)];
// Assign the issue to the calculated assignees
await github.issues.addAssignees({
issue_number: issue.number,
owner: context.repo.owner,
repo: context.repo.repo,
assignees: uniqueAssignees
});
} catch (error) {
console.error(error.message);
process.exit(1);
}
env:
GITHUB_TOKEN: ${{ secrets.ADS_OWASP_LLM_APPS_REPO_TOKEN }}