com.stripe.service.SubscriptionScheduleService Maven / Gradle / Ivy
// File generated from our OpenAPI spec
package com.stripe.service;
import com.google.gson.reflect.TypeToken;
import com.stripe.exception.StripeException;
import com.stripe.model.StripeCollection;
import com.stripe.model.SubscriptionSchedule;
import com.stripe.net.ApiRequest;
import com.stripe.net.ApiRequestParams;
import com.stripe.net.ApiResource;
import com.stripe.net.ApiService;
import com.stripe.net.BaseAddress;
import com.stripe.net.RequestOptions;
import com.stripe.net.StripeResponseGetter;
import com.stripe.param.SubscriptionScheduleAmendParams;
import com.stripe.param.SubscriptionScheduleCancelParams;
import com.stripe.param.SubscriptionScheduleCreateParams;
import com.stripe.param.SubscriptionScheduleListParams;
import com.stripe.param.SubscriptionScheduleReleaseParams;
import com.stripe.param.SubscriptionScheduleRetrieveParams;
import com.stripe.param.SubscriptionScheduleUpdateParams;
public final class SubscriptionScheduleService extends ApiService {
public SubscriptionScheduleService(StripeResponseGetter responseGetter) {
super(responseGetter);
}
/** Retrieves the list of your subscription schedules. */
public StripeCollection list(SubscriptionScheduleListParams params)
throws StripeException {
return list(params, (RequestOptions) null);
}
/** Retrieves the list of your subscription schedules. */
public StripeCollection list(RequestOptions options)
throws StripeException {
return list((SubscriptionScheduleListParams) null, options);
}
/** Retrieves the list of your subscription schedules. */
public StripeCollection list() throws StripeException {
return list((SubscriptionScheduleListParams) null, (RequestOptions) null);
}
/** Retrieves the list of your subscription schedules. */
public StripeCollection list(
SubscriptionScheduleListParams params, RequestOptions options) throws StripeException {
String path = "/v1/subscription_schedules";
ApiRequest request =
new ApiRequest(
BaseAddress.API,
ApiResource.RequestMethod.GET,
path,
ApiRequestParams.paramsToMap(params),
options);
return this.request(
request, new TypeToken>() {}.getType());
}
/**
* Creates a new subscription schedule object. Each customer can have up to 500 active or
* scheduled subscriptions.
*/
public SubscriptionSchedule create(SubscriptionScheduleCreateParams params)
throws StripeException {
return create(params, (RequestOptions) null);
}
/**
* Creates a new subscription schedule object. Each customer can have up to 500 active or
* scheduled subscriptions.
*/
public SubscriptionSchedule create(RequestOptions options) throws StripeException {
return create((SubscriptionScheduleCreateParams) null, options);
}
/**
* Creates a new subscription schedule object. Each customer can have up to 500 active or
* scheduled subscriptions.
*/
public SubscriptionSchedule create() throws StripeException {
return create((SubscriptionScheduleCreateParams) null, (RequestOptions) null);
}
/**
* Creates a new subscription schedule object. Each customer can have up to 500 active or
* scheduled subscriptions.
*/
public SubscriptionSchedule create(
SubscriptionScheduleCreateParams params, RequestOptions options) throws StripeException {
String path = "/v1/subscription_schedules";
ApiRequest request =
new ApiRequest(
BaseAddress.API,
ApiResource.RequestMethod.POST,
path,
ApiRequestParams.paramsToMap(params),
options);
return this.request(request, SubscriptionSchedule.class);
}
/**
* Retrieves the details of an existing subscription schedule. You only need to supply the unique
* subscription schedule identifier that was returned upon subscription schedule creation.
*/
public SubscriptionSchedule retrieve(String schedule, SubscriptionScheduleRetrieveParams params)
throws StripeException {
return retrieve(schedule, params, (RequestOptions) null);
}
/**
* Retrieves the details of an existing subscription schedule. You only need to supply the unique
* subscription schedule identifier that was returned upon subscription schedule creation.
*/
public SubscriptionSchedule retrieve(String schedule, RequestOptions options)
throws StripeException {
return retrieve(schedule, (SubscriptionScheduleRetrieveParams) null, options);
}
/**
* Retrieves the details of an existing subscription schedule. You only need to supply the unique
* subscription schedule identifier that was returned upon subscription schedule creation.
*/
public SubscriptionSchedule retrieve(String schedule) throws StripeException {
return retrieve(schedule, (SubscriptionScheduleRetrieveParams) null, (RequestOptions) null);
}
/**
* Retrieves the details of an existing subscription schedule. You only need to supply the unique
* subscription schedule identifier that was returned upon subscription schedule creation.
*/
public SubscriptionSchedule retrieve(
String schedule, SubscriptionScheduleRetrieveParams params, RequestOptions options)
throws StripeException {
String path = String.format("/v1/subscription_schedules/%s", ApiResource.urlEncodeId(schedule));
ApiRequest request =
new ApiRequest(
BaseAddress.API,
ApiResource.RequestMethod.GET,
path,
ApiRequestParams.paramsToMap(params),
options);
return this.request(request, SubscriptionSchedule.class);
}
/** Updates an existing subscription schedule. */
public SubscriptionSchedule update(String schedule, SubscriptionScheduleUpdateParams params)
throws StripeException {
return update(schedule, params, (RequestOptions) null);
}
/** Updates an existing subscription schedule. */
public SubscriptionSchedule update(String schedule, RequestOptions options)
throws StripeException {
return update(schedule, (SubscriptionScheduleUpdateParams) null, options);
}
/** Updates an existing subscription schedule. */
public SubscriptionSchedule update(String schedule) throws StripeException {
return update(schedule, (SubscriptionScheduleUpdateParams) null, (RequestOptions) null);
}
/** Updates an existing subscription schedule. */
public SubscriptionSchedule update(
String schedule, SubscriptionScheduleUpdateParams params, RequestOptions options)
throws StripeException {
String path = String.format("/v1/subscription_schedules/%s", ApiResource.urlEncodeId(schedule));
ApiRequest request =
new ApiRequest(
BaseAddress.API,
ApiResource.RequestMethod.POST,
path,
ApiRequestParams.paramsToMap(params),
options);
return this.request(request, SubscriptionSchedule.class);
}
/** Amends an existing subscription schedule. */
public SubscriptionSchedule amend(String schedule, SubscriptionScheduleAmendParams params)
throws StripeException {
return amend(schedule, params, (RequestOptions) null);
}
/** Amends an existing subscription schedule. */
public SubscriptionSchedule amend(String schedule, RequestOptions options)
throws StripeException {
return amend(schedule, (SubscriptionScheduleAmendParams) null, options);
}
/** Amends an existing subscription schedule. */
public SubscriptionSchedule amend(String schedule) throws StripeException {
return amend(schedule, (SubscriptionScheduleAmendParams) null, (RequestOptions) null);
}
/** Amends an existing subscription schedule. */
public SubscriptionSchedule amend(
String schedule, SubscriptionScheduleAmendParams params, RequestOptions options)
throws StripeException {
String path =
String.format("/v1/subscription_schedules/%s/amend", ApiResource.urlEncodeId(schedule));
ApiRequest request =
new ApiRequest(
BaseAddress.API,
ApiResource.RequestMethod.POST,
path,
ApiRequestParams.paramsToMap(params),
options);
return this.request(request, SubscriptionSchedule.class);
}
/**
* Cancels a subscription schedule and its associated subscription immediately (if the
* subscription schedule has an active subscription). A subscription schedule can only be canceled
* if its status is {@code not_started} or {@code active}.
*/
public SubscriptionSchedule cancel(String schedule, SubscriptionScheduleCancelParams params)
throws StripeException {
return cancel(schedule, params, (RequestOptions) null);
}
/**
* Cancels a subscription schedule and its associated subscription immediately (if the
* subscription schedule has an active subscription). A subscription schedule can only be canceled
* if its status is {@code not_started} or {@code active}.
*/
public SubscriptionSchedule cancel(String schedule, RequestOptions options)
throws StripeException {
return cancel(schedule, (SubscriptionScheduleCancelParams) null, options);
}
/**
* Cancels a subscription schedule and its associated subscription immediately (if the
* subscription schedule has an active subscription). A subscription schedule can only be canceled
* if its status is {@code not_started} or {@code active}.
*/
public SubscriptionSchedule cancel(String schedule) throws StripeException {
return cancel(schedule, (SubscriptionScheduleCancelParams) null, (RequestOptions) null);
}
/**
* Cancels a subscription schedule and its associated subscription immediately (if the
* subscription schedule has an active subscription). A subscription schedule can only be canceled
* if its status is {@code not_started} or {@code active}.
*/
public SubscriptionSchedule cancel(
String schedule, SubscriptionScheduleCancelParams params, RequestOptions options)
throws StripeException {
String path =
String.format("/v1/subscription_schedules/%s/cancel", ApiResource.urlEncodeId(schedule));
ApiRequest request =
new ApiRequest(
BaseAddress.API,
ApiResource.RequestMethod.POST,
path,
ApiRequestParams.paramsToMap(params),
options);
return this.request(request, SubscriptionSchedule.class);
}
/**
* Releases the subscription schedule immediately, which will stop scheduling of its phases, but
* leave any existing subscription in place. A schedule can only be released if its status is
* {@code not_started} or {@code active}. If the subscription schedule is currently associated
* with a subscription, releasing it will remove its {@code subscription} property and set the
* subscription’s ID to the {@code released_subscription} property.
*/
public SubscriptionSchedule release(String schedule, SubscriptionScheduleReleaseParams params)
throws StripeException {
return release(schedule, params, (RequestOptions) null);
}
/**
* Releases the subscription schedule immediately, which will stop scheduling of its phases, but
* leave any existing subscription in place. A schedule can only be released if its status is
* {@code not_started} or {@code active}. If the subscription schedule is currently associated
* with a subscription, releasing it will remove its {@code subscription} property and set the
* subscription’s ID to the {@code released_subscription} property.
*/
public SubscriptionSchedule release(String schedule, RequestOptions options)
throws StripeException {
return release(schedule, (SubscriptionScheduleReleaseParams) null, options);
}
/**
* Releases the subscription schedule immediately, which will stop scheduling of its phases, but
* leave any existing subscription in place. A schedule can only be released if its status is
* {@code not_started} or {@code active}. If the subscription schedule is currently associated
* with a subscription, releasing it will remove its {@code subscription} property and set the
* subscription’s ID to the {@code released_subscription} property.
*/
public SubscriptionSchedule release(String schedule) throws StripeException {
return release(schedule, (SubscriptionScheduleReleaseParams) null, (RequestOptions) null);
}
/**
* Releases the subscription schedule immediately, which will stop scheduling of its phases, but
* leave any existing subscription in place. A schedule can only be released if its status is
* {@code not_started} or {@code active}. If the subscription schedule is currently associated
* with a subscription, releasing it will remove its {@code subscription} property and set the
* subscription’s ID to the {@code released_subscription} property.
*/
public SubscriptionSchedule release(
String schedule, SubscriptionScheduleReleaseParams params, RequestOptions options)
throws StripeException {
String path =
String.format("/v1/subscription_schedules/%s/release", ApiResource.urlEncodeId(schedule));
ApiRequest request =
new ApiRequest(
BaseAddress.API,
ApiResource.RequestMethod.POST,
path,
ApiRequestParams.paramsToMap(params),
options);
return this.request(request, SubscriptionSchedule.class);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy