be.fedict.trust.service.entity.RevokedCertificateEntity.java Source code

Java tutorial

Introduction

Here is the source code for be.fedict.trust.service.entity.RevokedCertificateEntity.java

Source

/*
 * eID Trust Service Project.
 * Copyright (C) 2009-2010 FedICT.
 *
 * This is free software; you can redistribute it and/or modify it
 * under the terms of the GNU Lesser General Public License version
 * 3.0 as published by the Free Software Foundation.
 *
 * This software is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this software; if not, see 
 * http://www.gnu.org/licenses/.
 */

package be.fedict.trust.service.entity;

import java.io.Serializable;
import java.math.BigInteger;
import java.util.Date;

import javax.persistence.Column;
import javax.persistence.EmbeddedId;
import javax.persistence.Entity;
import javax.persistence.NamedQueries;
import javax.persistence.NamedQuery;
import javax.persistence.Table;
import javax.persistence.Temporal;
import javax.persistence.TemporalType;

import org.apache.commons.lang.builder.EqualsBuilder;
import org.apache.commons.lang.builder.HashCodeBuilder;
import org.apache.commons.lang.builder.ToStringBuilder;
import org.apache.commons.lang.builder.ToStringStyle;

@Entity
@Table(name = "ts_revoked_certs")
@NamedQueries({
        @NamedQuery(name = RevokedCertificateEntity.QUERY_WHERE_ISSUER_SERIAL, query = "FROM RevokedCertificateEntity "
                + "WHERE pk.issuer = :issuer AND pk.serialNumber = :serialNumber"),
        @NamedQuery(name = RevokedCertificateEntity.QUERY_CRL_NUMBER_WHERE_ISSUER, query = "SELECT MAX(crlNumber) FROM RevokedCertificateEntity "
                + "WHERE pk.issuer = :issuer"),
        @NamedQuery(name = RevokedCertificateEntity.DELETE_WHERE_ISSUER, query = "DELETE FROM RevokedCertificateEntity "
                + "WHERE pk.issuer = :issuer"),
        @NamedQuery(name = RevokedCertificateEntity.QUERY_WHERE_ISSUER, query = "FROM RevokedCertificateEntity "
                + "WHERE pk.issuer = :issuer"),
        @NamedQuery(name = RevokedCertificateEntity.DELETE_WHERE_ISSUER_OLDER_CRL_NUMBER, query = "DELETE FROM RevokedCertificateEntity "
                + "WHERE crlNumber < :crlNumber AND issuer = :issuer"),
        @NamedQuery(name = RevokedCertificateEntity.QUERY_COUNT_ALL, query = "SELECT COUNT(*) FROM RevokedCertificateEntity") })
public class RevokedCertificateEntity implements Serializable {

    private static final long serialVersionUID = 1L;

    public static final String QUERY_WHERE_ISSUER_SERIAL = "ts_rc.q.i.s";
    public static final String QUERY_WHERE_ISSUER = "ts_rc.q.i";
    public static final String QUERY_CRL_NUMBER_WHERE_ISSUER = "ts_rc.q.c";
    public static final String DELETE_WHERE_ISSUER = "ts_rc.d.i";
    public static final String DELETE_WHERE_ISSUER_OLDER_CRL_NUMBER = "ts_rc.d.i.old.c";
    public static final String QUERY_COUNT_ALL = "ts_rc.q.count.all";

    private RevokedCertificatePK pk;
    private Date revocationDate;
    private BigInteger crlNumber;

    public RevokedCertificateEntity() {
        super();
    }

    public RevokedCertificateEntity(String issuer, BigInteger serialNumber, Date revocationDate,
            BigInteger crlNumber) {
        this.pk = new RevokedCertificatePK(issuer, serialNumber.toString());
        this.revocationDate = revocationDate;
        this.crlNumber = crlNumber;
    }

    @EmbeddedId
    public RevokedCertificatePK getPk() {
        return this.pk;
    }

    public void setPk(RevokedCertificatePK pk) {
        this.pk = pk;
    }

    @Temporal(TemporalType.TIMESTAMP)
    public Date getRevocationDate() {
        return this.revocationDate;
    }

    public void setRevocationDate(Date revocationDate) {
        this.revocationDate = revocationDate;
    }

    @Column(precision = 38)
    public BigInteger getCrlNumber() {
        return this.crlNumber;
    }

    public void setCrlNumber(BigInteger crlNumber) {
        this.crlNumber = crlNumber;
    }

    @Override
    public boolean equals(Object obj) {
        if (this == obj) {
            return true;
        }
        if (null == obj) {
            return false;
        }
        if (false == obj instanceof RevokedCertificateEntity) {
            return false;
        }
        RevokedCertificateEntity rhs = (RevokedCertificateEntity) obj;
        return new EqualsBuilder().append(this.pk, rhs.pk).isEquals();
    }

    @Override
    public int hashCode() {
        return new HashCodeBuilder().append(this.pk).toHashCode();
    }

    @Override
    public String toString() {
        return new ToStringBuilder(this, ToStringStyle.SHORT_PREFIX_STYLE).append("pk", this.pk)
                .append("crlNumber", this.crlNumber).append("revocationDate", this.revocationDate).toString();
    }
}