ci: add --discord-webhook / -d CLI option for custom Discord webhook URL
This commit is contained in:
@@ -1,6 +1,7 @@
|
|||||||
#!/usr/bin/env bun
|
#!/usr/bin/env bun
|
||||||
|
|
||||||
import { Script } from "@opencode-ai/script"
|
import { Script } from "@opencode-ai/script"
|
||||||
|
import { parseArgs } from "util"
|
||||||
|
|
||||||
interface PR {
|
interface PR {
|
||||||
number: number
|
number: number
|
||||||
@@ -20,10 +21,10 @@ interface FailedPR {
|
|||||||
reason: string
|
reason: string
|
||||||
}
|
}
|
||||||
|
|
||||||
async function postToDiscord(failures: FailedPR[]) {
|
async function postToDiscord(failures: FailedPR[], webhookUrl?: string) {
|
||||||
const webhookUrl = process.env.DISCORD_ISSUES_WEBHOOK_URL
|
const url = webhookUrl || process.env.DISCORD_ISSUES_WEBHOOK_URL
|
||||||
if (!webhookUrl) {
|
if (!url) {
|
||||||
console.log("Warning: DISCORD_ISSUES_WEBHOOK_URL not set, skipping Discord notification")
|
console.log("Warning: No Discord webhook URL provided, skipping notification")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -37,7 +38,7 @@ Please resolve these conflicts manually.`
|
|||||||
|
|
||||||
const content = JSON.stringify({ content: message })
|
const content = JSON.stringify({ content: message })
|
||||||
|
|
||||||
const response = await fetch(webhookUrl, {
|
const response = await fetch(url, {
|
||||||
method: "POST",
|
method: "POST",
|
||||||
headers: { "Content-Type": "application/json" },
|
headers: { "Content-Type": "application/json" },
|
||||||
body: content,
|
body: content,
|
||||||
@@ -51,6 +52,15 @@ Please resolve these conflicts manually.`
|
|||||||
}
|
}
|
||||||
|
|
||||||
async function main() {
|
async function main() {
|
||||||
|
const { values } = parseArgs({
|
||||||
|
args: Bun.argv.slice(2),
|
||||||
|
options: {
|
||||||
|
"discord-webhook": { type: "string", short: "d" },
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
|
const discordWebhook = values["discord-webhook"] as string | undefined
|
||||||
|
|
||||||
console.log("Fetching open PRs from team members...")
|
console.log("Fetching open PRs from team members...")
|
||||||
|
|
||||||
const allPrs: PR[] = []
|
const allPrs: PR[] = []
|
||||||
@@ -145,7 +155,7 @@ async function main() {
|
|||||||
console.log(`Failed: ${failed.length} PRs`)
|
console.log(`Failed: ${failed.length} PRs`)
|
||||||
failed.forEach((f) => console.log(` - PR #${f.number}: ${f.reason}`))
|
failed.forEach((f) => console.log(` - PR #${f.number}: ${f.reason}`))
|
||||||
|
|
||||||
await postToDiscord(failed)
|
await postToDiscord(failed, discordWebhook)
|
||||||
|
|
||||||
throw new Error(`${failed.length} PR(s) failed to merge. Check Discord for details.`)
|
throw new Error(`${failed.length} PR(s) failed to merge. Check Discord for details.`)
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user