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

com.stripe.param.issuing.AuthorizationCaptureParams Maven / Gradle / Ivy

// File generated from our OpenAPI spec
package com.stripe.param.issuing;

import com.google.gson.annotations.SerializedName;
import com.stripe.net.ApiRequestParams;
import java.math.BigDecimal;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import lombok.Getter;

@Getter
public class AuthorizationCaptureParams extends ApiRequestParams {
  /**
   * The amount to capture from the authorization. If not provided, the full amount of the
   * authorization will be captured. This amount is in the authorization currency and in the smallest currency unit.
   */
  @SerializedName("capture_amount")
  Long captureAmount;

  /**
   * Whether to close the authorization after capture. Defaults to true. Set to false to enable
   * multi-capture flows.
   */
  @SerializedName("close_authorization")
  Boolean closeAuthorization;

  /** Specifies which fields in the response should be expanded. */
  @SerializedName("expand")
  List expand;

  /**
   * Map of extra parameters for custom features not available in this client library. The content
   * in this map is not serialized under this field's {@code @SerializedName} value. Instead, each
   * key/value pair is serialized as if the key is a root-level field (serialized) name in this
   * param object. Effectively, this map is flattened to its parent instance.
   */
  @SerializedName(ApiRequestParams.EXTRA_PARAMS_KEY)
  Map extraParams;

  /** Additional purchase information that is optionally provided by the merchant. */
  @SerializedName("purchase_details")
  PurchaseDetails purchaseDetails;

  private AuthorizationCaptureParams(
      Long captureAmount,
      Boolean closeAuthorization,
      List expand,
      Map extraParams,
      PurchaseDetails purchaseDetails) {
    this.captureAmount = captureAmount;
    this.closeAuthorization = closeAuthorization;
    this.expand = expand;
    this.extraParams = extraParams;
    this.purchaseDetails = purchaseDetails;
  }

  public static Builder builder() {
    return new Builder();
  }

  public static class Builder {
    private Long captureAmount;

    private Boolean closeAuthorization;

    private List expand;

    private Map extraParams;

    private PurchaseDetails purchaseDetails;

    /** Finalize and obtain parameter instance from this builder. */
    public AuthorizationCaptureParams build() {
      return new AuthorizationCaptureParams(
          this.captureAmount,
          this.closeAuthorization,
          this.expand,
          this.extraParams,
          this.purchaseDetails);
    }

    /**
     * The amount to capture from the authorization. If not provided, the full amount of the
     * authorization will be captured. This amount is in the authorization currency and in the smallest currency unit.
     */
    public Builder setCaptureAmount(Long captureAmount) {
      this.captureAmount = captureAmount;
      return this;
    }

    /**
     * Whether to close the authorization after capture. Defaults to true. Set to false to enable
     * multi-capture flows.
     */
    public Builder setCloseAuthorization(Boolean closeAuthorization) {
      this.closeAuthorization = closeAuthorization;
      return this;
    }

    /**
     * Add an element to `expand` list. A list is initialized for the first `add/addAll` call, and
     * subsequent calls adds additional elements to the original list. See {@link
     * AuthorizationCaptureParams#expand} for the field documentation.
     */
    public Builder addExpand(String element) {
      if (this.expand == null) {
        this.expand = new ArrayList<>();
      }
      this.expand.add(element);
      return this;
    }

    /**
     * Add all elements to `expand` list. A list is initialized for the first `add/addAll` call, and
     * subsequent calls adds additional elements to the original list. See {@link
     * AuthorizationCaptureParams#expand} for the field documentation.
     */
    public Builder addAllExpand(List elements) {
      if (this.expand == null) {
        this.expand = new ArrayList<>();
      }
      this.expand.addAll(elements);
      return this;
    }

    /**
     * Add a key/value pair to `extraParams` map. A map is initialized for the first `put/putAll`
     * call, and subsequent calls add additional key/value pairs to the original map. See {@link
     * AuthorizationCaptureParams#extraParams} for the field documentation.
     */
    public Builder putExtraParam(String key, Object value) {
      if (this.extraParams == null) {
        this.extraParams = new HashMap<>();
      }
      this.extraParams.put(key, value);
      return this;
    }

    /**
     * Add all map key/value pairs to `extraParams` map. A map is initialized for the first
     * `put/putAll` call, and subsequent calls add additional key/value pairs to the original map.
     * See {@link AuthorizationCaptureParams#extraParams} for the field documentation.
     */
    public Builder putAllExtraParam(Map map) {
      if (this.extraParams == null) {
        this.extraParams = new HashMap<>();
      }
      this.extraParams.putAll(map);
      return this;
    }

    /** Additional purchase information that is optionally provided by the merchant. */
    public Builder setPurchaseDetails(AuthorizationCaptureParams.PurchaseDetails purchaseDetails) {
      this.purchaseDetails = purchaseDetails;
      return this;
    }
  }

  @Getter
  public static class PurchaseDetails {
    /**
     * Map of extra parameters for custom features not available in this client library. The content
     * in this map is not serialized under this field's {@code @SerializedName} value. Instead, each
     * key/value pair is serialized as if the key is a root-level field (serialized) name in this
     * param object. Effectively, this map is flattened to its parent instance.
     */
    @SerializedName(ApiRequestParams.EXTRA_PARAMS_KEY)
    Map extraParams;

    /** Fleet-specific information for transactions using Fleet cards. */
    @SerializedName("fleet")
    Fleet fleet;

    /** Information about the flight that was purchased with this transaction. */
    @SerializedName("flight")
    Flight flight;

    /** Information about fuel that was purchased with this transaction. */
    @SerializedName("fuel")
    Fuel fuel;

    /** Information about lodging that was purchased with this transaction. */
    @SerializedName("lodging")
    Lodging lodging;

    /** The line items in the purchase. */
    @SerializedName("receipt")
    List receipt;

    /** A merchant-specific order number. */
    @SerializedName("reference")
    String reference;

    private PurchaseDetails(
        Map extraParams,
        Fleet fleet,
        Flight flight,
        Fuel fuel,
        Lodging lodging,
        List receipt,
        String reference) {
      this.extraParams = extraParams;
      this.fleet = fleet;
      this.flight = flight;
      this.fuel = fuel;
      this.lodging = lodging;
      this.receipt = receipt;
      this.reference = reference;
    }

    public static Builder builder() {
      return new Builder();
    }

    public static class Builder {
      private Map extraParams;

      private Fleet fleet;

      private Flight flight;

      private Fuel fuel;

      private Lodging lodging;

      private List receipt;

      private String reference;

      /** Finalize and obtain parameter instance from this builder. */
      public AuthorizationCaptureParams.PurchaseDetails build() {
        return new AuthorizationCaptureParams.PurchaseDetails(
            this.extraParams,
            this.fleet,
            this.flight,
            this.fuel,
            this.lodging,
            this.receipt,
            this.reference);
      }

      /**
       * Add a key/value pair to `extraParams` map. A map is initialized for the first `put/putAll`
       * call, and subsequent calls add additional key/value pairs to the original map. See {@link
       * AuthorizationCaptureParams.PurchaseDetails#extraParams} for the field documentation.
       */
      public Builder putExtraParam(String key, Object value) {
        if (this.extraParams == null) {
          this.extraParams = new HashMap<>();
        }
        this.extraParams.put(key, value);
        return this;
      }

      /**
       * Add all map key/value pairs to `extraParams` map. A map is initialized for the first
       * `put/putAll` call, and subsequent calls add additional key/value pairs to the original map.
       * See {@link AuthorizationCaptureParams.PurchaseDetails#extraParams} for the field
       * documentation.
       */
      public Builder putAllExtraParam(Map map) {
        if (this.extraParams == null) {
          this.extraParams = new HashMap<>();
        }
        this.extraParams.putAll(map);
        return this;
      }

      /** Fleet-specific information for transactions using Fleet cards. */
      public Builder setFleet(AuthorizationCaptureParams.PurchaseDetails.Fleet fleet) {
        this.fleet = fleet;
        return this;
      }

      /** Information about the flight that was purchased with this transaction. */
      public Builder setFlight(AuthorizationCaptureParams.PurchaseDetails.Flight flight) {
        this.flight = flight;
        return this;
      }

      /** Information about fuel that was purchased with this transaction. */
      public Builder setFuel(AuthorizationCaptureParams.PurchaseDetails.Fuel fuel) {
        this.fuel = fuel;
        return this;
      }

      /** Information about lodging that was purchased with this transaction. */
      public Builder setLodging(AuthorizationCaptureParams.PurchaseDetails.Lodging lodging) {
        this.lodging = lodging;
        return this;
      }

      /**
       * Add an element to `receipt` list. A list is initialized for the first `add/addAll` call,
       * and subsequent calls adds additional elements to the original list. See {@link
       * AuthorizationCaptureParams.PurchaseDetails#receipt} for the field documentation.
       */
      public Builder addReceipt(AuthorizationCaptureParams.PurchaseDetails.Receipt element) {
        if (this.receipt == null) {
          this.receipt = new ArrayList<>();
        }
        this.receipt.add(element);
        return this;
      }

      /**
       * Add all elements to `receipt` list. A list is initialized for the first `add/addAll` call,
       * and subsequent calls adds additional elements to the original list. See {@link
       * AuthorizationCaptureParams.PurchaseDetails#receipt} for the field documentation.
       */
      public Builder addAllReceipt(
          List elements) {
        if (this.receipt == null) {
          this.receipt = new ArrayList<>();
        }
        this.receipt.addAll(elements);
        return this;
      }

      /** A merchant-specific order number. */
      public Builder setReference(String reference) {
        this.reference = reference;
        return this;
      }
    }

    @Getter
    public static class Fleet {
      /**
       * Answers to prompts presented to the cardholder at the point of sale. Prompted fields vary
       * depending on the configuration of your physical fleet cards. Typical points of sale support
       * only numeric entry.
       */
      @SerializedName("cardholder_prompt_data")
      CardholderPromptData cardholderPromptData;

      /**
       * Map of extra parameters for custom features not available in this client library. The
       * content in this map is not serialized under this field's {@code @SerializedName} value.
       * Instead, each key/value pair is serialized as if the key is a root-level field (serialized)
       * name in this param object. Effectively, this map is flattened to its parent instance.
       */
      @SerializedName(ApiRequestParams.EXTRA_PARAMS_KEY)
      Map extraParams;

      /**
       * The type of purchase. One of {@code fuel_purchase}, {@code non_fuel_purchase}, or {@code
       * fuel_and_non_fuel_purchase}.
       */
      @SerializedName("purchase_type")
      PurchaseType purchaseType;

      /**
       * More information about the total amount. This information is not guaranteed to be accurate
       * as some merchants may provide unreliable data.
       */
      @SerializedName("reported_breakdown")
      ReportedBreakdown reportedBreakdown;

      /**
       * The type of fuel service. One of {@code non_fuel_transaction}, {@code full_service}, or
       * {@code self_service}.
       */
      @SerializedName("service_type")
      ServiceType serviceType;

      private Fleet(
          CardholderPromptData cardholderPromptData,
          Map extraParams,
          PurchaseType purchaseType,
          ReportedBreakdown reportedBreakdown,
          ServiceType serviceType) {
        this.cardholderPromptData = cardholderPromptData;
        this.extraParams = extraParams;
        this.purchaseType = purchaseType;
        this.reportedBreakdown = reportedBreakdown;
        this.serviceType = serviceType;
      }

      public static Builder builder() {
        return new Builder();
      }

      public static class Builder {
        private CardholderPromptData cardholderPromptData;

        private Map extraParams;

        private PurchaseType purchaseType;

        private ReportedBreakdown reportedBreakdown;

        private ServiceType serviceType;

        /** Finalize and obtain parameter instance from this builder. */
        public AuthorizationCaptureParams.PurchaseDetails.Fleet build() {
          return new AuthorizationCaptureParams.PurchaseDetails.Fleet(
              this.cardholderPromptData,
              this.extraParams,
              this.purchaseType,
              this.reportedBreakdown,
              this.serviceType);
        }

        /**
         * Answers to prompts presented to the cardholder at the point of sale. Prompted fields vary
         * depending on the configuration of your physical fleet cards. Typical points of sale
         * support only numeric entry.
         */
        public Builder setCardholderPromptData(
            AuthorizationCaptureParams.PurchaseDetails.Fleet.CardholderPromptData
                cardholderPromptData) {
          this.cardholderPromptData = cardholderPromptData;
          return this;
        }

        /**
         * Add a key/value pair to `extraParams` map. A map is initialized for the first
         * `put/putAll` call, and subsequent calls add additional key/value pairs to the original
         * map. See {@link AuthorizationCaptureParams.PurchaseDetails.Fleet#extraParams} for the
         * field documentation.
         */
        public Builder putExtraParam(String key, Object value) {
          if (this.extraParams == null) {
            this.extraParams = new HashMap<>();
          }
          this.extraParams.put(key, value);
          return this;
        }

        /**
         * Add all map key/value pairs to `extraParams` map. A map is initialized for the first
         * `put/putAll` call, and subsequent calls add additional key/value pairs to the original
         * map. See {@link AuthorizationCaptureParams.PurchaseDetails.Fleet#extraParams} for the
         * field documentation.
         */
        public Builder putAllExtraParam(Map map) {
          if (this.extraParams == null) {
            this.extraParams = new HashMap<>();
          }
          this.extraParams.putAll(map);
          return this;
        }

        /**
         * The type of purchase. One of {@code fuel_purchase}, {@code non_fuel_purchase}, or {@code
         * fuel_and_non_fuel_purchase}.
         */
        public Builder setPurchaseType(
            AuthorizationCaptureParams.PurchaseDetails.Fleet.PurchaseType purchaseType) {
          this.purchaseType = purchaseType;
          return this;
        }

        /**
         * More information about the total amount. This information is not guaranteed to be
         * accurate as some merchants may provide unreliable data.
         */
        public Builder setReportedBreakdown(
            AuthorizationCaptureParams.PurchaseDetails.Fleet.ReportedBreakdown reportedBreakdown) {
          this.reportedBreakdown = reportedBreakdown;
          return this;
        }

        /**
         * The type of fuel service. One of {@code non_fuel_transaction}, {@code full_service}, or
         * {@code self_service}.
         */
        public Builder setServiceType(
            AuthorizationCaptureParams.PurchaseDetails.Fleet.ServiceType serviceType) {
          this.serviceType = serviceType;
          return this;
        }
      }

      @Getter
      public static class CardholderPromptData {
        /** Driver ID. */
        @SerializedName("driver_id")
        String driverId;

        /**
         * Map of extra parameters for custom features not available in this client library. The
         * content in this map is not serialized under this field's {@code @SerializedName} value.
         * Instead, each key/value pair is serialized as if the key is a root-level field
         * (serialized) name in this param object. Effectively, this map is flattened to its parent
         * instance.
         */
        @SerializedName(ApiRequestParams.EXTRA_PARAMS_KEY)
        Map extraParams;

        /** Odometer reading. */
        @SerializedName("odometer")
        Long odometer;

        /**
         * An alphanumeric ID. This field is used when a vehicle ID, driver ID, or generic ID is
         * entered by the cardholder, but the merchant or card network did not specify the prompt
         * type.
         */
        @SerializedName("unspecified_id")
        String unspecifiedId;

        /** User ID. */
        @SerializedName("user_id")
        String userId;

        /** Vehicle number. */
        @SerializedName("vehicle_number")
        String vehicleNumber;

        private CardholderPromptData(
            String driverId,
            Map extraParams,
            Long odometer,
            String unspecifiedId,
            String userId,
            String vehicleNumber) {
          this.driverId = driverId;
          this.extraParams = extraParams;
          this.odometer = odometer;
          this.unspecifiedId = unspecifiedId;
          this.userId = userId;
          this.vehicleNumber = vehicleNumber;
        }

        public static Builder builder() {
          return new Builder();
        }

        public static class Builder {
          private String driverId;

          private Map extraParams;

          private Long odometer;

          private String unspecifiedId;

          private String userId;

          private String vehicleNumber;

          /** Finalize and obtain parameter instance from this builder. */
          public AuthorizationCaptureParams.PurchaseDetails.Fleet.CardholderPromptData build() {
            return new AuthorizationCaptureParams.PurchaseDetails.Fleet.CardholderPromptData(
                this.driverId,
                this.extraParams,
                this.odometer,
                this.unspecifiedId,
                this.userId,
                this.vehicleNumber);
          }

          /** Driver ID. */
          public Builder setDriverId(String driverId) {
            this.driverId = driverId;
            return this;
          }

          /**
           * Add a key/value pair to `extraParams` map. A map is initialized for the first
           * `put/putAll` call, and subsequent calls add additional key/value pairs to the original
           * map. See {@link
           * AuthorizationCaptureParams.PurchaseDetails.Fleet.CardholderPromptData#extraParams} for
           * the field documentation.
           */
          public Builder putExtraParam(String key, Object value) {
            if (this.extraParams == null) {
              this.extraParams = new HashMap<>();
            }
            this.extraParams.put(key, value);
            return this;
          }

          /**
           * Add all map key/value pairs to `extraParams` map. A map is initialized for the first
           * `put/putAll` call, and subsequent calls add additional key/value pairs to the original
           * map. See {@link
           * AuthorizationCaptureParams.PurchaseDetails.Fleet.CardholderPromptData#extraParams} for
           * the field documentation.
           */
          public Builder putAllExtraParam(Map map) {
            if (this.extraParams == null) {
              this.extraParams = new HashMap<>();
            }
            this.extraParams.putAll(map);
            return this;
          }

          /** Odometer reading. */
          public Builder setOdometer(Long odometer) {
            this.odometer = odometer;
            return this;
          }

          /**
           * An alphanumeric ID. This field is used when a vehicle ID, driver ID, or generic ID is
           * entered by the cardholder, but the merchant or card network did not specify the prompt
           * type.
           */
          public Builder setUnspecifiedId(String unspecifiedId) {
            this.unspecifiedId = unspecifiedId;
            return this;
          }

          /** User ID. */
          public Builder setUserId(String userId) {
            this.userId = userId;
            return this;
          }

          /** Vehicle number. */
          public Builder setVehicleNumber(String vehicleNumber) {
            this.vehicleNumber = vehicleNumber;
            return this;
          }
        }
      }

      @Getter
      public static class ReportedBreakdown {
        /**
         * Map of extra parameters for custom features not available in this client library. The
         * content in this map is not serialized under this field's {@code @SerializedName} value.
         * Instead, each key/value pair is serialized as if the key is a root-level field
         * (serialized) name in this param object. Effectively, this map is flattened to its parent
         * instance.
         */
        @SerializedName(ApiRequestParams.EXTRA_PARAMS_KEY)
        Map extraParams;

        /** Breakdown of fuel portion of the purchase. */
        @SerializedName("fuel")
        Fuel fuel;

        /** Breakdown of non-fuel portion of the purchase. */
        @SerializedName("non_fuel")
        NonFuel nonFuel;

        /** Information about tax included in this transaction. */
        @SerializedName("tax")
        Tax tax;

        private ReportedBreakdown(
            Map extraParams, Fuel fuel, NonFuel nonFuel, Tax tax) {
          this.extraParams = extraParams;
          this.fuel = fuel;
          this.nonFuel = nonFuel;
          this.tax = tax;
        }

        public static Builder builder() {
          return new Builder();
        }

        public static class Builder {
          private Map extraParams;

          private Fuel fuel;

          private NonFuel nonFuel;

          private Tax tax;

          /** Finalize and obtain parameter instance from this builder. */
          public AuthorizationCaptureParams.PurchaseDetails.Fleet.ReportedBreakdown build() {
            return new AuthorizationCaptureParams.PurchaseDetails.Fleet.ReportedBreakdown(
                this.extraParams, this.fuel, this.nonFuel, this.tax);
          }

          /**
           * Add a key/value pair to `extraParams` map. A map is initialized for the first
           * `put/putAll` call, and subsequent calls add additional key/value pairs to the original
           * map. See {@link
           * AuthorizationCaptureParams.PurchaseDetails.Fleet.ReportedBreakdown#extraParams} for the
           * field documentation.
           */
          public Builder putExtraParam(String key, Object value) {
            if (this.extraParams == null) {
              this.extraParams = new HashMap<>();
            }
            this.extraParams.put(key, value);
            return this;
          }

          /**
           * Add all map key/value pairs to `extraParams` map. A map is initialized for the first
           * `put/putAll` call, and subsequent calls add additional key/value pairs to the original
           * map. See {@link
           * AuthorizationCaptureParams.PurchaseDetails.Fleet.ReportedBreakdown#extraParams} for the
           * field documentation.
           */
          public Builder putAllExtraParam(Map map) {
            if (this.extraParams == null) {
              this.extraParams = new HashMap<>();
            }
            this.extraParams.putAll(map);
            return this;
          }

          /** Breakdown of fuel portion of the purchase. */
          public Builder setFuel(
              AuthorizationCaptureParams.PurchaseDetails.Fleet.ReportedBreakdown.Fuel fuel) {
            this.fuel = fuel;
            return this;
          }

          /** Breakdown of non-fuel portion of the purchase. */
          public Builder setNonFuel(
              AuthorizationCaptureParams.PurchaseDetails.Fleet.ReportedBreakdown.NonFuel nonFuel) {
            this.nonFuel = nonFuel;
            return this;
          }

          /** Information about tax included in this transaction. */
          public Builder setTax(
              AuthorizationCaptureParams.PurchaseDetails.Fleet.ReportedBreakdown.Tax tax) {
            this.tax = tax;
            return this;
          }
        }

        @Getter
        public static class Fuel {
          /**
           * Map of extra parameters for custom features not available in this client library. The
           * content in this map is not serialized under this field's {@code @SerializedName} value.
           * Instead, each key/value pair is serialized as if the key is a root-level field
           * (serialized) name in this param object. Effectively, this map is flattened to its
           * parent instance.
           */
          @SerializedName(ApiRequestParams.EXTRA_PARAMS_KEY)
          Map extraParams;

          /**
           * Gross fuel amount that should equal Fuel Volume multipled by Fuel Unit Cost, inclusive
           * of taxes.
           */
          @SerializedName("gross_amount_decimal")
          BigDecimal grossAmountDecimal;

          private Fuel(Map extraParams, BigDecimal grossAmountDecimal) {
            this.extraParams = extraParams;
            this.grossAmountDecimal = grossAmountDecimal;
          }

          public static Builder builder() {
            return new Builder();
          }

          public static class Builder {
            private Map extraParams;

            private BigDecimal grossAmountDecimal;

            /** Finalize and obtain parameter instance from this builder. */
            public AuthorizationCaptureParams.PurchaseDetails.Fleet.ReportedBreakdown.Fuel build() {
              return new AuthorizationCaptureParams.PurchaseDetails.Fleet.ReportedBreakdown.Fuel(
                  this.extraParams, this.grossAmountDecimal);
            }

            /**
             * Add a key/value pair to `extraParams` map. A map is initialized for the first
             * `put/putAll` call, and subsequent calls add additional key/value pairs to the
             * original map. See {@link
             * AuthorizationCaptureParams.PurchaseDetails.Fleet.ReportedBreakdown.Fuel#extraParams}
             * for the field documentation.
             */
            public Builder putExtraParam(String key, Object value) {
              if (this.extraParams == null) {
                this.extraParams = new HashMap<>();
              }
              this.extraParams.put(key, value);
              return this;
            }

            /**
             * Add all map key/value pairs to `extraParams` map. A map is initialized for the first
             * `put/putAll` call, and subsequent calls add additional key/value pairs to the
             * original map. See {@link
             * AuthorizationCaptureParams.PurchaseDetails.Fleet.ReportedBreakdown.Fuel#extraParams}
             * for the field documentation.
             */
            public Builder putAllExtraParam(Map map) {
              if (this.extraParams == null) {
                this.extraParams = new HashMap<>();
              }
              this.extraParams.putAll(map);
              return this;
            }

            /**
             * Gross fuel amount that should equal Fuel Volume multipled by Fuel Unit Cost,
             * inclusive of taxes.
             */
            public Builder setGrossAmountDecimal(BigDecimal grossAmountDecimal) {
              this.grossAmountDecimal = grossAmountDecimal;
              return this;
            }
          }
        }

        @Getter
        public static class NonFuel {
          /**
           * Map of extra parameters for custom features not available in this client library. The
           * content in this map is not serialized under this field's {@code @SerializedName} value.
           * Instead, each key/value pair is serialized as if the key is a root-level field
           * (serialized) name in this param object. Effectively, this map is flattened to its
           * parent instance.
           */
          @SerializedName(ApiRequestParams.EXTRA_PARAMS_KEY)
          Map extraParams;

          /**
           * Gross non-fuel amount that should equal the sum of the line items, inclusive of taxes.
           */
          @SerializedName("gross_amount_decimal")
          BigDecimal grossAmountDecimal;

          private NonFuel(Map extraParams, BigDecimal grossAmountDecimal) {
            this.extraParams = extraParams;
            this.grossAmountDecimal = grossAmountDecimal;
          }

          public static Builder builder() {
            return new Builder();
          }

          public static class Builder {
            private Map extraParams;

            private BigDecimal grossAmountDecimal;

            /** Finalize and obtain parameter instance from this builder. */
            public AuthorizationCaptureParams.PurchaseDetails.Fleet.ReportedBreakdown.NonFuel
                build() {
              return new AuthorizationCaptureParams.PurchaseDetails.Fleet.ReportedBreakdown.NonFuel(
                  this.extraParams, this.grossAmountDecimal);
            }

            /**
             * Add a key/value pair to `extraParams` map. A map is initialized for the first
             * `put/putAll` call, and subsequent calls add additional key/value pairs to the
             * original map. See {@link
             * AuthorizationCaptureParams.PurchaseDetails.Fleet.ReportedBreakdown.NonFuel#extraParams}
             * for the field documentation.
             */
            public Builder putExtraParam(String key, Object value) {
              if (this.extraParams == null) {
                this.extraParams = new HashMap<>();
              }
              this.extraParams.put(key, value);
              return this;
            }

            /**
             * Add all map key/value pairs to `extraParams` map. A map is initialized for the first
             * `put/putAll` call, and subsequent calls add additional key/value pairs to the
             * original map. See {@link
             * AuthorizationCaptureParams.PurchaseDetails.Fleet.ReportedBreakdown.NonFuel#extraParams}
             * for the field documentation.
             */
            public Builder putAllExtraParam(Map map) {
              if (this.extraParams == null) {
                this.extraParams = new HashMap<>();
              }
              this.extraParams.putAll(map);
              return this;
            }

            /**
             * Gross non-fuel amount that should equal the sum of the line items, inclusive of
             * taxes.
             */
            public Builder setGrossAmountDecimal(BigDecimal grossAmountDecimal) {
              this.grossAmountDecimal = grossAmountDecimal;
              return this;
            }
          }
        }

        @Getter
        public static class Tax {
          /**
           * Map of extra parameters for custom features not available in this client library. The
           * content in this map is not serialized under this field's {@code @SerializedName} value.
           * Instead, each key/value pair is serialized as if the key is a root-level field
           * (serialized) name in this param object. Effectively, this map is flattened to its
           * parent instance.
           */
          @SerializedName(ApiRequestParams.EXTRA_PARAMS_KEY)
          Map extraParams;

          /**
           * Amount of state or provincial Sales Tax included in the transaction amount. Null if not
           * reported by merchant or not subject to tax.
           */
          @SerializedName("local_amount_decimal")
          BigDecimal localAmountDecimal;

          /**
           * Amount of national Sales Tax or VAT included in the transaction amount. Null if not
           * reported by merchant or not subject to tax.
           */
          @SerializedName("national_amount_decimal")
          BigDecimal nationalAmountDecimal;

          private Tax(
              Map extraParams,
              BigDecimal localAmountDecimal,
              BigDecimal nationalAmountDecimal) {
            this.extraParams = extraParams;
            this.localAmountDecimal = localAmountDecimal;
            this.nationalAmountDecimal = nationalAmountDecimal;
          }

          public static Builder builder() {
            return new Builder();
          }

          public static class Builder {
            private Map extraParams;

            private BigDecimal localAmountDecimal;

            private BigDecimal nationalAmountDecimal;

            /** Finalize and obtain parameter instance from this builder. */
            public AuthorizationCaptureParams.PurchaseDetails.Fleet.ReportedBreakdown.Tax build() {
              return new AuthorizationCaptureParams.PurchaseDetails.Fleet.ReportedBreakdown.Tax(
                  this.extraParams, this.localAmountDecimal, this.nationalAmountDecimal);
            }

            /**
             * Add a key/value pair to `extraParams` map. A map is initialized for the first
             * `put/putAll` call, and subsequent calls add additional key/value pairs to the
             * original map. See {@link
             * AuthorizationCaptureParams.PurchaseDetails.Fleet.ReportedBreakdown.Tax#extraParams}
             * for the field documentation.
             */
            public Builder putExtraParam(String key, Object value) {
              if (this.extraParams == null) {
                this.extraParams = new HashMap<>();
              }
              this.extraParams.put(key, value);
              return this;
            }

            /**
             * Add all map key/value pairs to `extraParams` map. A map is initialized for the first
             * `put/putAll` call, and subsequent calls add additional key/value pairs to the
             * original map. See {@link
             * AuthorizationCaptureParams.PurchaseDetails.Fleet.ReportedBreakdown.Tax#extraParams}
             * for the field documentation.
             */
            public Builder putAllExtraParam(Map map) {
              if (this.extraParams == null) {
                this.extraParams = new HashMap<>();
              }
              this.extraParams.putAll(map);
              return this;
            }

            /**
             * Amount of state or provincial Sales Tax included in the transaction amount. Null if
             * not reported by merchant or not subject to tax.
             */
            public Builder setLocalAmountDecimal(BigDecimal localAmountDecimal) {
              this.localAmountDecimal = localAmountDecimal;
              return this;
            }

            /**
             * Amount of national Sales Tax or VAT included in the transaction amount. Null if not
             * reported by merchant or not subject to tax.
             */
            public Builder setNationalAmountDecimal(BigDecimal nationalAmountDecimal) {
              this.nationalAmountDecimal = nationalAmountDecimal;
              return this;
            }
          }
        }
      }

      public enum PurchaseType implements ApiRequestParams.EnumParam {
        @SerializedName("fuel_and_non_fuel_purchase")
        FUEL_AND_NON_FUEL_PURCHASE("fuel_and_non_fuel_purchase"),

        @SerializedName("fuel_purchase")
        FUEL_PURCHASE("fuel_purchase"),

        @SerializedName("non_fuel_purchase")
        NON_FUEL_PURCHASE("non_fuel_purchase");

        @Getter(onMethod_ = {@Override})
        private final String value;

        PurchaseType(String value) {
          this.value = value;
        }
      }

      public enum ServiceType implements ApiRequestParams.EnumParam {
        @SerializedName("full_service")
        FULL_SERVICE("full_service"),

        @SerializedName("non_fuel_transaction")
        NON_FUEL_TRANSACTION("non_fuel_transaction"),

        @SerializedName("self_service")
        SELF_SERVICE("self_service");

        @Getter(onMethod_ = {@Override})
        private final String value;

        ServiceType(String value) {
          this.value = value;
        }
      }
    }

    @Getter
    public static class Flight {
      /** The time that the flight departed. */
      @SerializedName("departure_at")
      Long departureAt;

      /**
       * Map of extra parameters for custom features not available in this client library. The
       * content in this map is not serialized under this field's {@code @SerializedName} value.
       * Instead, each key/value pair is serialized as if the key is a root-level field (serialized)
       * name in this param object. Effectively, this map is flattened to its parent instance.
       */
      @SerializedName(ApiRequestParams.EXTRA_PARAMS_KEY)
      Map extraParams;

      /** The name of the passenger. */
      @SerializedName("passenger_name")
      String passengerName;

      /** Whether the ticket is refundable. */
      @SerializedName("refundable")
      Boolean refundable;

      /** The legs of the trip. */
      @SerializedName("segments")
      List segments;

      /** The travel agency that issued the ticket. */
      @SerializedName("travel_agency")
      String travelAgency;

      private Flight(
          Long departureAt,
          Map extraParams,
          String passengerName,
          Boolean refundable,
          List segments,
          String travelAgency) {
        this.departureAt = departureAt;
        this.extraParams = extraParams;
        this.passengerName = passengerName;
        this.refundable = refundable;
        this.segments = segments;
        this.travelAgency = travelAgency;
      }

      public static Builder builder() {
        return new Builder();
      }

      public static class Builder {
        private Long departureAt;

        private Map extraParams;

        private String passengerName;

        private Boolean refundable;

        private List segments;

        private String travelAgency;

        /** Finalize and obtain parameter instance from this builder. */
        public AuthorizationCaptureParams.PurchaseDetails.Flight build() {
          return new AuthorizationCaptureParams.PurchaseDetails.Flight(
              this.departureAt,
              this.extraParams,
              this.passengerName,
              this.refundable,
              this.segments,
              this.travelAgency);
        }

        /** The time that the flight departed. */
        public Builder setDepartureAt(Long departureAt) {
          this.departureAt = departureAt;
          return this;
        }

        /**
         * Add a key/value pair to `extraParams` map. A map is initialized for the first
         * `put/putAll` call, and subsequent calls add additional key/value pairs to the original
         * map. See {@link AuthorizationCaptureParams.PurchaseDetails.Flight#extraParams} for the
         * field documentation.
         */
        public Builder putExtraParam(String key, Object value) {
          if (this.extraParams == null) {
            this.extraParams = new HashMap<>();
          }
          this.extraParams.put(key, value);
          return this;
        }

        /**
         * Add all map key/value pairs to `extraParams` map. A map is initialized for the first
         * `put/putAll` call, and subsequent calls add additional key/value pairs to the original
         * map. See {@link AuthorizationCaptureParams.PurchaseDetails.Flight#extraParams} for the
         * field documentation.
         */
        public Builder putAllExtraParam(Map map) {
          if (this.extraParams == null) {
            this.extraParams = new HashMap<>();
          }
          this.extraParams.putAll(map);
          return this;
        }

        /** The name of the passenger. */
        public Builder setPassengerName(String passengerName) {
          this.passengerName = passengerName;
          return this;
        }

        /** Whether the ticket is refundable. */
        public Builder setRefundable(Boolean refundable) {
          this.refundable = refundable;
          return this;
        }

        /**
         * Add an element to `segments` list. A list is initialized for the first `add/addAll` call,
         * and subsequent calls adds additional elements to the original list. See {@link
         * AuthorizationCaptureParams.PurchaseDetails.Flight#segments} for the field documentation.
         */
        public Builder addSegment(
            AuthorizationCaptureParams.PurchaseDetails.Flight.Segment element) {
          if (this.segments == null) {
            this.segments = new ArrayList<>();
          }
          this.segments.add(element);
          return this;
        }

        /**
         * Add all elements to `segments` list. A list is initialized for the first `add/addAll`
         * call, and subsequent calls adds additional elements to the original list. See {@link
         * AuthorizationCaptureParams.PurchaseDetails.Flight#segments} for the field documentation.
         */
        public Builder addAllSegment(
            List elements) {
          if (this.segments == null) {
            this.segments = new ArrayList<>();
          }
          this.segments.addAll(elements);
          return this;
        }

        /** The travel agency that issued the ticket. */
        public Builder setTravelAgency(String travelAgency) {
          this.travelAgency = travelAgency;
          return this;
        }
      }

      @Getter
      public static class Segment {
        /** The three-letter IATA airport code of the flight's destination. */
        @SerializedName("arrival_airport_code")
        String arrivalAirportCode;

        /** The airline carrier code. */
        @SerializedName("carrier")
        String carrier;

        /** The three-letter IATA airport code that the flight departed from. */
        @SerializedName("departure_airport_code")
        String departureAirportCode;

        /**
         * Map of extra parameters for custom features not available in this client library. The
         * content in this map is not serialized under this field's {@code @SerializedName} value.
         * Instead, each key/value pair is serialized as if the key is a root-level field
         * (serialized) name in this param object. Effectively, this map is flattened to its parent
         * instance.
         */
        @SerializedName(ApiRequestParams.EXTRA_PARAMS_KEY)
        Map extraParams;

        /** The flight number. */
        @SerializedName("flight_number")
        String flightNumber;

        /** The flight's service class. */
        @SerializedName("service_class")
        String serviceClass;

        /** Whether a stopover is allowed on this flight. */
        @SerializedName("stopover_allowed")
        Boolean stopoverAllowed;

        private Segment(
            String arrivalAirportCode,
            String carrier,
            String departureAirportCode,
            Map extraParams,
            String flightNumber,
            String serviceClass,
            Boolean stopoverAllowed) {
          this.arrivalAirportCode = arrivalAirportCode;
          this.carrier = carrier;
          this.departureAirportCode = departureAirportCode;
          this.extraParams = extraParams;
          this.flightNumber = flightNumber;
          this.serviceClass = serviceClass;
          this.stopoverAllowed = stopoverAllowed;
        }

        public static Builder builder() {
          return new Builder();
        }

        public static class Builder {
          private String arrivalAirportCode;

          private String carrier;

          private String departureAirportCode;

          private Map extraParams;

          private String flightNumber;

          private String serviceClass;

          private Boolean stopoverAllowed;

          /** Finalize and obtain parameter instance from this builder. */
          public AuthorizationCaptureParams.PurchaseDetails.Flight.Segment build() {
            return new AuthorizationCaptureParams.PurchaseDetails.Flight.Segment(
                this.arrivalAirportCode,
                this.carrier,
                this.departureAirportCode,
                this.extraParams,
                this.flightNumber,
                this.serviceClass,
                this.stopoverAllowed);
          }

          /** The three-letter IATA airport code of the flight's destination. */
          public Builder setArrivalAirportCode(String arrivalAirportCode) {
            this.arrivalAirportCode = arrivalAirportCode;
            return this;
          }

          /** The airline carrier code. */
          public Builder setCarrier(String carrier) {
            this.carrier = carrier;
            return this;
          }

          /** The three-letter IATA airport code that the flight departed from. */
          public Builder setDepartureAirportCode(String departureAirportCode) {
            this.departureAirportCode = departureAirportCode;
            return this;
          }

          /**
           * Add a key/value pair to `extraParams` map. A map is initialized for the first
           * `put/putAll` call, and subsequent calls add additional key/value pairs to the original
           * map. See {@link AuthorizationCaptureParams.PurchaseDetails.Flight.Segment#extraParams}
           * for the field documentation.
           */
          public Builder putExtraParam(String key, Object value) {
            if (this.extraParams == null) {
              this.extraParams = new HashMap<>();
            }
            this.extraParams.put(key, value);
            return this;
          }

          /**
           * Add all map key/value pairs to `extraParams` map. A map is initialized for the first
           * `put/putAll` call, and subsequent calls add additional key/value pairs to the original
           * map. See {@link AuthorizationCaptureParams.PurchaseDetails.Flight.Segment#extraParams}
           * for the field documentation.
           */
          public Builder putAllExtraParam(Map map) {
            if (this.extraParams == null) {
              this.extraParams = new HashMap<>();
            }
            this.extraParams.putAll(map);
            return this;
          }

          /** The flight number. */
          public Builder setFlightNumber(String flightNumber) {
            this.flightNumber = flightNumber;
            return this;
          }

          /** The flight's service class. */
          public Builder setServiceClass(String serviceClass) {
            this.serviceClass = serviceClass;
            return this;
          }

          /** Whether a stopover is allowed on this flight. */
          public Builder setStopoverAllowed(Boolean stopoverAllowed) {
            this.stopoverAllowed = stopoverAllowed;
            return this;
          }
        }
      }
    }

    @Getter
    public static class Fuel {
      /**
       * Map of extra parameters for custom features not available in this client library. The
       * content in this map is not serialized under this field's {@code @SerializedName} value.
       * Instead, each key/value pair is serialized as if the key is a root-level field (serialized)
       * name in this param object. Effectively, this map is flattened to its parent instance.
       */
      @SerializedName(ApiRequestParams.EXTRA_PARAMS_KEY)
      Map extraParams;

      /**
       * Conexxus Payment
       * System Product Code identifying the primary fuel product purchased.
       */
      @SerializedName("industry_product_code")
      String industryProductCode;

      /**
       * The quantity of {@code unit}s of fuel that was dispensed, represented as a decimal string
       * with at most 12 decimal places.
       */
      @SerializedName("quantity_decimal")
      BigDecimal quantityDecimal;

      /**
       * The type of fuel that was purchased. One of {@code diesel}, {@code unleaded_plus}, {@code
       * unleaded_regular}, {@code unleaded_super}, or {@code other}.
       */
      @SerializedName("type")
      Type type;

      /**
       * The units for {@code quantity_decimal}. One of {@code charging_minute}, {@code
       * imperial_gallon}, {@code kilogram}, {@code kilowatt_hour}, {@code liter}, {@code pound},
       * {@code us_gallon}, or {@code other}.
       */
      @SerializedName("unit")
      Unit unit;

      /**
       * The cost in cents per each unit of fuel, represented as a decimal string with at most 12
       * decimal places.
       */
      @SerializedName("unit_cost_decimal")
      BigDecimal unitCostDecimal;

      private Fuel(
          Map extraParams,
          String industryProductCode,
          BigDecimal quantityDecimal,
          Type type,
          Unit unit,
          BigDecimal unitCostDecimal) {
        this.extraParams = extraParams;
        this.industryProductCode = industryProductCode;
        this.quantityDecimal = quantityDecimal;
        this.type = type;
        this.unit = unit;
        this.unitCostDecimal = unitCostDecimal;
      }

      public static Builder builder() {
        return new Builder();
      }

      public static class Builder {
        private Map extraParams;

        private String industryProductCode;

        private BigDecimal quantityDecimal;

        private Type type;

        private Unit unit;

        private BigDecimal unitCostDecimal;

        /** Finalize and obtain parameter instance from this builder. */
        public AuthorizationCaptureParams.PurchaseDetails.Fuel build() {
          return new AuthorizationCaptureParams.PurchaseDetails.Fuel(
              this.extraParams,
              this.industryProductCode,
              this.quantityDecimal,
              this.type,
              this.unit,
              this.unitCostDecimal);
        }

        /**
         * Add a key/value pair to `extraParams` map. A map is initialized for the first
         * `put/putAll` call, and subsequent calls add additional key/value pairs to the original
         * map. See {@link AuthorizationCaptureParams.PurchaseDetails.Fuel#extraParams} for the
         * field documentation.
         */
        public Builder putExtraParam(String key, Object value) {
          if (this.extraParams == null) {
            this.extraParams = new HashMap<>();
          }
          this.extraParams.put(key, value);
          return this;
        }

        /**
         * Add all map key/value pairs to `extraParams` map. A map is initialized for the first
         * `put/putAll` call, and subsequent calls add additional key/value pairs to the original
         * map. See {@link AuthorizationCaptureParams.PurchaseDetails.Fuel#extraParams} for the
         * field documentation.
         */
        public Builder putAllExtraParam(Map map) {
          if (this.extraParams == null) {
            this.extraParams = new HashMap<>();
          }
          this.extraParams.putAll(map);
          return this;
        }

        /**
         * Conexxus Payment
         * System Product Code identifying the primary fuel product purchased.
         */
        public Builder setIndustryProductCode(String industryProductCode) {
          this.industryProductCode = industryProductCode;
          return this;
        }

        /**
         * The quantity of {@code unit}s of fuel that was dispensed, represented as a decimal string
         * with at most 12 decimal places.
         */
        public Builder setQuantityDecimal(BigDecimal quantityDecimal) {
          this.quantityDecimal = quantityDecimal;
          return this;
        }

        /**
         * The type of fuel that was purchased. One of {@code diesel}, {@code unleaded_plus}, {@code
         * unleaded_regular}, {@code unleaded_super}, or {@code other}.
         */
        public Builder setType(AuthorizationCaptureParams.PurchaseDetails.Fuel.Type type) {
          this.type = type;
          return this;
        }

        /**
         * The units for {@code quantity_decimal}. One of {@code charging_minute}, {@code
         * imperial_gallon}, {@code kilogram}, {@code kilowatt_hour}, {@code liter}, {@code pound},
         * {@code us_gallon}, or {@code other}.
         */
        public Builder setUnit(AuthorizationCaptureParams.PurchaseDetails.Fuel.Unit unit) {
          this.unit = unit;
          return this;
        }

        /**
         * The cost in cents per each unit of fuel, represented as a decimal string with at most 12
         * decimal places.
         */
        public Builder setUnitCostDecimal(BigDecimal unitCostDecimal) {
          this.unitCostDecimal = unitCostDecimal;
          return this;
        }
      }

      public enum Type implements ApiRequestParams.EnumParam {
        @SerializedName("diesel")
        DIESEL("diesel"),

        @SerializedName("other")
        OTHER("other"),

        @SerializedName("unleaded_plus")
        UNLEADED_PLUS("unleaded_plus"),

        @SerializedName("unleaded_regular")
        UNLEADED_REGULAR("unleaded_regular"),

        @SerializedName("unleaded_super")
        UNLEADED_SUPER("unleaded_super");

        @Getter(onMethod_ = {@Override})
        private final String value;

        Type(String value) {
          this.value = value;
        }
      }

      public enum Unit implements ApiRequestParams.EnumParam {
        @SerializedName("charging_minute")
        CHARGING_MINUTE("charging_minute"),

        @SerializedName("imperial_gallon")
        IMPERIAL_GALLON("imperial_gallon"),

        @SerializedName("kilogram")
        KILOGRAM("kilogram"),

        @SerializedName("kilowatt_hour")
        KILOWATT_HOUR("kilowatt_hour"),

        @SerializedName("liter")
        LITER("liter"),

        @SerializedName("other")
        OTHER("other"),

        @SerializedName("pound")
        POUND("pound"),

        @SerializedName("us_gallon")
        US_GALLON("us_gallon");

        @Getter(onMethod_ = {@Override})
        private final String value;

        Unit(String value) {
          this.value = value;
        }
      }
    }

    @Getter
    public static class Lodging {
      /** The time of checking into the lodging. */
      @SerializedName("check_in_at")
      Long checkInAt;

      /**
       * Map of extra parameters for custom features not available in this client library. The
       * content in this map is not serialized under this field's {@code @SerializedName} value.
       * Instead, each key/value pair is serialized as if the key is a root-level field (serialized)
       * name in this param object. Effectively, this map is flattened to its parent instance.
       */
      @SerializedName(ApiRequestParams.EXTRA_PARAMS_KEY)
      Map extraParams;

      /** The number of nights stayed at the lodging. */
      @SerializedName("nights")
      Long nights;

      private Lodging(Long checkInAt, Map extraParams, Long nights) {
        this.checkInAt = checkInAt;
        this.extraParams = extraParams;
        this.nights = nights;
      }

      public static Builder builder() {
        return new Builder();
      }

      public static class Builder {
        private Long checkInAt;

        private Map extraParams;

        private Long nights;

        /** Finalize and obtain parameter instance from this builder. */
        public AuthorizationCaptureParams.PurchaseDetails.Lodging build() {
          return new AuthorizationCaptureParams.PurchaseDetails.Lodging(
              this.checkInAt, this.extraParams, this.nights);
        }

        /** The time of checking into the lodging. */
        public Builder setCheckInAt(Long checkInAt) {
          this.checkInAt = checkInAt;
          return this;
        }

        /**
         * Add a key/value pair to `extraParams` map. A map is initialized for the first
         * `put/putAll` call, and subsequent calls add additional key/value pairs to the original
         * map. See {@link AuthorizationCaptureParams.PurchaseDetails.Lodging#extraParams} for the
         * field documentation.
         */
        public Builder putExtraParam(String key, Object value) {
          if (this.extraParams == null) {
            this.extraParams = new HashMap<>();
          }
          this.extraParams.put(key, value);
          return this;
        }

        /**
         * Add all map key/value pairs to `extraParams` map. A map is initialized for the first
         * `put/putAll` call, and subsequent calls add additional key/value pairs to the original
         * map. See {@link AuthorizationCaptureParams.PurchaseDetails.Lodging#extraParams} for the
         * field documentation.
         */
        public Builder putAllExtraParam(Map map) {
          if (this.extraParams == null) {
            this.extraParams = new HashMap<>();
          }
          this.extraParams.putAll(map);
          return this;
        }

        /** The number of nights stayed at the lodging. */
        public Builder setNights(Long nights) {
          this.nights = nights;
          return this;
        }
      }
    }

    @Getter
    public static class Receipt {
      @SerializedName("description")
      String description;

      /**
       * Map of extra parameters for custom features not available in this client library. The
       * content in this map is not serialized under this field's {@code @SerializedName} value.
       * Instead, each key/value pair is serialized as if the key is a root-level field (serialized)
       * name in this param object. Effectively, this map is flattened to its parent instance.
       */
      @SerializedName(ApiRequestParams.EXTRA_PARAMS_KEY)
      Map extraParams;

      @SerializedName("quantity")
      BigDecimal quantity;

      @SerializedName("total")
      Long total;

      @SerializedName("unit_cost")
      Long unitCost;

      private Receipt(
          String description,
          Map extraParams,
          BigDecimal quantity,
          Long total,
          Long unitCost) {
        this.description = description;
        this.extraParams = extraParams;
        this.quantity = quantity;
        this.total = total;
        this.unitCost = unitCost;
      }

      public static Builder builder() {
        return new Builder();
      }

      public static class Builder {
        private String description;

        private Map extraParams;

        private BigDecimal quantity;

        private Long total;

        private Long unitCost;

        /** Finalize and obtain parameter instance from this builder. */
        public AuthorizationCaptureParams.PurchaseDetails.Receipt build() {
          return new AuthorizationCaptureParams.PurchaseDetails.Receipt(
              this.description, this.extraParams, this.quantity, this.total, this.unitCost);
        }

        public Builder setDescription(String description) {
          this.description = description;
          return this;
        }

        /**
         * Add a key/value pair to `extraParams` map. A map is initialized for the first
         * `put/putAll` call, and subsequent calls add additional key/value pairs to the original
         * map. See {@link AuthorizationCaptureParams.PurchaseDetails.Receipt#extraParams} for the
         * field documentation.
         */
        public Builder putExtraParam(String key, Object value) {
          if (this.extraParams == null) {
            this.extraParams = new HashMap<>();
          }
          this.extraParams.put(key, value);
          return this;
        }

        /**
         * Add all map key/value pairs to `extraParams` map. A map is initialized for the first
         * `put/putAll` call, and subsequent calls add additional key/value pairs to the original
         * map. See {@link AuthorizationCaptureParams.PurchaseDetails.Receipt#extraParams} for the
         * field documentation.
         */
        public Builder putAllExtraParam(Map map) {
          if (this.extraParams == null) {
            this.extraParams = new HashMap<>();
          }
          this.extraParams.putAll(map);
          return this;
        }

        public Builder setQuantity(BigDecimal quantity) {
          this.quantity = quantity;
          return this;
        }

        public Builder setTotal(Long total) {
          this.total = total;
          return this;
        }

        public Builder setUnitCost(Long unitCost) {
          this.unitCost = unitCost;
          return this;
        }
      }
    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy