ExecutionReference.java

85 lines | 2.047 kB Blame History Raw Download
/*
 * Copyright 2012 LinkedIn Corp.
 *
 * Licensed under the Apache License, Version 2.0 (the "License"); you may not
 * use this file except in compliance with the License. You may obtain a copy of
 * the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
 * License for the specific language governing permissions and limitations under
 * the License.
 */

package azkaban.executor;

public class ExecutionReference {

  private final int execId;
  private Executor executor;
  //Todo jamiesjc: deprecate updateTime in ExecutionReference class gradually.
  private long updateTime;
  private long nextCheckTime = -1;
  private int numErrors = 0;


  public ExecutionReference(final int execId) {
    this.execId = execId;
  }

  public ExecutionReference(final int execId, final Executor executor) {
    if (executor == null) {
      throw new IllegalArgumentException(String.format(
          "Executor cannot be null for exec id: %d ExecutionReference", execId));
    }
    this.execId = execId;
    this.executor = executor;
  }

  public long getUpdateTime() {
    return this.updateTime;
  }

  public void setUpdateTime(final long updateTime) {
    this.updateTime = updateTime;
  }

  public long getNextCheckTime() {
    return this.nextCheckTime;
  }

  public void setNextCheckTime(final long nextCheckTime) {
    this.nextCheckTime = nextCheckTime;
  }

  public int getExecId() {
    return this.execId;
  }

  public String getHost() {
    return this.executor.getHost();
  }

  public int getPort() {
    return this.executor.getPort();
  }

  public int getNumErrors() {
    return this.numErrors;
  }

  public void setNumErrors(final int numErrors) {
    this.numErrors = numErrors;
  }

  public Executor getExecutor() {
    return this.executor;
  }

  public void setExecutor(final Executor executor) {
    this.executor = executor;
  }
}