try {
// Job oder Order
Variable_set params = spooler.create_variable_set();
if (spooler_task.params() != null) params.merge(spooler_task.params());
if (spooler_job.order_queue() != null && spooler_task.order().params() != null)
params.merge(spooler_task.order().params());
// mandatory parameters
name = "file";
if ( params.value("file") != null && params.value("file").length()>0 ) {
file = params.value("file");
// To make orderparams available for substitution in orderparam value
while (file.matches("^.*%[^%]+%.*$")) {
String p = file.replaceFirst("^.*%([^%]+)%.*$", "$1");
String s = params.var(p);
s = s.replace('\\','/');
file = file.replaceAll("%"+p+"%", s);
logger.debug("processing job parameter [file]: substitute %"+p+"% with "+s);
}
logger.info(".. job parameter [file]: " + file);
}
else if ( params.value("source_file") != null && params.value("source_file").length() > 0 ) {
file = params.value("source_file");
// To make orderparams available for substitution in orderparam value
while (file.matches("^.*%[^%]+%.*$")) {
String p = file.replaceFirst("^.*%([^%]+)%.*$", "$1");
String s = params.var(p);
s = s.replace('\\','/');
file = file.replaceAll("%"+p+"%", s);
logger.debug("processing job parameter [source_file]: substitute %"+p+"% with "+s);
}
logger.info(".. job parameter [source_file]: " + file);
}
else {
throw new Exception("job parameter is missing: ["+name+"]");
}
// optional parameters
name = "file_spec";
if ( params.value(name)!=null && params.value(name).length()>0 ) {
fileSpec = params.value(name);
logger.info(".. job parameter ["+name+"]: " + fileSpec);
}
try {
name = "gracious";
if ( params.value(name) != null && params.value(name).length() > 0 ) {
flags |= ( SOSFileOperations.toBoolean(params.value(name)) ) ? SOSFileOperations.GRACIOUS : 0;
logger.info(".. job parameter ["+name+"]: " + params.value(name));
}
name = "recursive";
if ( params.value(name) != null && params.value(name).length() > 0 ) {
flags |= ( SOSFileOperations.toBoolean(params.value(name)) ) ? SOSFileOperations.RECURSIVE : 0;
logger.info(".. job parameter ["+name+"]: " + params.value(name));
}
name = "remove_dir";
if ( params.value(name) != null && params.value(name).length() > 0 ) {
flags |= ( SOSFileOperations.toBoolean(params.value(name)) ) ? SOSFileOperations.REMOVE_DIR : 0;
logger.info(".. job parameter ["+name+"]: " + params.value(name));
}
name = "wipe";
if ( params.var(name)!=null && params.var(name).length()>0 ) {
flags |= ( SOSFileOperations.toBoolean(params.var(name)) ) ? SOSFileOperations.WIPE : 0;
logger.info(".. job parameter ["+name+"]: " + params.var(name));
}
name = "count_files";
if ( params.value(name)!=null && params.value(name).length()>0 ) {
count_files = SOSFileOperations.toBoolean(params.value(name));
logger.info(".. job parameter ["+name+"]: " + params.value(name));
if (spooler_job.order_queue() == null)
logger.warn("This is no order job. Job parameter ["+name+"] is only available for order jobs");
}
} catch (Exception x) {
throw new Exception("cannot evaluate job parameter ["+name+"]: "+ x.getMessage());
}
name = "min_file_age";
if ( params.var(name)!=null && params.var(name).length()>0 ) {
minFileAge = params.var(name);
logger.info(".. job parameter ["+name+"]: " + minFileAge);
}
name = "max_file_age";
if ( params.var(name)!=null && params.var(name).length()>0 ) {
maxFileAge = params.var(name);
logger.info(".. job parameter ["+name+"]: " + maxFileAge);
}
name = "min_file_size";
if ( params.var(name)!=null && params.var(name).length()>0 ) {
minFileSize = params.var(name);
logger.info(".. job parameter ["+name+"]: " + minFileSize);
}
name = "max_file_size";
if ( params.var(name)!=null && params.var(name).length()>0 ) {
maxFileSize = params.var(name);
logger.info(".. job parameter ["+name+"]: " + maxFileSize);
}
name="skip_first_files";
if ( params.var(name)!=null && params.var(name).length()>0 ) {
try {
skipFirstFiles = Integer.parseInt(params.var(name));
} catch (Exception ex) {
throw new Exception("invalid, non-numeric value for parameter [" + name + "]: " + ex.getMessage());
}
logger.info(".. job parameter ["+name+"]: " + skipFirstFiles);
}
name="skip_last_files";
if ( params.var(name)!=null && params.var(name).length()>0 ) {
try {
skipLastFiles = Integer.parseInt(params.var(name));
} catch (Exception ex) {
throw new Exception("invalid, non-numeric value for parameter [" + name + "]: " + ex.getMessage());
}
logger.info(".. job parameter ["+name+"]: " + skipLastFiles);
}
// Methodenaufruf
int nrOfRemovedObjects = SOSFileOperations.removeFileCnt(file, fileSpec, flags, java.util.regex.Pattern.CASE_INSENSITIVE, minFileAge, maxFileAge, minFileSize, maxFileSize, skipFirstFiles, skipLastFiles, logger);
// Anzahl der �bertragenen Dateien wird in einen Order-Parameter geschrieben
if (count_files && spooler_job.order_queue() != null) {
spooler_task.order().params().set_var("scheduler_SOSFileOperations_file_count", String.valueOf(nrOfRemovedObjects));
}
rc = (nrOfRemovedObjects > 0);
if (!rc && params.value("gracious") != null && params.value("gracious").equalsIgnoreCase("all")) {
return (spooler_job.order_queue() != null);
} else {
return (spooler_job.order_queue() != null) ? rc : false;
}