Method from org.apache.synapse.startup.quartz.SimpleQuartz Detail: |
public void addProperty(OMElement prop) {
xmlProperties.add(prop);
}
|
public void destroy() {
if (sch != null) {
try {
sch.shutdown();
} catch (SchedulerException e) {
log.warn("Error shutting down scheduler", e);
throw new SynapseException("Error shutting down scheduler", e);
}
}
}
|
public int getCount() {
return repeatCount;
}
|
public String getCron() {
return cron;
}
|
public long getInterval() {
return repeatInterval;
}
|
public String getJobClass() {
return className;
}
|
public List getPinnedServers() {
return pinnedServers;
}
|
public Set getProperties() {
return xmlProperties;
}
|
public QName getTagQName() {
return SimpleQuartzFactory.TASK;
}
|
public void init(SynapseEnvironment synapseEnvironment) {
// this server name given by system property SynapseServerName
// otherwise take host-name
// else assume localhost
String thisServerName = ServerManager.getInstance().getServerName();
if(thisServerName == null || thisServerName.equals("")) {
try {
InetAddress addr = InetAddress.getLocalHost();
thisServerName = addr.getHostName();
} catch (UnknownHostException e) {
log.warn("Could not get local host name", e);
}
if(thisServerName == null || thisServerName.equals("")) {
thisServerName = "localhost";
}
}
log.debug("Synapse server name : " + thisServerName);
// start proxy service if either,
// pinned server name list is empty
// or pinned server list has this server name
List pinnedServers = getPinnedServers();
if(pinnedServers != null && !pinnedServers.isEmpty()) {
if(!pinnedServers.contains(thisServerName)) {
log.info("Server name not in pinned servers list. Not starting Task : " + getName());
return;
}
}
try {
sch = DirectSchedulerFactory.getInstance().getScheduler();
if (sch == null) {
DirectSchedulerFactory.getInstance().createVolatileScheduler(THREADPOOLSIZE);
sch = DirectSchedulerFactory.getInstance().getScheduler();
}
if(sch == null) {
throw new NullPointerException("Scheduler is null");
}
Trigger trigger = null;
if (cron == null) {
if (repeatCount >= 0) {
trigger = TriggerUtils.makeImmediateTrigger(repeatCount - 1, repeatInterval);
} else {
trigger = TriggerUtils.makeImmediateTrigger(-1, repeatInterval);
}
} else {
CronTrigger cronTrig = new CronTrigger();
cronTrig.setCronExpression(cron);
trigger = cronTrig;
}
// give the trigger a random name
trigger.setName("Trigger" + String.valueOf((new Random()).nextLong()));
trigger.setGroup("synapse.simple.quartz");
trigger.setVolatility(true);
JobDetail jobDetail = new JobDetail();
// Give the job a name
jobDetail.setName(name);
jobDetail.setGroup("synapse.simple.quartz");
jobDetail.setJobClass(SimpleQuartzJob.class);
JobDataMap jdm = new JobDataMap();
jdm.put(SimpleQuartzJob.SYNAPSE_ENVIRONMENT, synapseEnvironment);
jdm.put(SimpleQuartzJob.CLASSNAME, className);
jdm.put(SimpleQuartzJob.PROPERTIES, xmlProperties);
jobDetail.setJobDataMap(jdm);
sch.scheduleJob(jobDetail, trigger);
sch.start();
log.info("Scheduled job " + jobDetail.getFullName() + " for class " + className);
} catch (Exception e) {
log.fatal("Error starting up Scheduler", e);
throw new SynapseException("Error starting up Scheduler", e);
}
}
|
public void setCount(int i) {
repeatCount = i;
}
|
public void setCron(String attributeValue) {
cron = attributeValue;
}
|
public void setInterval(long l) {
repeatInterval = l;
}
|
public void setJobClass(String attributeValue) {
className = attributeValue;
}
|
public void setPinnedServers(List pinnedServers) {
this.pinnedServers = pinnedServers;
}
|