Edits history of script submission #20715 for ' ListMerchantCustomAttributes (square)'

  • bun
    One script reply has been approved by the moderators
    Ap­pro­ved
    //native
    type Square = {
      token: string;
    };
    /**
     * ListMerchantCustomAttributes
     * Lists the [custom attributes]($m/CustomAttribute) associated with a merchant.
    You can use the `with_definitions` query parameter to also retrieve custom attribute definitions
    in the same call.
    When all response pages are retrieved, the results include all custom attributes that are
    visible to the requesting application, including those that are owned by other applications
    and set to `VISIBILITY_READ_ONLY` or `VISIBILITY_READ_WRITE_VALUES`.
     */
    export async function main(
      auth: Square,
      merchant_id: string,
      visibility_filter: "ALL" | "READ" | "READ_WRITE" | undefined,
      limit: string | undefined,
      cursor: string | undefined,
      with_definitions: string | undefined,
    ) {
      const url = new URL(
        `https://connect.squareup.com/v2/merchants/${merchant_id}/custom-attributes`,
      );
      for (const [k, v] of [
        ["visibility_filter", visibility_filter],
        ["limit", limit],
        ["cursor", cursor],
        ["with_definitions", with_definitions],
      ]) {
        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 235 days ago