Edits history of script submission #3921 for ' Create Custom Object Field (zendesk)'

  • nativets
    One script reply has been approved by the moderators
    Ap­pro­ved
    type Zendesk = {
      username: string;
      password: string;
      subdomain: string;
    };
    /**
     * Create Custom Object Field
     * Creates any of the following custom field types:
    
    * text (default when no "type" is specified)
    * textarea
    * checkbox
    * date
    * integer
    * decimal
    * regexp
    * dropdown
    * lookup
    
    See [About custom field types](https://support.zendesk.com/hc/en-us/articles/203661866) in Zendesk help.
    
    #### Allowed For
    
    * Admins
    
     */
    export async function main(
      auth: Zendesk,
      custom_object_key: string,
      body: {
        custom_object_field?: {
          active?: string;
          created_at?: string;
          custom_field_options?: {
            id?: string;
            name?: string;
            position?: string;
            raw_name?: string;
            url?: string;
            value?: string;
            [k: string]: unknown;
          }[];
          description?: string;
          id?: string;
          key?: string;
          position?: string;
          raw_description?: string;
          raw_title?: string;
          regexp_for_validation?: string;
          relationship_filter?: { [k: string]: unknown };
          relationship_target_type?: string;
          system?: string;
          tag?: string;
          title?: string;
          type?: string;
          updated_at?: string;
          url?: string;
          [k: string]: unknown;
        };
        [k: string]: unknown;
      }
    ) {
      const url = new URL(
        `https://${auth.subdomain}.zendesk.com/api/v2/custom_objects/${custom_object_key}/fields`
      );
    
      const response = await fetch(url, {
        method: "POST",
        headers: {
          "Content-Type": "application/json",
          Authorization: "Basic " + btoa(`${auth.username}:${auth.password}`),
        },
        body: JSON.stringify(body),
      });
      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;
    };
    /**
     * Create Custom Object Field
     * Creates any of the following custom field types:
    
    * text (default when no "type" is specified)
    * textarea
    * checkbox
    * date
    * integer
    * decimal
    * regexp
    * dropdown
    * lookup
    
    See [About custom field types](https://support.zendesk.com/hc/en-us/articles/203661866) in Zendesk help.
    
    #### Allowed For
    
    * Admins
    
     */
    export async function main(
      auth: Zendesk,
      custom_object_key: string,
      body: {
        custom_object_field?: {
          active?: string;
          created_at?: string;
          custom_field_options?: {
            id?: string;
            name?: string;
            position?: string;
            raw_name?: string;
            url?: string;
            value?: string;
            [k: string]: unknown;
          }[];
          description?: string;
          id?: string;
          key?: string;
          position?: string;
          raw_description?: string;
          raw_title?: string;
          regexp_for_validation?: string;
          relationship_filter?: { [k: string]: unknown };
          relationship_target_type?: string;
          system?: string;
          tag?: string;
          title?: string;
          type?: string;
          updated_at?: string;
          url?: string;
          [k: string]: unknown;
        };
        [k: string]: unknown;
      }
    ) {
      const url = new URL(
        `https://${auth.subdomain}.zendesk.com/api/v2/custom_objects/${custom_object_key}/fields`
      );
    
      const response = await fetch(url, {
        method: "POST",
        headers: {
          "Content-Type": "application/json",
          Authorization: "Basic " + btoa(`${auth.username}:${auth.password}`),
        },
        body: JSON.stringify(body),
      });
      if (!response.ok) {
        const text = await response.text();
        throw new Error(`${response.status} ${text}`);
      }
      return await response.json();
    }
    

    Submitted by hugo697 923 days ago