com.plaid.client.model.AssetReportInvestments Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of plaid-java Show documentation
Show all versions of plaid-java Show documentation
Bindings for the Plaid (plaid.com) API.
/*
* The Plaid API
* The Plaid REST API. Please see https://plaid.com/docs/api for more details.
*
* The version of the OpenAPI document: 2020-09-14_1.503.5
*
*
* NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
* https://openapi-generator.tech
* Do not edit the class manually.
*/
package com.plaid.client.model;
import java.util.Objects;
import java.util.Arrays;
import com.google.gson.TypeAdapter;
import com.google.gson.annotations.JsonAdapter;
import com.google.gson.annotations.SerializedName;
import com.google.gson.stream.JsonReader;
import com.google.gson.stream.JsonWriter;
import com.plaid.client.model.InvestmentTransactionSubtype;
import com.plaid.client.model.InvestmentTransactionType;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import java.io.IOException;
import java.time.LocalDate;
/**
* A transaction within an investment account.
*/
@ApiModel(description = "A transaction within an investment account.")
@javax.annotation.Generated(value = "org.openapitools.codegen.languages.JavaClientCodegen", date = "2024-03-28T21:00:55.745394Z[Etc/UTC]")
public class AssetReportInvestments {
public static final String SERIALIZED_NAME_INVESTMENT_TRANSACTION_ID = "investment_transaction_id";
@SerializedName(SERIALIZED_NAME_INVESTMENT_TRANSACTION_ID)
private String investmentTransactionId;
public static final String SERIALIZED_NAME_ACCOUNT_ID = "account_id";
@SerializedName(SERIALIZED_NAME_ACCOUNT_ID)
private String accountId;
public static final String SERIALIZED_NAME_SECURITY_ID = "security_id";
@SerializedName(SERIALIZED_NAME_SECURITY_ID)
private String securityId;
public static final String SERIALIZED_NAME_DATE = "date";
@SerializedName(SERIALIZED_NAME_DATE)
private LocalDate date;
public static final String SERIALIZED_NAME_NAME = "name";
@SerializedName(SERIALIZED_NAME_NAME)
private String name;
public static final String SERIALIZED_NAME_QUANTITY = "quantity";
@SerializedName(SERIALIZED_NAME_QUANTITY)
private Double quantity;
public static final String SERIALIZED_NAME_VESTED_QUANTITY = "vested_quantity";
@SerializedName(SERIALIZED_NAME_VESTED_QUANTITY)
private Double vestedQuantity;
public static final String SERIALIZED_NAME_VESTED_VALUE = "vested_value";
@SerializedName(SERIALIZED_NAME_VESTED_VALUE)
private Double vestedValue;
public static final String SERIALIZED_NAME_AMOUNT = "amount";
@SerializedName(SERIALIZED_NAME_AMOUNT)
private Double amount;
public static final String SERIALIZED_NAME_PRICE = "price";
@SerializedName(SERIALIZED_NAME_PRICE)
private Double price;
public static final String SERIALIZED_NAME_FEES = "fees";
@SerializedName(SERIALIZED_NAME_FEES)
private Double fees;
public static final String SERIALIZED_NAME_TYPE = "type";
@SerializedName(SERIALIZED_NAME_TYPE)
private InvestmentTransactionType type;
public static final String SERIALIZED_NAME_SUBTYPE = "subtype";
@SerializedName(SERIALIZED_NAME_SUBTYPE)
private InvestmentTransactionSubtype subtype;
public static final String SERIALIZED_NAME_ISO_CURRENCY_CODE = "iso_currency_code";
@SerializedName(SERIALIZED_NAME_ISO_CURRENCY_CODE)
private String isoCurrencyCode;
public static final String SERIALIZED_NAME_UNOFFICIAL_CURRENCY_CODE = "unofficial_currency_code";
@SerializedName(SERIALIZED_NAME_UNOFFICIAL_CURRENCY_CODE)
private String unofficialCurrencyCode;
public AssetReportInvestments investmentTransactionId(String investmentTransactionId) {
this.investmentTransactionId = investmentTransactionId;
return this;
}
/**
* The ID of the Investment transaction, unique across all Plaid transactions. Like all Plaid identifiers, the `investment_transaction_id` is case sensitive.
* @return investmentTransactionId
**/
@ApiModelProperty(required = true, value = "The ID of the Investment transaction, unique across all Plaid transactions. Like all Plaid identifiers, the `investment_transaction_id` is case sensitive.")
public String getInvestmentTransactionId() {
return investmentTransactionId;
}
public void setInvestmentTransactionId(String investmentTransactionId) {
this.investmentTransactionId = investmentTransactionId;
}
public AssetReportInvestments accountId(String accountId) {
this.accountId = accountId;
return this;
}
/**
* The `account_id` of the account against which this transaction posted.
* @return accountId
**/
@ApiModelProperty(required = true, value = "The `account_id` of the account against which this transaction posted.")
public String getAccountId() {
return accountId;
}
public void setAccountId(String accountId) {
this.accountId = accountId;
}
public AssetReportInvestments securityId(String securityId) {
this.securityId = securityId;
return this;
}
/**
* The `security_id` to which this transaction is related.
* @return securityId
**/
@javax.annotation.Nullable
@ApiModelProperty(required = true, value = "The `security_id` to which this transaction is related.")
public String getSecurityId() {
return securityId;
}
public void setSecurityId(String securityId) {
this.securityId = securityId;
}
public AssetReportInvestments date(LocalDate date) {
this.date = date;
return this;
}
/**
* The [ISO 8601](https://wikipedia.org/wiki/ISO_8601) posting date for the transaction.
* @return date
**/
@ApiModelProperty(required = true, value = "The [ISO 8601](https://wikipedia.org/wiki/ISO_8601) posting date for the transaction.")
public LocalDate getDate() {
return date;
}
public void setDate(LocalDate date) {
this.date = date;
}
public AssetReportInvestments name(String name) {
this.name = name;
return this;
}
/**
* The institution’s description of the transaction.
* @return name
**/
@ApiModelProperty(required = true, value = "The institution’s description of the transaction.")
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public AssetReportInvestments quantity(Double quantity) {
this.quantity = quantity;
return this;
}
/**
* The number of units of the security involved in this transaction. Positive for buy transactions; negative for sell transactions.
* @return quantity
**/
@ApiModelProperty(required = true, value = "The number of units of the security involved in this transaction. Positive for buy transactions; negative for sell transactions.")
public Double getQuantity() {
return quantity;
}
public void setQuantity(Double quantity) {
this.quantity = quantity;
}
public AssetReportInvestments vestedQuantity(Double vestedQuantity) {
this.vestedQuantity = vestedQuantity;
return this;
}
/**
* The total quantity of vested assets held, as reported by the financial institution. Vested assets are only associated with [equities](https://plaid.com/docs/api/products/investments/#investments-holdings-get-response-securities-type).
* @return vestedQuantity
**/
@ApiModelProperty(required = true, value = "The total quantity of vested assets held, as reported by the financial institution. Vested assets are only associated with [equities](https://plaid.com/docs/api/products/investments/#investments-holdings-get-response-securities-type).")
public Double getVestedQuantity() {
return vestedQuantity;
}
public void setVestedQuantity(Double vestedQuantity) {
this.vestedQuantity = vestedQuantity;
}
public AssetReportInvestments vestedValue(Double vestedValue) {
this.vestedValue = vestedValue;
return this;
}
/**
* The value of the vested holdings as reported by the institution.
* @return vestedValue
**/
@ApiModelProperty(required = true, value = "The value of the vested holdings as reported by the institution.")
public Double getVestedValue() {
return vestedValue;
}
public void setVestedValue(Double vestedValue) {
this.vestedValue = vestedValue;
}
public AssetReportInvestments amount(Double amount) {
this.amount = amount;
return this;
}
/**
* The complete value of the transaction. Positive values when cash is debited, e.g. purchases of stock; negative values when cash is credited, e.g. sales of stock. Treatment remains the same for cash-only movements unassociated with securities.
* @return amount
**/
@ApiModelProperty(required = true, value = "The complete value of the transaction. Positive values when cash is debited, e.g. purchases of stock; negative values when cash is credited, e.g. sales of stock. Treatment remains the same for cash-only movements unassociated with securities.")
public Double getAmount() {
return amount;
}
public void setAmount(Double amount) {
this.amount = amount;
}
public AssetReportInvestments price(Double price) {
this.price = price;
return this;
}
/**
* The price of the security at which this transaction occurred.
* @return price
**/
@ApiModelProperty(required = true, value = "The price of the security at which this transaction occurred.")
public Double getPrice() {
return price;
}
public void setPrice(Double price) {
this.price = price;
}
public AssetReportInvestments fees(Double fees) {
this.fees = fees;
return this;
}
/**
* The combined value of all fees applied to this transaction
* @return fees
**/
@javax.annotation.Nullable
@ApiModelProperty(required = true, value = "The combined value of all fees applied to this transaction")
public Double getFees() {
return fees;
}
public void setFees(Double fees) {
this.fees = fees;
}
public AssetReportInvestments type(InvestmentTransactionType type) {
this.type = type;
return this;
}
/**
* Get type
* @return type
**/
@ApiModelProperty(required = true, value = "")
public InvestmentTransactionType getType() {
return type;
}
public void setType(InvestmentTransactionType type) {
this.type = type;
}
public AssetReportInvestments subtype(InvestmentTransactionSubtype subtype) {
this.subtype = subtype;
return this;
}
/**
* Get subtype
* @return subtype
**/
@ApiModelProperty(required = true, value = "")
public InvestmentTransactionSubtype getSubtype() {
return subtype;
}
public void setSubtype(InvestmentTransactionSubtype subtype) {
this.subtype = subtype;
}
public AssetReportInvestments isoCurrencyCode(String isoCurrencyCode) {
this.isoCurrencyCode = isoCurrencyCode;
return this;
}
/**
* The ISO-4217 currency code of the transaction. Always `null` if `unofficial_currency_code` is non-`null`.
* @return isoCurrencyCode
**/
@javax.annotation.Nullable
@ApiModelProperty(required = true, value = "The ISO-4217 currency code of the transaction. Always `null` if `unofficial_currency_code` is non-`null`.")
public String getIsoCurrencyCode() {
return isoCurrencyCode;
}
public void setIsoCurrencyCode(String isoCurrencyCode) {
this.isoCurrencyCode = isoCurrencyCode;
}
public AssetReportInvestments unofficialCurrencyCode(String unofficialCurrencyCode) {
this.unofficialCurrencyCode = unofficialCurrencyCode;
return this;
}
/**
* The unofficial currency code associated with the holding. Always `null` if `iso_currency_code` is non-`null`. Unofficial currency codes are used for currencies that do not have official ISO currency codes, such as cryptocurrencies and the currencies of certain countries. See the [currency code schema](https://plaid.com/docs/api/accounts#currency-code-schema) for a full listing of supported `iso_currency_code`s.
* @return unofficialCurrencyCode
**/
@javax.annotation.Nullable
@ApiModelProperty(required = true, value = "The unofficial currency code associated with the holding. Always `null` if `iso_currency_code` is non-`null`. Unofficial currency codes are used for currencies that do not have official ISO currency codes, such as cryptocurrencies and the currencies of certain countries. See the [currency code schema](https://plaid.com/docs/api/accounts#currency-code-schema) for a full listing of supported `iso_currency_code`s.")
public String getUnofficialCurrencyCode() {
return unofficialCurrencyCode;
}
public void setUnofficialCurrencyCode(String unofficialCurrencyCode) {
this.unofficialCurrencyCode = unofficialCurrencyCode;
}
@Override
public boolean equals(Object o) {
if (this == o) {
return true;
}
if (o == null || getClass() != o.getClass()) {
return false;
}
AssetReportInvestments assetReportInvestments = (AssetReportInvestments) o;
return Objects.equals(this.investmentTransactionId, assetReportInvestments.investmentTransactionId) &&
Objects.equals(this.accountId, assetReportInvestments.accountId) &&
Objects.equals(this.securityId, assetReportInvestments.securityId) &&
Objects.equals(this.date, assetReportInvestments.date) &&
Objects.equals(this.name, assetReportInvestments.name) &&
Objects.equals(this.quantity, assetReportInvestments.quantity) &&
Objects.equals(this.vestedQuantity, assetReportInvestments.vestedQuantity) &&
Objects.equals(this.vestedValue, assetReportInvestments.vestedValue) &&
Objects.equals(this.amount, assetReportInvestments.amount) &&
Objects.equals(this.price, assetReportInvestments.price) &&
Objects.equals(this.fees, assetReportInvestments.fees) &&
Objects.equals(this.type, assetReportInvestments.type) &&
Objects.equals(this.subtype, assetReportInvestments.subtype) &&
Objects.equals(this.isoCurrencyCode, assetReportInvestments.isoCurrencyCode) &&
Objects.equals(this.unofficialCurrencyCode, assetReportInvestments.unofficialCurrencyCode);
}
@Override
public int hashCode() {
return Objects.hash(investmentTransactionId, accountId, securityId, date, name, quantity, vestedQuantity, vestedValue, amount, price, fees, type, subtype, isoCurrencyCode, unofficialCurrencyCode);
}
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
sb.append("class AssetReportInvestments {\n");
sb.append(" investmentTransactionId: ").append(toIndentedString(investmentTransactionId)).append("\n");
sb.append(" accountId: ").append(toIndentedString(accountId)).append("\n");
sb.append(" securityId: ").append(toIndentedString(securityId)).append("\n");
sb.append(" date: ").append(toIndentedString(date)).append("\n");
sb.append(" name: ").append(toIndentedString(name)).append("\n");
sb.append(" quantity: ").append(toIndentedString(quantity)).append("\n");
sb.append(" vestedQuantity: ").append(toIndentedString(vestedQuantity)).append("\n");
sb.append(" vestedValue: ").append(toIndentedString(vestedValue)).append("\n");
sb.append(" amount: ").append(toIndentedString(amount)).append("\n");
sb.append(" price: ").append(toIndentedString(price)).append("\n");
sb.append(" fees: ").append(toIndentedString(fees)).append("\n");
sb.append(" type: ").append(toIndentedString(type)).append("\n");
sb.append(" subtype: ").append(toIndentedString(subtype)).append("\n");
sb.append(" isoCurrencyCode: ").append(toIndentedString(isoCurrencyCode)).append("\n");
sb.append(" unofficialCurrencyCode: ").append(toIndentedString(unofficialCurrencyCode)).append("\n");
sb.append("}");
return sb.toString();
}
/**
* Convert the given object to string with each line indented by 4 spaces
* (except the first line).
*/
private String toIndentedString(Object o) {
if (o == null) {
return "null";
}
return o.toString().replace("\n", "\n ");
}
}