All Downloads are FREE. Search and download functionalities are using the official Maven repository.
Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
org.cardanofoundation.explorer.consumercommon.entity.PoolUpdate Maven / Gradle / Ivy
package org.cardanofoundation.explorer.consumercommon.entity;
import org.cardanofoundation.explorer.consumercommon.validation.Hash32Type;
import org.cardanofoundation.explorer.consumercommon.validation.Lovelace;
import java.math.BigInteger;
import java.util.Objects;
import jakarta.persistence.Column;
import jakarta.persistence.ConstraintMode;
import jakarta.persistence.Entity;
import jakarta.persistence.FetchType;
import jakarta.persistence.ForeignKey;
import jakarta.persistence.JoinColumn;
import jakarta.persistence.ManyToOne;
import jakarta.persistence.Table;
import jakarta.persistence.UniqueConstraint;
import jakarta.validation.constraints.Digits;
import lombok.AllArgsConstructor;
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.NoArgsConstructor;
import lombok.Setter;
import lombok.experimental.SuperBuilder;
import org.hibernate.Hibernate;
@Entity
@Table(name = "pool_update", uniqueConstraints = {
@UniqueConstraint(name = "unique_pool_update",
columnNames = {"registered_tx_id", "cert_index"})
})
@Getter
@Setter
@NoArgsConstructor
@AllArgsConstructor
@SuperBuilder(toBuilder = true)
public class PoolUpdate extends BaseEntity {
@ManyToOne(fetch = FetchType.LAZY, optional = false)
@JoinColumn(name = "hash_id", nullable = false,
foreignKey = @ForeignKey(value = ConstraintMode.NO_CONSTRAINT, name = "none"))
@EqualsAndHashCode.Exclude
private PoolHash poolHash;
@Column(name = "hash_id", updatable = false, insertable = false)
private Long poolHashId;
@Column(name = "cert_index", nullable = false)
private Integer certIndex;
@Column(name = "vrf_key_hash", nullable = false, length = 64)
@Hash32Type
private String vrfKeyHash;
@Column(name = "pledge", nullable = false, precision = 20)
@Lovelace
@Digits(integer = 20, fraction = 0)
private BigInteger pledge;
@ManyToOne(fetch = FetchType.LAZY, optional = false)
@JoinColumn(name = "reward_addr_id", nullable = false,
foreignKey = @ForeignKey(value = ConstraintMode.NO_CONSTRAINT, name = "none"))
@EqualsAndHashCode.Exclude
private StakeAddress rewardAddr;
@Column(name = "reward_addr_id", updatable = false, insertable = false)
private Long rewardAddrId;
@Column(name = "active_epoch_no", nullable = false)
private Integer activeEpochNo;
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "meta_id",
foreignKey = @ForeignKey(value = ConstraintMode.NO_CONSTRAINT, name = "none"))
@EqualsAndHashCode.Exclude
private PoolMetadataRef meta;
@Column(name = "margin", nullable = false)
private Double margin;
@Column(name = "fixed_cost", nullable = false, precision = 20)
@Lovelace
@Digits(integer = 20, fraction = 0)
private BigInteger fixedCost;
@ManyToOne(fetch = FetchType.LAZY, optional = false)
@JoinColumn(name = "registered_tx_id", nullable = false,
foreignKey = @ForeignKey(value = ConstraintMode.NO_CONSTRAINT, name = "none"))
@EqualsAndHashCode.Exclude
private Tx registeredTx;
@Column(name = "registered_tx_id", updatable = false, insertable = false)
private Long registeredTxId;
@Override
public boolean equals(Object o) {
if (this == o) {
return true;
}
if (o == null || Hibernate.getClass(this) != Hibernate.getClass(o)) {
return false;
}
PoolUpdate that = (PoolUpdate) o;
return id != null && Objects.equals(id, that.id);
}
@Override
public int hashCode() {
return getClass().hashCode();
}
}