1
19
20 package com.liferay.portal.scheduler.job;
21
22 import com.liferay.portal.kernel.json.JSONFactoryUtil;
23 import com.liferay.portal.kernel.json.JSONObject;
24 import com.liferay.portal.kernel.log.Log;
25 import com.liferay.portal.kernel.log.LogFactoryUtil;
26 import com.liferay.portal.kernel.messaging.MessageBusUtil;
27 import com.liferay.portal.kernel.scheduler.SchedulerEngine;
28
29 import java.util.Date;
30
31 import org.quartz.Job;
32 import org.quartz.JobDataMap;
33 import org.quartz.JobDetail;
34 import org.quartz.JobExecutionContext;
35
36
43 public class MessageSenderJob implements Job {
44
45 public void execute(JobExecutionContext jobExecutionContext) {
46 try {
47 JobDetail jobDetail = jobExecutionContext.getJobDetail();
48
49 JobDataMap jobDataMap = jobDetail.getJobDataMap();
50
51 String destination = jobDataMap.getString(
52 SchedulerEngine.DESTINATION);
53 String messageBody = jobDataMap.getString(
54 SchedulerEngine.MESSAGE_BODY);
55
56 Date scheduledFireTime = jobExecutionContext.getScheduledFireTime();
57
58 JSONObject jsonObj = JSONFactoryUtil.createJSONObject(messageBody);
59
60 jsonObj.put(
61 "scheduledFireTime",
62 JSONFactoryUtil.createJSONObject(
63 JSONFactoryUtil.serialize(scheduledFireTime)));
64
65 MessageBusUtil.sendMessage(destination, jsonObj.toString());
66 }
67 catch (Exception e) {
68 _log.error("Unable to execute job", e);
69 }
70 }
71
72 private static Log _log = LogFactoryUtil.getLog(MessageSenderJob.class);
73
74 }