//native
async function apiBase(auth: RT.AdobeAcrobatSign): Promise<string> {
if (auth.base_uri) return auth.base_uri.replace(/\/+$/, "")
const r = await fetch("https://api.adobesign.com/api/rest/v6/baseUris", {
headers: {
Authorization: `Bearer ${auth.token}`,
Accept: "application/json",
},
})
if (!r.ok) throw new Error(`${r.status} ${await r.text()}`)
const { apiAccessPoint } = (await r.json()) as { apiAccessPoint: string }
return apiAccessPoint.replace(/\/+$/, "")
}
/**
* Create Webhook
* Register a webhook that pushes Acrobat Sign events to a URL. The endpoint must echo the X-AdobeSign-ClientId header on the verification GET.
*/
export async function main(
auth: RT.AdobeAcrobatSign,
webhook: {
name?: string
scope?: "ACCOUNT" | "GROUP" | "USER" | "RESOURCE"
state?: "ACTIVE" | "INACTIVE"
webhookSubscriptionEvents?: string[]
webhookUrlInfo?: { url?: string }
resourceType?: string
resourceId?: string
[key: string]: unknown
}
) {
const base = await apiBase(auth)
const url = new URL(`${base}/api/rest/v6/webhooks`)
const response = await fetch(url, {
method: "POST",
headers: {
Authorization: `Bearer ${auth.token}`,
"Content-Type": "application/json",
Accept: "application/json",
},
body: JSON.stringify(webhook),
})
if (!response.ok) {
throw new Error(`${response.status} ${await response.text()}`)
}
return await response.json()
}
Submitted by hugo989 5 days ago