All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.stripe.model.reporting.ReportRun Maven / Gradle / Ivy

There is a newer version: 28.2.0
Show newest version
// File generated from our OpenAPI spec
package com.stripe.model.reporting;

import com.google.gson.annotations.SerializedName;
import com.stripe.exception.StripeException;
import com.stripe.model.File;
import com.stripe.model.HasId;
import com.stripe.model.StripeObject;
import com.stripe.net.ApiRequest;
import com.stripe.net.ApiRequestParams;
import com.stripe.net.ApiResource;
import com.stripe.net.BaseAddress;
import com.stripe.net.RequestOptions;
import com.stripe.net.StripeResponseGetter;
import com.stripe.param.reporting.ReportRunCreateParams;
import com.stripe.param.reporting.ReportRunListParams;
import com.stripe.param.reporting.ReportRunRetrieveParams;
import java.util.List;
import java.util.Map;
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.Setter;

/**
 * The Report Run object represents an instance of a report type generated with specific run
 * parameters. Once the object is created, Stripe begins processing the report. When the report has
 * finished running, it will give you a reference to a file where you can retrieve your results. For
 * an overview, see API Access to
 * Reports.
 *
 * 

Note that certain report types can only be run based on your live-mode data (not test-mode * data), and will error when queried without a live-mode API key. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public class ReportRun extends ApiResource implements HasId { /** Time at which the object was created. Measured in seconds since the Unix epoch. */ @SerializedName("created") Long created; /** * If something should go wrong during the run, a message about the failure (populated when {@code * status=failed}). */ @SerializedName("error") String error; /** Unique identifier for the object. */ @Getter(onMethod_ = {@Override}) @SerializedName("id") String id; /** * {@code true} if the report is run on live mode data and {@code false} if it is run on test mode * data. */ @SerializedName("livemode") Boolean livemode; /** * String representing the object's type. Objects of the same type share the same value. * *

Equal to {@code reporting.report_run}. */ @SerializedName("object") String object; @SerializedName("parameters") Parameters parameters; /** * The ID of the report type to run, * such as {@code "balance.summary.1"}. */ @SerializedName("report_type") String reportType; /** * The file object representing the result of the report run (populated when {@code * status=succeeded}). */ @SerializedName("result") File result; /** * Status of this report run. This will be {@code pending} when the run is initially created. When * the run finishes, this will be set to {@code succeeded} and the {@code result} field will be * populated. Rarely, we may encounter an error, at which point this will be set to {@code failed} * and the {@code error} field will be populated. */ @SerializedName("status") String status; /** * Timestamp at which this run successfully finished (populated when {@code status=succeeded}). * Measured in seconds since the Unix epoch. */ @SerializedName("succeeded_at") Long succeededAt; /** * Creates a new object and begin running the report. (Certain report types require a live-mode API key.) */ public static ReportRun create(Map params) throws StripeException { return create(params, (RequestOptions) null); } /** * Creates a new object and begin running the report. (Certain report types require a live-mode API key.) */ public static ReportRun create(Map params, RequestOptions options) throws StripeException { String path = "/v1/reporting/report_runs"; ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getGlobalResponseGetter().request(request, ReportRun.class); } /** * Creates a new object and begin running the report. (Certain report types require a live-mode API key.) */ public static ReportRun create(ReportRunCreateParams params) throws StripeException { return create(params, (RequestOptions) null); } /** * Creates a new object and begin running the report. (Certain report types require a live-mode API key.) */ public static ReportRun create(ReportRunCreateParams params, RequestOptions options) throws StripeException { String path = "/v1/reporting/report_runs"; ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, ApiRequestParams.paramsToMap(params), options); return getGlobalResponseGetter().request(request, ReportRun.class); } /** Returns a list of Report Runs, with the most recent appearing first. */ public static ReportRunCollection list(Map params) throws StripeException { return list(params, (RequestOptions) null); } /** Returns a list of Report Runs, with the most recent appearing first. */ public static ReportRunCollection list(Map params, RequestOptions options) throws StripeException { String path = "/v1/reporting/report_runs"; ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options); return getGlobalResponseGetter().request(request, ReportRunCollection.class); } /** Returns a list of Report Runs, with the most recent appearing first. */ public static ReportRunCollection list(ReportRunListParams params) throws StripeException { return list(params, (RequestOptions) null); } /** Returns a list of Report Runs, with the most recent appearing first. */ public static ReportRunCollection list(ReportRunListParams params, RequestOptions options) throws StripeException { String path = "/v1/reporting/report_runs"; ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.GET, path, ApiRequestParams.paramsToMap(params), options); return getGlobalResponseGetter().request(request, ReportRunCollection.class); } /** Retrieves the details of an existing Report Run. */ public static ReportRun retrieve(String reportRun) throws StripeException { return retrieve(reportRun, (Map) null, (RequestOptions) null); } /** Retrieves the details of an existing Report Run. */ public static ReportRun retrieve(String reportRun, RequestOptions options) throws StripeException { return retrieve(reportRun, (Map) null, options); } /** Retrieves the details of an existing Report Run. */ public static ReportRun retrieve( String reportRun, Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/reporting/report_runs/%s", ApiResource.urlEncodeId(reportRun)); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options); return getGlobalResponseGetter().request(request, ReportRun.class); } /** Retrieves the details of an existing Report Run. */ public static ReportRun retrieve( String reportRun, ReportRunRetrieveParams params, RequestOptions options) throws StripeException { String path = String.format("/v1/reporting/report_runs/%s", ApiResource.urlEncodeId(reportRun)); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.GET, path, ApiRequestParams.paramsToMap(params), options); return getGlobalResponseGetter().request(request, ReportRun.class); } /** * For more details about Parameters, please refer to the API Reference. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Parameters extends StripeObject { /** The set of output columns requested for inclusion in the report run. */ @SerializedName("columns") List columns; /** Connected account ID by which to filter the report run. */ @SerializedName("connected_account") String connectedAccount; /** Currency of objects to be included in the report run. */ @SerializedName("currency") String currency; /** * Ending timestamp of data to be included in the report run. Can be any UTC timestamp between 1 * second after the user specified {@code interval_start} and 1 second before this report's last * {@code data_available_end} value. */ @SerializedName("interval_end") Long intervalEnd; /** * Starting timestamp of data to be included in the report run. Can be any UTC timestamp between * 1 second after this report's {@code data_available_start} and 1 second before the user * specified {@code interval_end} value. */ @SerializedName("interval_start") Long intervalStart; /** Payout ID by which to filter the report run. */ @SerializedName("payout") String payout; /** Category of balance transactions to be included in the report run. */ @SerializedName("reporting_category") String reportingCategory; /** * Defaults to {@code Etc/UTC}. The output timezone for all timestamps in the report. A list of * possible time zone values is maintained at the IANA * Time Zone Database. Has no effect on {@code interval_start} or {@code interval_end}. */ @SerializedName("timezone") String timezone; } @Override public void setResponseGetter(StripeResponseGetter responseGetter) { super.setResponseGetter(responseGetter); trySetResponseGetter(parameters, responseGetter); trySetResponseGetter(result, responseGetter); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy