Edits history of script submission #22692 for ' Create Webhook (adobe_acrobat_sign)'

  • bunnative
    One script reply has been approved by the moderators
    Ap­pro­ved
    //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