maia_modificado/.svn/pristine/83/8387daa957a6e35249cd5ff3da3...

697 lines
19 KiB
Plaintext
Executable File

package com.fp.persistence.pgeneral.gene;
import java.io.Serializable;
import java.lang.reflect.Field;
import java.math.BigDecimal;
import java.sql.Date;
import java.sql.Timestamp;
import java.util.List;
import javax.persistence.Column;
import javax.persistence.EmbeddedId;
import javax.persistence.Entity;
import javax.persistence.EntityManager;
import javax.persistence.Query;
import javax.persistence.Table;
import javax.persistence.Transient;
import com.fp.dto.hb.HibernateBean;
/** Clase que implementa la entidad de Hibernate que hace referencia a la tabla TGENEACCOUNTINSTALLRATES */
@Entity(name = "TgeneAccountInstallRates")
@Table(name = "TGENEACCOUNTINSTALLRATES")
public class TgeneAccountInstallRates extends com.fp.dto.AbstractDataTransport implements Serializable, HibernateBean, Cloneable {
/**
* HashCode asociado con la Instancia
*/
@Transient
private int hashValue = 0;
/**
* Version de la Clase
*/
private static final long serialVersionUID = 1L;
/**
* Clave primaria de la Entidad TgeneAccountInstallRates
*/
@EmbeddedId
private TgeneAccountInstallRatesKey pk;
@Column(name = "DATEFROM", nullable = true)
/**
* Fecha desde la cual esta definido el registro de tasas que se aplican en una operacio
*/
private Timestamp datefrom;
@Column(name = "BASERATECATALOG", nullable = true)
/**
* Codigo de catalogo de tasas base, BCE tasa banco central
*/
private String baseratecatalog;
@Column(name = "BASERATECATALOGCODE", nullable = true)
/**
* Codigo de tabla de catalogo BASERATE
*/
private String baseratecatalogcode;
@Column(name = "PRINCIPALBALANCETYPE", nullable = true)
/**
* Código de tipo de capital sobre el cual se aplica una tasa y se calcula un valor a provisionar
*/
private String principalbalancetype;
@Column(name = "PRINCIPALBALANCEGROUP", nullable = true)
/**
* Codigo del grupo de balance 1 Activo, 2 Pasivo, 3 Patrimonio .. 62 contingente deudor 61 por contra deudor
*/
private String principalbalancegroup;
@Column(name = "NEGOTIABLE", nullable = true)
/**
* Indica si la tasa se puede negociar con el cliente
*/
private String negotiable;
@Column(name = "BASERATE", nullable = true)
/**
* Tasa base
*/
private BigDecimal baserate;
@Column(name = "MARGIN", nullable = true)
/**
* Margen a aplicar dado el operador
*/
private BigDecimal margin;
@Column(name = "OPERATOR", nullable = true)
/**
* Operador a aplicar sobre la tasa base, +, - , %
*/
private String operator;
@Column(name = "RATE", nullable = true)
/**
* Tasa total con la cual se calcula provisiones y tabla de pagos
*/
private BigDecimal rate;
@Column(name = "EFFECTIVERATE", nullable = true)
/**
* Tasa efectiva
*/
private BigDecimal effectiverate;
@Column(name = "WORKINGDATE", nullable = true)
/**
* Fecha en la que se produjo un cambio
*/
private Date workingdate;
@Column(name = "REASON", nullable = true)
/**
* Motivo por el que se produjo el cambio: DES (desembolso) , etc
*/
private String reason;
@Column(name = "READJUSTMENTOPERATOR", nullable = true)
/**
* Operador que se utilizara el momento del reajuste
*/
private String readjustmentoperator;
@Column(name = "READJUSTMENTMARGIN", nullable = true)
/**
* Margen a aplicar en el reajuste
*/
private BigDecimal readjustmentmargin;
@Column(name = "CALCULATEDRATE", nullable = true)
/**
* Tasa que se genero al calcular el reajuste. Esta tasa no necesariamente se aplicara, puesto que puede ser mayor que el maximo permitido por la tasa base.
*/
private BigDecimal calculatedrate;
@Column(name = "ISNOMINALRATE", nullable = true)
/**
* Y, Indica que la defincion de la tasa base es efectiva, en este caso se calcula la tasa nominal, N la tasa base es nominal en este caso se calcula la tasa efectiva.
*/
private String isnominalrate;
@Column(name = "READJUSTBASERATECATALOG", nullable = true)
/**
* Codigo de catalogo de tasas base de reajuste, BCE tasa banco central
*/
private String readjustbaseratecatalog;
@Column(name = "READJUSTBASERATECATALOGCODE", nullable = true)
/**
* Codigo de tabla de catalogo BASERATE
*/
private String readjustbaseratecatalogcode;
@Column(name = "MAXBASERATECATALOG", nullable = true)
/**
* Codigo de catalogo de tasas base maxima, BCE tasa banco central
*/
private String maxbaseratecatalog;
@Column(name = "MAXBASERATECATALOGCODE", nullable = true)
/**
* Codigo de tabla de catalogo BASERATE
*/
private String maxbaseratecatalogcode;
/** Contructor por defecto */
public TgeneAccountInstallRates() {
}
/**
* Contructor de TgeneAccountInstallRates
*
* @param pPk Clave Primaria del entity
*/
public TgeneAccountInstallRates(TgeneAccountInstallRatesKey pPk) {
this();
this.pk = pPk;
}
/**
* Metodo que entrega datos de la tabla dada la clave primaria.
*
* @param pEntityManager referencia de la session a obtener datos del bean.
* @param pKey Caleve primaria del bean.
* @return TgeneAccountInstallRates
*/
public static TgeneAccountInstallRates find(EntityManager pEntityManager, TgeneAccountInstallRatesKey pKey) throws Exception {
TgeneAccountInstallRates obj = pEntityManager.find(TgeneAccountInstallRates.class, pKey);
return obj;
}
/**
* Entrega la Clave primaria de TgeneAccountInstallRates
*
* @return El objeto que referencia a la Clave primaria de TgeneAccountInstallRates
*/
public TgeneAccountInstallRatesKey getPk() {
return this.pk;
}
/**
* Fija un nuevo valor a la Clave primaria de TgeneAccountInstallRates
*
* @param pPk El objeto que referencia a la nueva Clave primaria de TgeneAccountInstallRates
*/
public void setPk(TgeneAccountInstallRatesKey pPk) {
this.pk = pPk;
}
/**
* Obtiene el valor de datefrom
*
* @return valor de datefrom
*/
public Timestamp getDatefrom() {
return this.datefrom;
}
/**
* Fija el valor de datefrom
*
* @param pDatefrom nuevo Valor de datefrom
*/
public void setDatefrom(Timestamp pDatefrom) {
this.datefrom = pDatefrom;
}
/**
* Obtiene el valor de baseratecatalog
*
* @return valor de baseratecatalog
*/
public String getBaseratecatalog() {
return this.baseratecatalog;
}
/**
* Fija el valor de baseratecatalog
*
* @param pBaseratecatalog nuevo Valor de baseratecatalog
*/
public void setBaseratecatalog(String pBaseratecatalog) {
this.baseratecatalog = pBaseratecatalog;
}
/**
* Obtiene el valor de baseratecatalogcode
*
* @return valor de baseratecatalogcode
*/
public String getBaseratecatalogcode() {
return this.baseratecatalogcode;
}
/**
* Fija el valor de baseratecatalogcode
*
* @param pBaseratecatalogcode nuevo Valor de baseratecatalogcode
*/
public void setBaseratecatalogcode(String pBaseratecatalogcode) {
this.baseratecatalogcode = pBaseratecatalogcode;
}
/**
* Obtiene el valor de principalbalancetype
*
* @return valor de principalbalancetype
*/
public String getPrincipalbalancetype() {
return this.principalbalancetype;
}
/**
* Fija el valor de principalbalancetype
*
* @param pPrincipalbalancetype nuevo Valor de principalbalancetype
*/
public void setPrincipalbalancetype(String pPrincipalbalancetype) {
this.principalbalancetype = pPrincipalbalancetype;
}
/**
* Obtiene el valor de principalbalancegroup
*
* @return valor de principalbalancegroup
*/
public String getPrincipalbalancegroup() {
return this.principalbalancegroup;
}
/**
* Fija el valor de principalbalancegroup
*
* @param pPrincipalbalancegroup nuevo Valor de principalbalancegroup
*/
public void setPrincipalbalancegroup(String pPrincipalbalancegroup) {
this.principalbalancegroup = pPrincipalbalancegroup;
}
/**
* Obtiene el valor de negotiable
*
* @return valor de negotiable
*/
public String getNegotiable() {
return this.negotiable;
}
/**
* Fija el valor de negotiable
*
* @param pNegotiable nuevo Valor de negotiable
*/
public void setNegotiable(String pNegotiable) {
this.negotiable = pNegotiable;
}
/**
* Obtiene el valor de baserate
*
* @return valor de baserate
*/
public BigDecimal getBaserate() {
return this.baserate;
}
/**
* Fija el valor de baserate
*
* @param pBaserate nuevo Valor de baserate
*/
public void setBaserate(BigDecimal pBaserate) {
this.baserate = pBaserate;
}
/**
* Obtiene el valor de margin
*
* @return valor de margin
*/
public BigDecimal getMargin() {
return this.margin;
}
/**
* Fija el valor de margin
*
* @param pMargin nuevo Valor de margin
*/
public void setMargin(BigDecimal pMargin) {
this.margin = pMargin;
}
/**
* Obtiene el valor de operator
*
* @return valor de operator
*/
public String getOperator() {
return this.operator;
}
/**
* Fija el valor de operator
*
* @param pOperator nuevo Valor de operator
*/
public void setOperator(String pOperator) {
this.operator = pOperator;
}
/**
* Obtiene el valor de rate
*
* @return valor de rate
*/
public BigDecimal getRate() {
return this.rate;
}
/**
* Fija el valor de rate
*
* @param pRate nuevo Valor de rate
*/
public void setRate(BigDecimal pRate) {
this.rate = pRate;
}
/**
* Obtiene el valor de effectiverate
*
* @return valor de effectiverate
*/
public BigDecimal getEffectiverate() {
return this.effectiverate;
}
/**
* Fija el valor de effectiverate
*
* @param pEffectiverate nuevo Valor de effectiverate
*/
public void setEffectiverate(BigDecimal pEffectiverate) {
this.effectiverate = pEffectiverate;
}
/**
* Obtiene el valor de workingdate
*
* @return valor de workingdate
*/
public Date getWorkingdate() {
return this.workingdate;
}
/**
* Fija el valor de workingdate
*
* @param pWorkingdate nuevo Valor de workingdate
*/
public void setWorkingdate(Date pWorkingdate) {
this.workingdate = pWorkingdate;
}
/**
* Obtiene el valor de reason
*
* @return valor de reason
*/
public String getReason() {
return this.reason;
}
/**
* Fija el valor de reason
*
* @param pReason nuevo Valor de reason
*/
public void setReason(String pReason) {
this.reason = pReason;
}
/**
* Obtiene el valor de readjustmentoperator
*
* @return valor de readjustmentoperator
*/
public String getReadjustmentoperator() {
return this.readjustmentoperator;
}
/**
* Fija el valor de readjustmentoperator
*
* @param pReadjustmentoperator nuevo Valor de readjustmentoperator
*/
public void setReadjustmentoperator(String pReadjustmentoperator) {
this.readjustmentoperator = pReadjustmentoperator;
}
/**
* Obtiene el valor de readjustmentmargin
*
* @return valor de readjustmentmargin
*/
public BigDecimal getReadjustmentmargin() {
return this.readjustmentmargin;
}
/**
* Fija el valor de readjustmentmargin
*
* @param pReadjustmentmargin nuevo Valor de readjustmentmargin
*/
public void setReadjustmentmargin(BigDecimal pReadjustmentmargin) {
this.readjustmentmargin = pReadjustmentmargin;
}
/**
* Obtiene el valor de calculatedrate
*
* @return valor de calculatedrate
*/
public BigDecimal getCalculatedrate() {
return this.calculatedrate;
}
/**
* Fija el valor de calculatedrate
*
* @param pCalculatedrate nuevo Valor de calculatedrate
*/
public void setCalculatedrate(BigDecimal pCalculatedrate) {
this.calculatedrate = pCalculatedrate;
}
/**
* Obtiene el valor de isnominalrate
*
* @return valor de isnominalrate
*/
public String getIsnominalrate() {
return this.isnominalrate;
}
/**
* Fija el valor de isnominalrate
*
* @param pIsnominalrate nuevo Valor de isnominalrate
*/
public void setIsnominalrate(String pIsnominalrate) {
this.isnominalrate = pIsnominalrate;
}
/**
* Obtiene el valor de readjustbaseratecatalog
*
* @return valor de readjustbaseratecatalog
*/
public String getReadjustbaseratecatalog() {
return this.readjustbaseratecatalog;
}
/**
* Fija el valor de readjustbaseratecatalog
*
* @param pReadjustbaseratecatalog nuevo Valor de readjustbaseratecatalog
*/
public void setReadjustbaseratecatalog(String pReadjustbaseratecatalog) {
this.readjustbaseratecatalog = pReadjustbaseratecatalog;
}
/**
* Obtiene el valor de readjustbaseratecatalogcode
*
* @return valor de readjustbaseratecatalogcode
*/
public String getReadjustbaseratecatalogcode() {
return this.readjustbaseratecatalogcode;
}
/**
* Fija el valor de readjustbaseratecatalogcode
*
* @param pReadjustbaseratecatalogcode nuevo Valor de readjustbaseratecatalogcode
*/
public void setReadjustbaseratecatalogcode(String pReadjustbaseratecatalogcode) {
this.readjustbaseratecatalogcode = pReadjustbaseratecatalogcode;
}
/**
* Obtiene el valor de maxbaseratecatalog
*
* @return valor de maxbaseratecatalog
*/
public String getMaxbaseratecatalog() {
return this.maxbaseratecatalog;
}
/**
* Fija el valor de maxbaseratecatalog
*
* @param pMaxbaseratecatalog nuevo Valor de maxbaseratecatalog
*/
public void setMaxbaseratecatalog(String pMaxbaseratecatalog) {
this.maxbaseratecatalog = pMaxbaseratecatalog;
}
/**
* Obtiene el valor de maxbaseratecatalogcode
*
* @return valor de maxbaseratecatalogcode
*/
public String getMaxbaseratecatalogcode() {
return this.maxbaseratecatalogcode;
}
/**
* Fija el valor de maxbaseratecatalogcode
*
* @param pMaxbaseratecatalogcode nuevo Valor de maxbaseratecatalogcode
*/
public void setMaxbaseratecatalogcode(String pMaxbaseratecatalogcode) {
this.maxbaseratecatalogcode = pMaxbaseratecatalogcode;
}
@Override
public boolean equals(Object rhs) {
if (rhs == null) {
return false;
}
if (!(rhs instanceof TgeneAccountInstallRates)) {
return false;
}
TgeneAccountInstallRates that = (TgeneAccountInstallRates) rhs;
if ((this.getPk() == null) || (that.getPk() == null)) {
return false;
}
return (this.getPk().equals(that.getPk()));
}
/**
* Implementacion del metodo hashCode de la la entidad TgeneAccountInstallRates
*
* @return el hashCode la instancia
*/
@Override
public int hashCode() {
if (this.hashValue == 0) {
int result = 17;
if (this.getPk() == null) {
result = super.hashCode();
} else {
result = this.getPk().hashCode();
}
this.hashValue = result;
}
return this.hashValue;
}
/** Implementacion toString */
@Override
public String toString() {
Field[] fs = this.getClass().getDeclaredFields();
String data = "";
for (Field f : fs) {
try {
String name = f.getName();
if (f.getType().getName().compareTo("java.util.Set") == 0) {
continue;
}
if ((name.compareTo("hashValue") == 0) || (name.compareTo("serialVersionUID") == 0)) {
continue;
}
data += name + "=" + f.get(this) + ";";
} catch (Exception e) {
continue;
}
}
if (data.compareTo("") == 0) {
data = super.toString();
}
return data;
}
/** Implementacion de la creacion de un bean en blanco TgeneAccountInstallRates */
@Override
public Object createInstance() {
TgeneAccountInstallRates instance = new TgeneAccountInstallRates();
instance.setPk(new TgeneAccountInstallRatesKey());
return instance;
}
/**
* Clona la entidad TgeneAccountInstallRates
*
* @see com.fp.dto.hb.HibernateBean#cloneMe()
*/
@Override
public Object cloneMe() throws CloneNotSupportedException {
TgeneAccountInstallRates p = (TgeneAccountInstallRates) this.clone();
p.setPk((TgeneAccountInstallRatesKey) this.pk.cloneMe());
return p;
}
public Object getId() {
return this.pk;
}
// Metodos manuales.
/** Sentencia que devuelve la definicion de valores a provisionar asociados de una cuenta. */
private static final String HQL_ACCOUNT_RATES = "from TgeneAccountInstallRates taccoinstrate " + " where taccoinstrate.pk.account = :account "
+ " and taccoinstrate.pk.company = :company " + " and taccoinstrate.pk.dateto = :dateto ";
/**
* Metodo que entrega una lista con los tipos de saldos a calcular tabla de amortizacion para una cuenta.
*
* @param pAccount Numero de cuenta.
* @param pCompany Compania a la que pertenece la cuenta.
* @return List<TgeneAccountInstallRates>
* @throws Exception
*/
@SuppressWarnings("unchecked")
public static List<TgeneAccountInstallRates> find(EntityManager pEntityManager, String pAccount, Integer pCompany) throws Exception {
List<TgeneAccountInstallRates> lObjects = null;
Query qry = pEntityManager.createQuery(HQL_ACCOUNT_RATES);
qry.setParameter("account", pAccount);
qry.setParameter("company", pCompany);
qry.setParameter("dateto", com.fp.common.helper.Constant.getDefaultExpiryDate());
lObjects = qry.getResultList();
return lObjects;
}
}