All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.mapfish.print.servlet.job.impl.PrintJobStatusImpl Maven / Gradle / Ivy

package org.mapfish.print.servlet.job.impl;

import org.hibernate.annotations.Target;
import org.hibernate.annotations.Type;
import org.mapfish.print.config.access.AccessAssertion;
import org.mapfish.print.servlet.job.PrintJobEntry;
import org.mapfish.print.servlet.job.PrintJobResult;
import org.mapfish.print.servlet.job.PrintJobStatus;

import java.util.Date;
import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Embedded;
import javax.persistence.Entity;
import javax.persistence.EnumType;
import javax.persistence.Enumerated;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.OneToOne;
import javax.persistence.Table;

/**
 * Represent a print job that has completed.  Contains the information about the print job.
 */
@Entity
@Table(name = "print_job_statuses")
public class PrintJobStatusImpl implements PrintJobStatus {
    @Embedded
    @Target(PrintJobEntryImpl.class)
    private final PrintJobEntry entry;
    @Id
    @Type(type = "org.hibernate.type.TextType")
    private String referenceId;
    @Column
    @Enumerated(EnumType.STRING)
    private PrintJobStatus.Status status = PrintJobStatus.Status.WAITING;

    @Column
    private Long completionTime;

    @Column
    private long requestCount;

    @Type(type = "org.hibernate.type.TextType")
    private String error;

    @OneToOne(targetEntity = PrintJobResultImpl.class, cascade = CascadeType.ALL, mappedBy = "status")
    @JoinColumn(name = "reference_id")
    private PrintJobResult result;

    private transient long waitingTime;

    private transient Long statusTime;

    /**
     * Constructor.
     */
    public PrintJobStatusImpl() {
        this.entry = null;
    }

    /**
     * Constructor.
     *
     * @param entry the PrintJobEntry.
     * @param requestCount request count
     */
    public PrintJobStatusImpl(final PrintJobEntry entry, final long requestCount) {
        this.referenceId = entry.getReferenceId();
        this.entry = entry;
        this.requestCount = requestCount;
    }

    @Override
    public PrintJobEntry getEntry() {
        return this.entry;
    }

    @Override
    public Long getCompletionTime() {
        return this.completionTime;
    }

    public void setCompletionTime(final Long completionTime) {
        this.completionTime = completionTime;
    }

    @Override
    public long getRequestCount() {
        return this.requestCount;
    }

    public void setRequestCount(final long requestCount) {
        this.requestCount = requestCount;
    }

    @Override
    public String getError() {
        return this.error;
    }

    public void setError(final String error) {
        this.error = error;
    }

    @Override
    public PrintJobStatus.Status getStatus() {
        return this.status;
    }

    public void setStatus(final PrintJobStatus.Status status) {
        this.status = status;
    }

    @Override
    public PrintJobResult getResult() {
        return this.result;
    }

    /**
     * Set the result.
     *
     * @param result The result
     */
    public void setResult(final PrintJobResult result) {
        this.result = result;
    }

    @Override
    public String getReferenceId() {
        return this.referenceId;
    }

    @Override
    public long getStartTime() {
        return getEntry().getStartTime();
    }

    @Override
    public AccessAssertion getAccess() {
        return getEntry().getAccess();
    }

    @Override
    public String getAppId() {
        return getEntry().getAppId();
    }

    @Override
    public Date getStartDate() {
        return getEntry().getStartDate();
    }

    @Override
    public Date getCompletionDate() {
        return getCompletionTime() == null ? null : new Date(getCompletionTime());
    }

    @Override
    public long getElapsedTime() {
        if (this.completionTime != null) {
            return this.completionTime - getEntry().getStartTime();
        } else if (this.statusTime != null) {
            // TODO: are we sure about that? Makes MapPrinterServletTest.doCreateAndPollAndGetReport unstable
            return this.statusTime - getEntry().getStartTime();
        } else {
            return System.currentTimeMillis() - getEntry().getStartTime();
        }
    }

    @Override
    public boolean isDone() {
        return getStatus() != PrintJobStatus.Status.RUNNING && getStatus() != PrintJobStatus.Status.WAITING;
    }

    @Override
    public long getWaitingTime() {
        return this.waitingTime;
    }

    @Override
    public void setWaitingTime(final long waitingTime) {
        this.waitingTime = waitingTime;
    }

    public Long getStatusTime() {
        return this.statusTime;
    }

    public void setStatusTime(final Long statusTime) {
        this.statusTime = statusTime;
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy