Edits history of script submission #5097 for ' Get BGP hijack events (cloudflare)'

  • nativets
    One script reply has been approved by the moderators
    Ap­pro­ved
    type Cloudflare = {
      token: string;
      email: string;
      key: string;
    };
    /**
     * Get BGP hijack events
     * Get the BGP hijack events. (Beta)
     */
    export async function main(
      auth: Cloudflare,
      page: string | undefined,
      per_page: string | undefined,
      eventId: string | undefined,
      hijackerAsn: string | undefined,
      victimAsn: string | undefined,
      involvedAsn: string | undefined,
      involvedCountry: string | undefined,
      prefix: string | undefined,
      minConfidence: string | undefined,
      maxConfidence: string | undefined,
      dateRange:
        | "1d"
        | "2d"
        | "7d"
        | "14d"
        | "28d"
        | "12w"
        | "24w"
        | "52w"
        | "1dControl"
        | "2dControl"
        | "7dControl"
        | "14dControl"
        | "28dControl"
        | "12wControl"
        | "24wControl"
        | undefined,
      dateStart: string | undefined,
      dateEnd: string | undefined,
      sortBy: "ID" | "TIME" | "CONFIDENCE" | undefined,
      sortOrder: "ASC" | "DESC" | undefined,
      format: "JSON" | "CSV" | undefined
    ) {
      const url = new URL(
        `https://api.cloudflare.com/client/v4/radar/bgp/hijacks/events`
      );
      for (const [k, v] of [
        ["page", page],
        ["per_page", per_page],
        ["eventId", eventId],
        ["hijackerAsn", hijackerAsn],
        ["victimAsn", victimAsn],
        ["involvedAsn", involvedAsn],
        ["involvedCountry", involvedCountry],
        ["prefix", prefix],
        ["minConfidence", minConfidence],
        ["maxConfidence", maxConfidence],
        ["dateRange", dateRange],
        ["dateStart", dateStart],
        ["dateEnd", dateEnd],
        ["sortBy", sortBy],
        ["sortOrder", sortOrder],
        ["format", format],
      ]) {
        if (v !== undefined && v !== "") {
          url.searchParams.append(k, v);
        }
      }
      const response = await fetch(url, {
        method: "GET",
        headers: {
          "X-AUTH-EMAIL": auth.email,
          "X-AUTH-KEY": auth.key,
          Authorization: "Bearer " + auth.token,
        },
        body: undefined,
      });
      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;
    };
    /**
     * Get BGP hijack events
     * Get the BGP hijack events. (Beta)
     */
    export async function main(
      auth: Cloudflare,
      page: string | undefined,
      per_page: string | undefined,
      eventId: string | undefined,
      hijackerAsn: string | undefined,
      victimAsn: string | undefined,
      involvedAsn: string | undefined,
      involvedCountry: string | undefined,
      prefix: string | undefined,
      minConfidence: string | undefined,
      maxConfidence: string | undefined,
      dateRange:
        | "1d"
        | "2d"
        | "7d"
        | "14d"
        | "28d"
        | "12w"
        | "24w"
        | "52w"
        | "1dControl"
        | "2dControl"
        | "7dControl"
        | "14dControl"
        | "28dControl"
        | "12wControl"
        | "24wControl"
        | undefined,
      dateStart: string | undefined,
      dateEnd: string | undefined,
      sortBy: "ID" | "TIME" | "CONFIDENCE" | undefined,
      sortOrder: "ASC" | "DESC" | undefined,
      format: "JSON" | "CSV" | undefined
    ) {
      const url = new URL(
        `https://api.cloudflare.com/client/v4/radar/bgp/hijacks/events`
      );
      for (const [k, v] of [
        ["page", page],
        ["per_page", per_page],
        ["eventId", eventId],
        ["hijackerAsn", hijackerAsn],
        ["victimAsn", victimAsn],
        ["involvedAsn", involvedAsn],
        ["involvedCountry", involvedCountry],
        ["prefix", prefix],
        ["minConfidence", minConfidence],
        ["maxConfidence", maxConfidence],
        ["dateRange", dateRange],
        ["dateStart", dateStart],
        ["dateEnd", dateEnd],
        ["sortBy", sortBy],
        ["sortOrder", sortOrder],
        ["format", format],
      ]) {
        if (v !== undefined && v !== "") {
          url.searchParams.append(k, v);
        }
      }
      const response = await fetch(url, {
        method: "GET",
        headers: {
          "X-AUTH-EMAIL": auth.email,
          "X-AUTH-KEY": auth.key,
          Authorization: "Bearer " + auth.token,
        },
        body: undefined,
      });
      if (!response.ok) {
        const text = await response.text();
        throw new Error(`${response.status} ${text}`);
      }
      return await response.json();
    }
    

    Submitted by hugo697 920 days ago