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

com.stripe.model.Review Maven / Gradle / Ivy

There is a newer version: 28.1.0-beta.3
Show newest version
// File generated from our OpenAPI spec
package com.stripe.model;

import com.google.gson.annotations.SerializedName;
import com.stripe.exception.StripeException;
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.ReviewApproveParams;
import com.stripe.param.ReviewListParams;
import com.stripe.param.ReviewRetrieveParams;
import java.math.BigDecimal;
import java.util.Map;
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.Setter;

/**
 * Reviews can be used to supplement automated fraud detection with human expertise.
 *
 * 

Learn more about Radar and reviewing payments here. */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public class Review extends ApiResource implements HasId { /** The ZIP or postal code of the card used, if applicable. */ @SerializedName("billing_zip") String billingZip; /** The charge associated with this review. */ @SerializedName("charge") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField charge; /** * The reason the review was closed, or null if it has not yet been closed. One of {@code * approved}, {@code refunded}, {@code refunded_as_fraud}, {@code disputed}, or {@code redacted}. */ @SerializedName("closed_reason") String closedReason; /** Time at which the object was created. Measured in seconds since the Unix epoch. */ @SerializedName("created") Long created; /** Unique identifier for the object. */ @Getter(onMethod_ = {@Override}) @SerializedName("id") String id; /** The IP address where the payment originated. */ @SerializedName("ip_address") String ipAddress; /** * Information related to the location of the payment. Note that this information is an * approximation and attempts to locate the nearest population center - it should not be used to * determine a specific address. */ @SerializedName("ip_address_location") IpAddressLocation ipAddressLocation; /** * Has the value {@code true} if the object exists in live mode or the value {@code false} if the * object exists in test mode. */ @SerializedName("livemode") Boolean livemode; /** * String representing the object's type. Objects of the same type share the same value. * *

Equal to {@code review}. */ @SerializedName("object") String object; /** If {@code true}, the review needs action. */ @SerializedName("open") Boolean open; /** The reason the review was opened. One of {@code rule} or {@code manual}. */ @SerializedName("opened_reason") String openedReason; /** The PaymentIntent ID associated with this review, if one exists. */ @SerializedName("payment_intent") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField paymentIntent; /** * The reason the review is currently open or closed. One of {@code rule}, {@code manual}, {@code * approved}, {@code refunded}, {@code refunded_as_fraud}, {@code disputed}, or {@code redacted}. */ @SerializedName("reason") String reason; /** Information related to the browsing session of the user who initiated the payment. */ @SerializedName("session") Session session; /** Get ID of expandable {@code charge} object. */ public String getCharge() { return (this.charge != null) ? this.charge.getId() : null; } public void setCharge(String id) { this.charge = ApiResource.setExpandableFieldId(id, this.charge); } /** Get expanded {@code charge}. */ public Charge getChargeObject() { return (this.charge != null) ? this.charge.getExpanded() : null; } public void setChargeObject(Charge expandableObject) { this.charge = new ExpandableField(expandableObject.getId(), expandableObject); } /** Get ID of expandable {@code paymentIntent} object. */ public String getPaymentIntent() { return (this.paymentIntent != null) ? this.paymentIntent.getId() : null; } public void setPaymentIntent(String id) { this.paymentIntent = ApiResource.setExpandableFieldId(id, this.paymentIntent); } /** Get expanded {@code paymentIntent}. */ public PaymentIntent getPaymentIntentObject() { return (this.paymentIntent != null) ? this.paymentIntent.getExpanded() : null; } public void setPaymentIntentObject(PaymentIntent expandableObject) { this.paymentIntent = new ExpandableField(expandableObject.getId(), expandableObject); } /** Approves a {@code Review} object, closing it and removing it from the list of reviews. */ public Review approve() throws StripeException { return approve((Map) null, (RequestOptions) null); } /** Approves a {@code Review} object, closing it and removing it from the list of reviews. */ public Review approve(RequestOptions options) throws StripeException { return approve((Map) null, options); } /** Approves a {@code Review} object, closing it and removing it from the list of reviews. */ public Review approve(Map params) throws StripeException { return approve(params, (RequestOptions) null); } /** Approves a {@code Review} object, closing it and removing it from the list of reviews. */ public Review approve(Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/reviews/%s/approve", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getResponseGetter().request(request, Review.class); } /** Approves a {@code Review} object, closing it and removing it from the list of reviews. */ public Review approve(ReviewApproveParams params) throws StripeException { return approve(params, (RequestOptions) null); } /** Approves a {@code Review} object, closing it and removing it from the list of reviews. */ public Review approve(ReviewApproveParams params, RequestOptions options) throws StripeException { String path = String.format("/v1/reviews/%s/approve", ApiResource.urlEncodeId(this.getId())); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, ApiRequestParams.paramsToMap(params), options); return getResponseGetter().request(request, Review.class); } /** * Returns a list of {@code Review} objects that have {@code open} set to {@code true}. The * objects are sorted in descending order by creation date, with the most recently created object * appearing first. */ public static ReviewCollection list(Map params) throws StripeException { return list(params, (RequestOptions) null); } /** * Returns a list of {@code Review} objects that have {@code open} set to {@code true}. The * objects are sorted in descending order by creation date, with the most recently created object * appearing first. */ public static ReviewCollection list(Map params, RequestOptions options) throws StripeException { String path = "/v1/reviews"; ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options); return getGlobalResponseGetter().request(request, ReviewCollection.class); } /** * Returns a list of {@code Review} objects that have {@code open} set to {@code true}. The * objects are sorted in descending order by creation date, with the most recently created object * appearing first. */ public static ReviewCollection list(ReviewListParams params) throws StripeException { return list(params, (RequestOptions) null); } /** * Returns a list of {@code Review} objects that have {@code open} set to {@code true}. The * objects are sorted in descending order by creation date, with the most recently created object * appearing first. */ public static ReviewCollection list(ReviewListParams params, RequestOptions options) throws StripeException { String path = "/v1/reviews"; ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.GET, path, ApiRequestParams.paramsToMap(params), options); return getGlobalResponseGetter().request(request, ReviewCollection.class); } /** Retrieves a {@code Review} object. */ public static Review retrieve(String review) throws StripeException { return retrieve(review, (Map) null, (RequestOptions) null); } /** Retrieves a {@code Review} object. */ public static Review retrieve(String review, RequestOptions options) throws StripeException { return retrieve(review, (Map) null, options); } /** Retrieves a {@code Review} object. */ public static Review retrieve(String review, Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/reviews/%s", ApiResource.urlEncodeId(review)); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options); return getGlobalResponseGetter().request(request, Review.class); } /** Retrieves a {@code Review} object. */ public static Review retrieve(String review, ReviewRetrieveParams params, RequestOptions options) throws StripeException { String path = String.format("/v1/reviews/%s", ApiResource.urlEncodeId(review)); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.GET, path, ApiRequestParams.paramsToMap(params), options); return getGlobalResponseGetter().request(request, Review.class); } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class IpAddressLocation extends StripeObject { /** The city where the payment originated. */ @SerializedName("city") String city; /** Two-letter ISO code representing the country where the payment originated. */ @SerializedName("country") String country; /** The geographic latitude where the payment originated. */ @SerializedName("latitude") BigDecimal latitude; /** The geographic longitude where the payment originated. */ @SerializedName("longitude") BigDecimal longitude; /** The state/county/province/region where the payment originated. */ @SerializedName("region") String region; } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Session extends StripeObject { /** The browser used in this browser session (e.g., {@code Chrome}). */ @SerializedName("browser") String browser; /** * Information about the device used for the browser session (e.g., {@code Samsung SM-G930T}). */ @SerializedName("device") String device; /** The platform for the browser session (e.g., {@code Macintosh}). */ @SerializedName("platform") String platform; /** The version for the browser session (e.g., {@code 61.0.3163.100}). */ @SerializedName("version") String version; } @Override public void setResponseGetter(StripeResponseGetter responseGetter) { super.setResponseGetter(responseGetter); trySetResponseGetter(charge, responseGetter); trySetResponseGetter(ipAddressLocation, responseGetter); trySetResponseGetter(paymentIntent, responseGetter); trySetResponseGetter(session, responseGetter); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy