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