Edits history of script submission #4924 for ' Preview Monitor (cloudflare)'

  • nativets
    One script reply has been approved by the moderators
    Ap­pro­ved
    type Cloudflare = {
      token: string;
      email: string;
      key: string;
    };
    /**
     * Preview Monitor
     * Preview pools using the specified monitor with provided monitor details. The returned preview_id can be used in the preview endpoint to retrieve the results.
     */
    export async function main(
      auth: Cloudflare,
      identifier: string,
      body: {
        allow_insecure?: boolean;
        consecutive_down?: number;
        consecutive_up?: number;
        description?: string;
        expected_body?: string;
        expected_codes?: string;
        follow_redirects?: boolean;
        header?: { [k: string]: unknown };
        interval?: number;
        method?: string;
        path?: string;
        port?: number;
        probe_zone?: string;
        retries?: number;
        timeout?: number;
        type?: "http" | "https" | "tcp" | "udp_icmp" | "icmp_ping" | "smtp";
        [k: string]: unknown;
      } & { [k: string]: unknown }
    ) {
      const url = new URL(
        `https://api.cloudflare.com/client/v4/user/load_balancers/monitors/${identifier}/preview`
      );
    
      const response = await fetch(url, {
        method: "POST",
        headers: {
          "X-AUTH-EMAIL": auth.email,
          "X-AUTH-KEY": auth.key,
          "Content-Type": "application/json",
          Authorization: "Bearer " + auth.token,
        },
        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 383 days ago

  • nativets
    type Cloudflare = {
      token: string;
      email: string;
      key: string;
    };
    /**
     * Preview Monitor
     * Preview pools using the specified monitor with provided monitor details. The returned preview_id can be used in the preview endpoint to retrieve the results.
     */
    export async function main(
      auth: Cloudflare,
      identifier: string,
      body: {
        allow_insecure?: boolean;
        consecutive_down?: number;
        consecutive_up?: number;
        description?: string;
        expected_body?: string;
        expected_codes?: string;
        follow_redirects?: boolean;
        header?: { [k: string]: unknown };
        interval?: number;
        method?: string;
        path?: string;
        port?: number;
        probe_zone?: string;
        retries?: number;
        timeout?: number;
        type?: "http" | "https" | "tcp" | "udp_icmp" | "icmp_ping" | "smtp";
        [k: string]: unknown;
      } & { [k: string]: unknown }
    ) {
      const url = new URL(
        `https://api.cloudflare.com/client/v4/user/load_balancers/monitors/${identifier}/preview`
      );
    
      const response = await fetch(url, {
        method: "POST",
        headers: {
          "X-AUTH-EMAIL": auth.email,
          "X-AUTH-KEY": auth.key,
          "Content-Type": "application/json",
          Authorization: "Bearer " + auth.token,
        },
        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 920 days ago