168 lines
4.9 KiB
Java
168 lines
4.9 KiB
Java
/**
|
|
*
|
|
*/
|
|
package org.gcube.accounting.datamodel.basetypes;
|
|
|
|
import java.io.Serializable;
|
|
import java.util.Calendar;
|
|
import java.util.Map;
|
|
|
|
import org.gcube.accounting.datamodel.BasicUsageRecord;
|
|
import org.gcube.accounting.datamodel.decorators.ComputedField;
|
|
import org.gcube.accounting.datamodel.decorators.RequiredField;
|
|
import org.gcube.accounting.datamodel.deprecationmanagement.annotations.MoveToOperationResult;
|
|
import org.gcube.accounting.datamodel.validations.annotations.NotEmpty;
|
|
import org.gcube.accounting.datamodel.validations.annotations.ValidInteger;
|
|
import org.gcube.accounting.datamodel.validations.annotations.ValidLong;
|
|
import org.gcube.accounting.exception.InvalidValueException;
|
|
|
|
/**
|
|
* @author Luca Frosini (ISTI - CNR) http://www.lucafrosini.com/
|
|
*
|
|
*/
|
|
public abstract class AbstractJobUsageRecord extends BasicUsageRecord {
|
|
|
|
//private static final Logger logger = LoggerFactory.getLogger(AbstractJobUsageRecord.class);
|
|
|
|
/**
|
|
* Generated Serial Version UID
|
|
*/
|
|
private static final long serialVersionUID = -8648691183939346858L;
|
|
|
|
protected static enum JobStatus {
|
|
completed, failed
|
|
};
|
|
|
|
@RequiredField @NotEmpty
|
|
public static final String JOB_ID = "jobId";
|
|
@RequiredField @NotEmpty
|
|
public static final String JOB_QUALIFIER = "jobQualifier";
|
|
@RequiredField @NotEmpty
|
|
public static final String JOB_NAME = "jobName";
|
|
@RequiredField @ValidLong @CalculateWallDuration
|
|
public static final String JOB_START_TIME = "jobStartTime";
|
|
@RequiredField @ValidLong @CalculateWallDuration
|
|
public static final String JOB_END_TIME = "jobEndTime";
|
|
@MoveToOperationResult
|
|
protected static final String JOB_STATUS = "jobStatus";
|
|
@ValidInteger
|
|
public static final String VMS_USED = "vmsUsed";
|
|
@ComputedField @ValidLong @CalculateWallDuration
|
|
protected static final String WALL_DURATION = "wallDuration";
|
|
|
|
public AbstractJobUsageRecord(){
|
|
super();
|
|
}
|
|
|
|
public AbstractJobUsageRecord(Map<String, Serializable> properties) throws InvalidValueException{
|
|
super(properties);
|
|
}
|
|
|
|
private static final String ABSTRACT_TO_REPLACE = "Abstract";
|
|
|
|
/**
|
|
* {@inheritDoc}
|
|
*/
|
|
@Override
|
|
protected String giveMeUsageRecordType() {
|
|
return AbstractJobUsageRecord.class.getSimpleName().replace(ABSTRACT_TO_REPLACE, "");
|
|
}
|
|
|
|
/**
|
|
* @return the Job Id
|
|
*/
|
|
public String getJobId() {
|
|
return (String) this.resourceProperties.get(JOB_ID);
|
|
}
|
|
|
|
/**
|
|
* @param jobId Job Id
|
|
* @throws InvalidValueException if fails
|
|
*/
|
|
public void setJobId(String jobId) throws InvalidValueException {
|
|
setResourceProperty(JOB_ID, jobId);
|
|
}
|
|
|
|
public String getJobQualifier() {
|
|
return (String) this.resourceProperties.get(JOB_QUALIFIER);
|
|
}
|
|
|
|
public void setJobQualifier(String jobQualifier) throws InvalidValueException {
|
|
setResourceProperty(JOB_QUALIFIER, jobQualifier);
|
|
}
|
|
|
|
public String getJobName() {
|
|
return (String) this.resourceProperties.get(JOB_NAME);
|
|
}
|
|
|
|
public void setJobName(String jobName) throws InvalidValueException {
|
|
setResourceProperty(JOB_NAME, jobName);
|
|
}
|
|
|
|
public Calendar getJobStartTime() {
|
|
long millis = (Long) this.resourceProperties.get(JOB_START_TIME);
|
|
return timestampStringToCalendar(millis);
|
|
}
|
|
|
|
public void setJobStartTime(Calendar jobStartTime) throws InvalidValueException {
|
|
setResourceProperty(JOB_START_TIME, jobStartTime.getTimeInMillis());
|
|
|
|
}
|
|
|
|
public Calendar getJobEndTime() {
|
|
long millis = (Long) this.resourceProperties.get(JOB_END_TIME);
|
|
return timestampStringToCalendar(millis);
|
|
}
|
|
|
|
public void setJobEndTime(Calendar jobEndTime) throws InvalidValueException {
|
|
setResourceProperty(JOB_END_TIME, jobEndTime.getTimeInMillis());
|
|
|
|
}
|
|
|
|
/*
|
|
@Deprecated
|
|
protected JobStatus getJobStatus() {
|
|
return JobStatus.values()[((OperationResult) this.resourceProperties.get(OPERATION_RESULT)).ordinal()];
|
|
}
|
|
|
|
@Deprecated
|
|
protected void setJobStatus(JobStatus jobStatus) throws InvalidValueException {
|
|
setResourceProperty(OPERATION_RESULT, jobStatus);
|
|
}
|
|
*/
|
|
|
|
public int getVmsUsed() {
|
|
return (Integer) this.resourceProperties.get(VMS_USED);
|
|
}
|
|
|
|
public void setVmsUsed(int vmsUsed) throws InvalidValueException {
|
|
setResourceProperty(VMS_USED, vmsUsed);
|
|
}
|
|
|
|
protected long calculateWallDuration() throws InvalidValueException {
|
|
try {
|
|
long endTime = (Long) this.resourceProperties.get(JOB_END_TIME);
|
|
long startTime = (Long) this.resourceProperties.get(JOB_START_TIME);
|
|
long wallDuration = endTime - startTime;
|
|
setResourceProperty(WALL_DURATION, wallDuration);
|
|
return wallDuration;
|
|
}catch(Exception e){
|
|
throw new InvalidValueException(String.format("To calculate Wall Duration both %s and %s must be set",
|
|
START_TIME, END_TIME), e);
|
|
}
|
|
}
|
|
|
|
public long getWallDuration() throws InvalidValueException {
|
|
Long wallDuration = (Long) this.resourceProperties.get(WALL_DURATION);
|
|
if(wallDuration == null){
|
|
try {
|
|
wallDuration = calculateWallDuration();
|
|
} catch(InvalidValueException e){
|
|
throw e;
|
|
}
|
|
}
|
|
return wallDuration;
|
|
}
|
|
|
|
}
|