com.prowidesoftware.swift.model.mx.dic.LoanContract1 Maven / Gradle / Ivy
package com.prowidesoftware.swift.model.mx.dic;
import java.time.LocalDate;
import java.util.ArrayList;
import java.util.List;
import com.prowidesoftware.swift.model.mx.adapters.IsoDateAdapter;
import jakarta.xml.bind.annotation.XmlAccessType;
import jakarta.xml.bind.annotation.XmlAccessorType;
import jakarta.xml.bind.annotation.XmlElement;
import jakarta.xml.bind.annotation.XmlSchemaType;
import jakarta.xml.bind.annotation.XmlType;
import jakarta.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
import org.apache.commons.lang3.builder.EqualsBuilder;
import org.apache.commons.lang3.builder.HashCodeBuilder;
import org.apache.commons.lang3.builder.ToStringBuilder;
import org.apache.commons.lang3.builder.ToStringStyle;
/**
* Contract by which an amount of money in exchange for future repayment of the principal amount along with interest or other finance charges.
*
*
*
*/
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "LoanContract1", propOrder = {
"ctrctDocId",
"buyr",
"sellr",
"amt",
"mtrtyDt",
"prlngtnFlg",
"startDt",
"sttlmCcy",
"spclConds",
"drtnCd",
"intrstRate",
"trch",
"pmtSchdl",
"intrstSchdl",
"intraCpnyLn",
"coll",
"sndctdLn",
"attchmnt"
})
public class LoanContract1 {
@XmlElement(name = "CtrctDocId", required = true)
protected DocumentIdentification22 ctrctDocId;
@XmlElement(name = "Buyr", required = true)
protected List buyr;
@XmlElement(name = "Sellr", required = true)
protected List sellr;
@XmlElement(name = "Amt", required = true)
protected ActiveCurrencyAndAmount amt;
@XmlElement(name = "MtrtyDt", required = true, type = String.class)
@XmlJavaTypeAdapter(IsoDateAdapter.class)
@XmlSchemaType(name = "date")
protected LocalDate mtrtyDt;
@XmlElement(name = "PrlngtnFlg")
protected boolean prlngtnFlg;
@XmlElement(name = "StartDt", required = true, type = String.class)
@XmlJavaTypeAdapter(IsoDateAdapter.class)
@XmlSchemaType(name = "date")
protected LocalDate startDt;
@XmlElement(name = "SttlmCcy", required = true)
protected String sttlmCcy;
@XmlElement(name = "SpclConds")
protected SpecialCondition1 spclConds;
@XmlElement(name = "DrtnCd", required = true)
protected String drtnCd;
@XmlElement(name = "IntrstRate", required = true)
protected InterestRate2Choice intrstRate;
@XmlElement(name = "Trch")
protected List trch;
@XmlElement(name = "PmtSchdl")
protected PaymentSchedule1Choice pmtSchdl;
@XmlElement(name = "IntrstSchdl", required = true)
protected InterestPaymentSchedule1Choice intrstSchdl;
@XmlElement(name = "IntraCpnyLn")
protected boolean intraCpnyLn;
@XmlElement(name = "Coll")
protected ContractCollateral1 coll;
@XmlElement(name = "SndctdLn")
protected List sndctdLn;
@XmlElement(name = "Attchmnt")
protected List attchmnt;
/**
* Gets the value of the ctrctDocId property.
*
* @return
* possible object is
* {@link DocumentIdentification22 }
*
*/
public DocumentIdentification22 getCtrctDocId() {
return ctrctDocId;
}
/**
* Sets the value of the ctrctDocId property.
*
* @param value
* allowed object is
* {@link DocumentIdentification22 }
*
*/
public LoanContract1 setCtrctDocId(DocumentIdentification22 value) {
this.ctrctDocId = value;
return this;
}
/**
* Gets the value of the buyr property.
*
*
* This accessor method returns a reference to the live list,
* not a snapshot. Therefore any modification you make to the
* returned list will be present inside the Jakarta XML Binding object.
* This is why there is not a {@code set} method for the buyr property.
*
*
* For example, to add a new item, do as follows:
*
* getBuyr().add(newItem);
*
*
*
*
* Objects of the following type(s) are allowed in the list
* {@link TradeParty2 }
*
*
* @return
* The value of the buyr property.
*/
public List getBuyr() {
if (buyr == null) {
buyr = new ArrayList<>();
}
return this.buyr;
}
/**
* Gets the value of the sellr property.
*
*
* This accessor method returns a reference to the live list,
* not a snapshot. Therefore any modification you make to the
* returned list will be present inside the Jakarta XML Binding object.
* This is why there is not a {@code set} method for the sellr property.
*
*
* For example, to add a new item, do as follows:
*
* getSellr().add(newItem);
*
*
*
*
* Objects of the following type(s) are allowed in the list
* {@link TradeParty2 }
*
*
* @return
* The value of the sellr property.
*/
public List getSellr() {
if (sellr == null) {
sellr = new ArrayList<>();
}
return this.sellr;
}
/**
* Gets the value of the amt property.
*
* @return
* possible object is
* {@link ActiveCurrencyAndAmount }
*
*/
public ActiveCurrencyAndAmount getAmt() {
return amt;
}
/**
* Sets the value of the amt property.
*
* @param value
* allowed object is
* {@link ActiveCurrencyAndAmount }
*
*/
public LoanContract1 setAmt(ActiveCurrencyAndAmount value) {
this.amt = value;
return this;
}
/**
* Gets the value of the mtrtyDt property.
*
* @return
* possible object is
* {@link String }
*
*/
public LocalDate getMtrtyDt() {
return mtrtyDt;
}
/**
* Sets the value of the mtrtyDt property.
*
* @param value
* allowed object is
* {@link String }
*
*/
public LoanContract1 setMtrtyDt(LocalDate value) {
this.mtrtyDt = value;
return this;
}
/**
* Gets the value of the prlngtnFlg property.
*
*/
public boolean isPrlngtnFlg() {
return prlngtnFlg;
}
/**
* Sets the value of the prlngtnFlg property.
*
*/
public LoanContract1 setPrlngtnFlg(boolean value) {
this.prlngtnFlg = value;
return this;
}
/**
* Gets the value of the startDt property.
*
* @return
* possible object is
* {@link String }
*
*/
public LocalDate getStartDt() {
return startDt;
}
/**
* Sets the value of the startDt property.
*
* @param value
* allowed object is
* {@link String }
*
*/
public LoanContract1 setStartDt(LocalDate value) {
this.startDt = value;
return this;
}
/**
* Gets the value of the sttlmCcy property.
*
* @return
* possible object is
* {@link String }
*
*/
public String getSttlmCcy() {
return sttlmCcy;
}
/**
* Sets the value of the sttlmCcy property.
*
* @param value
* allowed object is
* {@link String }
*
*/
public LoanContract1 setSttlmCcy(String value) {
this.sttlmCcy = value;
return this;
}
/**
* Gets the value of the spclConds property.
*
* @return
* possible object is
* {@link SpecialCondition1 }
*
*/
public SpecialCondition1 getSpclConds() {
return spclConds;
}
/**
* Sets the value of the spclConds property.
*
* @param value
* allowed object is
* {@link SpecialCondition1 }
*
*/
public LoanContract1 setSpclConds(SpecialCondition1 value) {
this.spclConds = value;
return this;
}
/**
* Gets the value of the drtnCd property.
*
* @return
* possible object is
* {@link String }
*
*/
public String getDrtnCd() {
return drtnCd;
}
/**
* Sets the value of the drtnCd property.
*
* @param value
* allowed object is
* {@link String }
*
*/
public LoanContract1 setDrtnCd(String value) {
this.drtnCd = value;
return this;
}
/**
* Gets the value of the intrstRate property.
*
* @return
* possible object is
* {@link InterestRate2Choice }
*
*/
public InterestRate2Choice getIntrstRate() {
return intrstRate;
}
/**
* Sets the value of the intrstRate property.
*
* @param value
* allowed object is
* {@link InterestRate2Choice }
*
*/
public LoanContract1 setIntrstRate(InterestRate2Choice value) {
this.intrstRate = value;
return this;
}
/**
* Gets the value of the trch property.
*
*
* This accessor method returns a reference to the live list,
* not a snapshot. Therefore any modification you make to the
* returned list will be present inside the Jakarta XML Binding object.
* This is why there is not a {@code set} method for the trch property.
*
*
* For example, to add a new item, do as follows:
*
* getTrch().add(newItem);
*
*
*
*
* Objects of the following type(s) are allowed in the list
* {@link LoanContractTranche1 }
*
*
* @return
* The value of the trch property.
*/
public List getTrch() {
if (trch == null) {
trch = new ArrayList<>();
}
return this.trch;
}
/**
* Gets the value of the pmtSchdl property.
*
* @return
* possible object is
* {@link PaymentSchedule1Choice }
*
*/
public PaymentSchedule1Choice getPmtSchdl() {
return pmtSchdl;
}
/**
* Sets the value of the pmtSchdl property.
*
* @param value
* allowed object is
* {@link PaymentSchedule1Choice }
*
*/
public LoanContract1 setPmtSchdl(PaymentSchedule1Choice value) {
this.pmtSchdl = value;
return this;
}
/**
* Gets the value of the intrstSchdl property.
*
* @return
* possible object is
* {@link InterestPaymentSchedule1Choice }
*
*/
public InterestPaymentSchedule1Choice getIntrstSchdl() {
return intrstSchdl;
}
/**
* Sets the value of the intrstSchdl property.
*
* @param value
* allowed object is
* {@link InterestPaymentSchedule1Choice }
*
*/
public LoanContract1 setIntrstSchdl(InterestPaymentSchedule1Choice value) {
this.intrstSchdl = value;
return this;
}
/**
* Gets the value of the intraCpnyLn property.
*
*/
public boolean isIntraCpnyLn() {
return intraCpnyLn;
}
/**
* Sets the value of the intraCpnyLn property.
*
*/
public LoanContract1 setIntraCpnyLn(boolean value) {
this.intraCpnyLn = value;
return this;
}
/**
* Gets the value of the coll property.
*
* @return
* possible object is
* {@link ContractCollateral1 }
*
*/
public ContractCollateral1 getColl() {
return coll;
}
/**
* Sets the value of the coll property.
*
* @param value
* allowed object is
* {@link ContractCollateral1 }
*
*/
public LoanContract1 setColl(ContractCollateral1 value) {
this.coll = value;
return this;
}
/**
* Gets the value of the sndctdLn property.
*
*
* This accessor method returns a reference to the live list,
* not a snapshot. Therefore any modification you make to the
* returned list will be present inside the Jakarta XML Binding object.
* This is why there is not a {@code set} method for the sndctdLn property.
*
*
* For example, to add a new item, do as follows:
*
* getSndctdLn().add(newItem);
*
*
*
*
* Objects of the following type(s) are allowed in the list
* {@link SyndicatedLoan1 }
*
*
* @return
* The value of the sndctdLn property.
*/
public List getSndctdLn() {
if (sndctdLn == null) {
sndctdLn = new ArrayList<>();
}
return this.sndctdLn;
}
/**
* Gets the value of the attchmnt property.
*
*
* This accessor method returns a reference to the live list,
* not a snapshot. Therefore any modification you make to the
* returned list will be present inside the Jakarta XML Binding object.
* This is why there is not a {@code set} method for the attchmnt property.
*
*
* For example, to add a new item, do as follows:
*
* getAttchmnt().add(newItem);
*
*
*
*
* Objects of the following type(s) are allowed in the list
* {@link DocumentGeneralInformation3 }
*
*
* @return
* The value of the attchmnt property.
*/
public List getAttchmnt() {
if (attchmnt == null) {
attchmnt = new ArrayList<>();
}
return this.attchmnt;
}
@Override
public String toString() {
return ToStringBuilder.reflectionToString(this, ToStringStyle.MULTI_LINE_STYLE);
}
@Override
public boolean equals(Object that) {
return EqualsBuilder.reflectionEquals(this, that);
}
@Override
public int hashCode() {
return HashCodeBuilder.reflectionHashCode(this);
}
/**
* Adds a new item to the buyr list.
* @see #getBuyr()
*
*/
public LoanContract1 addBuyr(TradeParty2 buyr) {
getBuyr().add(buyr);
return this;
}
/**
* Adds a new item to the sellr list.
* @see #getSellr()
*
*/
public LoanContract1 addSellr(TradeParty2 sellr) {
getSellr().add(sellr);
return this;
}
/**
* Adds a new item to the trch list.
* @see #getTrch()
*
*/
public LoanContract1 addTrch(LoanContractTranche1 trch) {
getTrch().add(trch);
return this;
}
/**
* Adds a new item to the sndctdLn list.
* @see #getSndctdLn()
*
*/
public LoanContract1 addSndctdLn(SyndicatedLoan1 sndctdLn) {
getSndctdLn().add(sndctdLn);
return this;
}
/**
* Adds a new item to the attchmnt list.
* @see #getAttchmnt()
*
*/
public LoanContract1 addAttchmnt(DocumentGeneralInformation3 attchmnt) {
getAttchmnt().add(attchmnt);
return this;
}
}