Edits history of script submission #10853 for ' List 1-Click Applications (digitalocean)'

  • bun
    One script reply has been approved by the moderators
    Ap­pro­ved
    //native
    type Digitalocean = {
      token: string;
    };
    /**
     * List 1-Click Applications
     * To list all available 1-Click applications, send a GET request to `/v2/1-clicks`. The `type` may
    be provided as query paramater in order to restrict results to a certain type of 1-Click, for
    example: `/v2/1-clicks?type=droplet`. Current supported types are `kubernetes` and `droplet`.
    
    The response will be a JSON object with a key called `1_clicks`. This will be set to an array of
    1-Click application data, each of which will contain the the slug and type for the 1-Click.
    
     */
    export async function main(
      auth: Digitalocean,
      type: "droplet" | "kubernetes" | undefined,
    ) {
      const url = new URL(`https://api.digitalocean.com/v2/1-clicks`);
      for (const [k, v] of [["type", type]]) {
        if (v !== undefined && v !== "" && k !== undefined) {
          url.searchParams.append(k, v);
        }
      }
      const response = await fetch(url, {
        method: "GET",
        headers: {
          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 536 days ago