/*
* JBoss, Home of Professional Open Source.
* See the COPYRIGHT.txt file distributed with this work for information
* regarding copyright ownership. Some portions may be licensed
* to Red Hat, Inc. under one or more contributor license agreements.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library 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 library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
* 02110-1301 USA.
*/
package org.teiid.translator;
import java.util.Date;
import org.teiid.core.TeiidRuntimeException;
/**
* Used by asynch connectors to indicate data is not available and results should be polled for after
* the given delay in milliseconds or until a Date is reached.
* <br>
* Note that delays are not guaranteed unless {@link #strict} is set to true. With {@link #strict} false, the delay is the maximum amount
* of time before the plan will be re-queued for execution. There are several scenarios that would cause the delay to be shorter, such as
* multiple sources where one source returns a shorter delay or if the engine believes more work is to be done before allowing the plan to sit idle.
* <br>
*/
public class DataNotAvailableException extends TeiidRuntimeException {
private static final long serialVersionUID = 5569111182915674334L;
private long retryDelay = 0;
private Date waitUntil;
private boolean strict;
/**
* Indicate that the engine should not poll for results and will be notified
* via the {@link ExecutionContext#dataAvailable()} method. However the engine may still ask
* for results before the dataAvailable is called.
*/
public static final DataNotAvailableException NO_POLLING = new DataNotAvailableException(-1);
/**
* Uses a delay of 0, which implies an immediate poll for results.
*/
public DataNotAvailableException() {
}
/**
* Uses the given retryDelay. Negative values indicate that the
* engine should not poll for results (see also {@link DataNotAvailableException#NO_POLLING} and will be notified
* via the {@link ExecutionContext#dataAvailable()} method.
* @param retryDelay in milliseconds
*/
public DataNotAvailableException(long retryDelay) {
this.retryDelay = retryDelay;
}
/**
* Instructs the engine to wait until the Date is met before getting results. By default this will
* be strictly enforced, meaning that no attempt will be made to get results before the given Date.
* @param waitUntil
*/
public DataNotAvailableException(Date waitUntil) {
this.waitUntil = waitUntil;
this.strict = true;
}
public long getRetryDelay() {
return retryDelay;
}
public Date getWaitUntil() {
return waitUntil;
}
/**
* If the delay or Date is strictly enforced then the execution will not asked for results until
* after that time or until {@link ExecutionContext#dataAvailable()} is called.
* @return
*/
public boolean isStrict() {
return strict;
}
public void setStrict(boolean strict) {
this.strict = strict;
}
}