Edits history of script submission #3982 for ' Bulk Delete Organizations (zendesk)'

  • nativets
    One script reply has been approved by the moderators
    Ap­pro­ved
    type Zendesk = {
      username: string;
      password: string;
      subdomain: string;
    };
    /**
     * Bulk Delete Organizations
     * Accepts a comma-separated list of up to 100 organization ids or external ids.
    
    #### Response
    
    This endpoint returns a `job_status` JSON object and queues a background job to do the work. Use the Show Job Status endpoint to check for the job's completion. Only a certain number of jobs can be queued or running at the same time. See Job limit for more information.
    
    #### Allowed For
    
    * Admins
    * Agents assigned to a custom role with permissions to manage organizations (Enterprise only)
    
     */
    export async function main(
      auth: Zendesk,
      ids: string | undefined,
      external_ids: string | undefined
    ) {
      const url = new URL(
        `https://${auth.subdomain}.zendesk.com/api/v2/organizations/destroy_many`
      );
      for (const [k, v] of [
        ["ids", ids],
        ["external_ids", external_ids],
      ]) {
        if (v !== undefined && v !== "") {
          url.searchParams.append(k, v);
        }
      }
      const response = await fetch(url, {
        method: "DELETE",
        headers: {
          Authorization: "Basic " + btoa(`${auth.username}:${auth.password}`),
        },
        body: undefined,
      });
      if (!response.ok) {
        const text = await response.text();
        throw new Error(`${response.status} ${text}`);
      }
      return await response.json();
    }
    

    Submitted by hugo697 377 days ago

  • nativets
    type Zendesk = {
      username: string;
      password: string;
      subdomain: string;
    };
    /**
     * Bulk Delete Organizations
     * Accepts a comma-separated list of up to 100 organization ids or external ids.
    
    #### Response
    
    This endpoint returns a `job_status` JSON object and queues a background job to do the work. Use the Show Job Status endpoint to check for the job's completion. Only a certain number of jobs can be queued or running at the same time. See Job limit for more information.
    
    #### Allowed For
    
    * Admins
    * Agents assigned to a custom role with permissions to manage organizations (Enterprise only)
    
     */
    export async function main(
      auth: Zendesk,
      ids: string | undefined,
      external_ids: string | undefined
    ) {
      const url = new URL(
        `https://${auth.subdomain}.zendesk.com/api/v2/organizations/destroy_many`
      );
      for (const [k, v] of [
        ["ids", ids],
        ["external_ids", external_ids],
      ]) {
        if (v !== undefined && v !== "") {
          url.searchParams.append(k, v);
        }
      }
      const response = await fetch(url, {
        method: "DELETE",
        headers: {
          Authorization: "Basic " + btoa(`${auth.username}:${auth.password}`),
        },
        body: undefined,
      });
      if (!response.ok) {
        const text = await response.text();
        throw new Error(`${response.status} ${text}`);
      }
      return await response.json();
    }
    

    Submitted by hugo697 923 days ago