Edits history of script submission #2639 for ' Get invoices upcoming lines (stripe)'

  • nativets
    One script reply has been approved by the moderators
    Ap­pro­ved
    type Stripe = {
      token: string;
    };
    /**
     * Get invoices upcoming lines
     * When retrieving an upcoming invoice, you’ll get a lines property containing the total count of line items and the first handful of those items. There is also a URL where you can retrieve the full (paginated) list of line items.
     */
    export async function main(
      auth: Stripe,
      automatic_tax: any,
      coupon: string | undefined,
      currency: string | undefined,
      customer: string | undefined,
      customer_details: any,
      discounts: any,
      ending_before: string | undefined,
      expand: any,
      invoice_items: any,
      issuer: any,
      limit: string | undefined,
      on_behalf_of: any,
      schedule: string | undefined,
      starting_after: string | undefined,
      subscription: string | undefined,
      subscription_billing_cycle_anchor: any,
      subscription_cancel_at: any,
      subscription_cancel_at_period_end: string | undefined,
      subscription_cancel_now: string | undefined,
      subscription_default_tax_rates: any,
      subscription_items: any,
      subscription_proration_behavior:
        | "always_invoice"
        | "create_prorations"
        | "none"
        | undefined,
      subscription_proration_date: string | undefined,
      subscription_resume_at: "now" | undefined,
      subscription_start_date: string | undefined,
      subscription_trial_end: any,
      subscription_trial_from_plan: string | undefined
    ) {
      const url = new URL(`https://api.stripe.com/v1/invoices/upcoming/lines`);
      for (const [k, v] of [
        ["coupon", coupon],
        ["currency", currency],
        ["customer", customer],
        ["ending_before", ending_before],
        ["limit", limit],
        ["schedule", schedule],
        ["starting_after", starting_after],
        ["subscription", subscription],
        ["subscription_cancel_at_period_end", subscription_cancel_at_period_end],
        ["subscription_cancel_now", subscription_cancel_now],
        ["subscription_proration_behavior", subscription_proration_behavior],
        ["subscription_proration_date", subscription_proration_date],
        ["subscription_resume_at", subscription_resume_at],
        ["subscription_start_date", subscription_start_date],
        ["subscription_trial_from_plan", subscription_trial_from_plan],
      ]) {
        if (v !== undefined && v !== "") {
          url.searchParams.append(k, v);
        }
      }
      encodeParams({
        automatic_tax,
        customer_details,
        discounts,
        expand,
        invoice_items,
        issuer,
        on_behalf_of,
        subscription_billing_cycle_anchor,
        subscription_cancel_at,
        subscription_default_tax_rates,
        subscription_items,
        subscription_trial_end,
      }).forEach((v, k) => {
        if (v !== undefined && v !== "") {
          url.searchParams.append(k, v);
        }
      });
      const response = await fetch(url, {
        method: "GET",
        headers: {
          "Content-Type": "application/x-www-form-urlencoded",
          Authorization: "Bearer " + auth.token,
        },
        body: undefined,
      });
      if (!response.ok) {
        const text = await response.text();
        throw new Error(`${response.status} ${text}`);
      }
      return await response.json();
    }
    
    function encodeParams(o: any) {
      function iter(o: any, path: string) {
        if (Array.isArray(o)) {
          o.forEach(function (a) {
            iter(a, path + "[]");
          });
          return;
        }
        if (o !== null && typeof o === "object") {
          Object.keys(o).forEach(function (k) {
            iter(o[k], path + "[" + k + "]");
          });
          return;
        }
        data.push(path + "=" + o);
      }
      const data: string[] = [];
      Object.keys(o).forEach(function (k) {
        if (o[k] !== undefined) {
          iter(o[k], k);
        }
      });
      return new URLSearchParams(data.join("&"));
    }
    

    Submitted by hugo697 368 days ago

  • nativets
    type Stripe = {
      token: string;
    };
    /**
     * Get invoices upcoming lines
     * When retrieving an upcoming invoice, you’ll get a lines property containing the total count of line items and the first handful of those items. There is also a URL where you can retrieve the full (paginated) list of line items.
     */
    export async function main(
      auth: Stripe,
      automatic_tax: any,
      coupon: string | undefined,
      currency: string | undefined,
      customer: string | undefined,
      customer_details: any,
      discounts: any,
      ending_before: string | undefined,
      expand: any,
      invoice_items: any,
      issuer: any,
      limit: string | undefined,
      on_behalf_of: any,
      schedule: string | undefined,
      starting_after: string | undefined,
      subscription: string | undefined,
      subscription_billing_cycle_anchor: any,
      subscription_cancel_at: any,
      subscription_cancel_at_period_end: string | undefined,
      subscription_cancel_now: string | undefined,
      subscription_default_tax_rates: any,
      subscription_items: any,
      subscription_proration_behavior:
        | "always_invoice"
        | "create_prorations"
        | "none"
        | undefined,
      subscription_proration_date: string | undefined,
      subscription_resume_at: "now" | undefined,
      subscription_start_date: string | undefined,
      subscription_trial_end: any,
      subscription_trial_from_plan: string | undefined
    ) {
      const url = new URL(`https://api.stripe.com/v1/invoices/upcoming/lines`);
      for (const [k, v] of [
        ["coupon", coupon],
        ["currency", currency],
        ["customer", customer],
        ["ending_before", ending_before],
        ["limit", limit],
        ["schedule", schedule],
        ["starting_after", starting_after],
        ["subscription", subscription],
        ["subscription_cancel_at_period_end", subscription_cancel_at_period_end],
        ["subscription_cancel_now", subscription_cancel_now],
        ["subscription_proration_behavior", subscription_proration_behavior],
        ["subscription_proration_date", subscription_proration_date],
        ["subscription_resume_at", subscription_resume_at],
        ["subscription_start_date", subscription_start_date],
        ["subscription_trial_from_plan", subscription_trial_from_plan],
      ]) {
        if (v !== undefined && v !== "") {
          url.searchParams.append(k, v);
        }
      }
      encodeParams({
        automatic_tax,
        customer_details,
        discounts,
        expand,
        invoice_items,
        issuer,
        on_behalf_of,
        subscription_billing_cycle_anchor,
        subscription_cancel_at,
        subscription_default_tax_rates,
        subscription_items,
        subscription_trial_end,
      }).forEach((v, k) => {
        if (v !== undefined && v !== "") {
          url.searchParams.append(k, v);
        }
      });
      const response = await fetch(url, {
        method: "GET",
        headers: {
          "Content-Type": "application/x-www-form-urlencoded",
          Authorization: "Bearer " + auth.token,
        },
        body: undefined,
      });
      if (!response.ok) {
        const text = await response.text();
        throw new Error(`${response.status} ${text}`);
      }
      return await response.json();
    }
    
    function encodeParams(o: any) {
      function iter(o: any, path: string) {
        if (Array.isArray(o)) {
          o.forEach(function (a) {
            iter(a, path + "[]");
          });
          return;
        }
        if (o !== null && typeof o === "object") {
          Object.keys(o).forEach(function (k) {
            iter(o[k], path + "[" + k + "]");
          });
          return;
        }
        data.push(path + "=" + o);
      }
      const data: string[] = [];
      Object.keys(o).forEach(function (k) {
        if (o[k] !== undefined) {
          iter(o[k], k);
        }
      });
      return new URLSearchParams(data.join("&"));
    }
    

    Submitted by hugo697 795 days ago

  • nativets
    type Stripe = {
      token: string;
    };
    /**
     * Get invoices upcoming lines
     * <p>When retrieving an upcoming invoice, you’ll get a <strong>lines</strong> property containing the total count of line items and the first handful of those items. There is also a URL where you can retrieve the full (paginated) list of line items.</p>
     */
    export async function main(
      auth: Stripe,
      automatic_tax: any,
      coupon: string | undefined,
      currency: string | undefined,
      customer: string | undefined,
      customer_details: any,
      discounts: any,
      ending_before: string | undefined,
      expand: any,
      invoice_items: any,
      limit: string | undefined,
      schedule: string | undefined,
      starting_after: string | undefined,
      subscription: string | undefined,
      subscription_billing_cycle_anchor: any,
      subscription_cancel_at: any,
      subscription_cancel_at_period_end: string | undefined,
      subscription_cancel_now: string | undefined,
      subscription_default_tax_rates: any,
      subscription_items: any,
      subscription_proration_behavior:
        | "always_invoice"
        | "create_prorations"
        | "none"
        | undefined,
      subscription_proration_date: string | undefined,
      subscription_resume_at: "now" | undefined,
      subscription_start_date: string | undefined,
      subscription_trial_end: any,
      subscription_trial_from_plan: string | undefined
    ) {
      const url = new URL(`https://api.stripe.com/v1/invoices/upcoming/lines`);
      for (const [k, v] of [
        ["coupon", coupon],
        ["currency", currency],
        ["customer", customer],
        ["ending_before", ending_before],
        ["limit", limit],
        ["schedule", schedule],
        ["starting_after", starting_after],
        ["subscription", subscription],
        ["subscription_cancel_at_period_end", subscription_cancel_at_period_end],
        ["subscription_cancel_now", subscription_cancel_now],
        ["subscription_proration_behavior", subscription_proration_behavior],
        ["subscription_proration_date", subscription_proration_date],
        ["subscription_resume_at", subscription_resume_at],
        ["subscription_start_date", subscription_start_date],
        ["subscription_trial_from_plan", subscription_trial_from_plan],
      ]) {
        if (v !== undefined && v !== "") {
          url.searchParams.append(k, v);
        }
      }
      encodeParams({
        automatic_tax,
        customer_details,
        discounts,
        expand,
        invoice_items,
        subscription_billing_cycle_anchor,
        subscription_cancel_at,
        subscription_default_tax_rates,
        subscription_items,
        subscription_trial_end,
      }).forEach((v, k) => {
        if (v !== undefined && v !== "") {
          url.searchParams.append(k, v);
        }
      });
      const response = await fetch(url, {
        method: "GET",
        headers: {
          "Content-Type": "application/x-www-form-urlencoded",
          Authorization: "Bearer " + auth.token,
        },
        body: undefined,
      });
      if (!response.ok) {
        const text = await response.text();
        throw new Error(`${response.status} ${text}`);
      }
      return await response.json();
    }
    
    function encodeParams(o: any) {
      function iter(o: any, path: string) {
        if (Array.isArray(o)) {
          o.forEach(function (a) {
            iter(a, path + "[]");
          });
          return;
        }
        if (o !== null && typeof o === "object") {
          Object.keys(o).forEach(function (k) {
            iter(o[k], path + "[" + k + "]");
          });
          return;
        }
        data.push(path + "=" + o);
      }
      const data: string[] = [];
      Object.keys(o).forEach(function (k) {
        if (o[k] !== undefined) {
          iter(o[k], k);
        }
      });
      return new URLSearchParams(data.join("&"));
    }
    

    Submitted by hugo697 922 days ago