quartzPro/.svn/pristine/06/066a10d0b46c3cabb5ff464a648...

808 lines
32 KiB
Plaintext

package com.ifish.jpush;
import java.util.Map;
import java.util.Set;
import com.google.gson.JsonObject;
import com.ifish.jpush.common.ClientConfig;
import com.ifish.jpush.common.TimeUnit;
import com.ifish.jpush.common.Week;
import com.ifish.jpush.common.connection.HttpProxy;
import com.ifish.jpush.common.resp.APIConnectionException;
import com.ifish.jpush.common.resp.APIRequestException;
import com.ifish.jpush.common.resp.BooleanResult;
import com.ifish.jpush.common.resp.DefaultResult;
import com.ifish.jpush.device.AliasDeviceListResult;
import com.ifish.jpush.device.DeviceClient;
import com.ifish.jpush.device.OnlineStatus;
import com.ifish.jpush.device.TagAliasResult;
import com.ifish.jpush.device.TagListResult;
import com.ifish.jpush.push.PushClient;
import com.ifish.jpush.push.PushResult;
import com.ifish.jpush.push.model.Message;
import com.ifish.jpush.push.model.Platform;
import com.ifish.jpush.push.model.PushPayload;
import com.ifish.jpush.push.model.audience.Audience;
import com.ifish.jpush.push.model.notification.IosAlert;
import com.ifish.jpush.push.model.notification.Notification;
import com.ifish.jpush.report.MessagesResult;
import com.ifish.jpush.report.ReceivedsResult;
import com.ifish.jpush.report.ReportClient;
import com.ifish.jpush.report.UsersResult;
import com.ifish.jpush.schedule.ScheduleClient;
import com.ifish.jpush.schedule.ScheduleListResult;
import com.ifish.jpush.schedule.ScheduleResult;
import com.ifish.jpush.schedule.model.SchedulePayload;
import com.ifish.jpush.schedule.model.TriggerPayload;
import com.ifish.jpush.utils.Preconditions;
/**
* The global entrance of JPush API library.
*/
public class JPushClient {
private final PushClient _pushClient;
private final ReportClient _reportClient;
private final DeviceClient _deviceClient;
private final ScheduleClient _scheduleClient;
/**
* Create a JPush Client.
*
* @param masterSecret API access secret of the appKey.
* @param appKey The KEY of one application on JPush.
*/
public JPushClient(String masterSecret, String appKey) {
_pushClient = new PushClient(masterSecret, appKey);
_reportClient = new ReportClient(masterSecret, appKey);
_deviceClient = new DeviceClient(masterSecret, appKey);
_scheduleClient = new ScheduleClient(masterSecret, appKey);
}
public JPushClient(String masterSecret, String appKey, int maxRetryTimes) {
_pushClient = new PushClient(masterSecret, appKey, maxRetryTimes);
_reportClient = new ReportClient(masterSecret, appKey, maxRetryTimes);
_deviceClient = new DeviceClient(masterSecret, appKey, maxRetryTimes);
_scheduleClient = new ScheduleClient(masterSecret, appKey, maxRetryTimes);
}
public JPushClient(String masterSecret, String appKey, int maxRetryTimes, HttpProxy proxy) {
_pushClient = new PushClient(masterSecret, appKey, maxRetryTimes, proxy);
_reportClient = new ReportClient(masterSecret, appKey, maxRetryTimes, proxy);
_deviceClient = new DeviceClient(masterSecret, appKey, maxRetryTimes, proxy);
_scheduleClient = new ScheduleClient(masterSecret, appKey, maxRetryTimes, proxy);
}
/**
* Create a JPush Client by custom Client configuration.
*
* If you are using JPush privacy cloud, maybe this constructor is what you needed.
*
* @param masterSecret API access secret of the appKey.
* @param appKey The KEY of one application on JPush.
* @param maxRetryTimes Client request retry times.
* @param proxy The proxy, if there is no proxy, should be null.
* @param conf The client configuration. Can use ClientConfig.getInstance() as default.
*/
public JPushClient(String masterSecret, String appKey, int maxRetryTimes, HttpProxy proxy, ClientConfig conf) {
_pushClient = new PushClient(masterSecret, appKey, maxRetryTimes, proxy, conf);
_reportClient = new ReportClient(masterSecret, appKey, maxRetryTimes, proxy, conf);
_deviceClient = new DeviceClient(masterSecret, appKey, maxRetryTimes, proxy, conf);
_scheduleClient = new ScheduleClient(masterSecret, appKey, maxRetryTimes, proxy, conf);
}
/**
* Create a JPush Client by custom Client configuration with global settings.
*
* If you are using JPush privacy cloud, and you want different settings from default globally,
* maybe this constructor is what you needed.
*
* @param masterSecret API access secret of the appKey.
* @param appKey The KEY of one application on JPush.
* @param maxRetryTimes Client request retry times.
* @param proxy The proxy, if there is no proxy, should be null.
* @param conf The client configuration. Can use ClientConfig.getInstance() as default.
* @param apnsProduction Global APNs environment setting. It will override PushPayload Options.
* @param timeToLive Global time_to_live setting. It will override PushPayload Options.
*/
public JPushClient(String masterSecret, String appKey, int maxRetryTimes, HttpProxy proxy, ClientConfig conf,
boolean apnsProduction, long timeToLive) {
_pushClient = new PushClient(masterSecret, appKey, maxRetryTimes, proxy, conf);
_reportClient = new ReportClient(masterSecret, appKey, maxRetryTimes, proxy, conf);
_deviceClient = new DeviceClient(masterSecret, appKey, maxRetryTimes, proxy, conf);
_scheduleClient = new ScheduleClient(masterSecret, appKey, maxRetryTimes, proxy, conf);
_pushClient.setDefaults(apnsProduction, timeToLive);
}
/**
* Create a JPush Client with global settings.
*
* If you want different settings from default globally, this constructor is what you needed.
*
* @param masterSecret API access secret of the appKey.
* @param appKey The KEY of one application on JPush.
* @param apnsProduction Global APNs environment setting. It will override PushPayload Options.
* @param timeToLive Global time_to_live setting. It will override PushPayload Options.
*/
public JPushClient(String masterSecret, String appKey, boolean apnsProduction, long timeToLive) {
_pushClient = new PushClient(masterSecret, appKey, apnsProduction, timeToLive);
_reportClient = new ReportClient(masterSecret, appKey);
_deviceClient = new DeviceClient(masterSecret, appKey);
_scheduleClient = new ScheduleClient(masterSecret, appKey);
}
// ----------------------------- Push API
/**
* Send a push with PushPayload object.
*
* @param pushPayload payload object of a push.
* @return PushResult The result object of a Push. Can be printed to a JSON.
* @throws APIConnectionException
* @throws APIRequestException
*/
public PushResult sendPush(PushPayload pushPayload) throws APIConnectionException, APIRequestException {
return _pushClient.sendPush(pushPayload);
}
/**
* Send a push with JSON string.
*
* You can send a push JSON string directly with this method.
*
* Attention: globally settings cannot be affect this type of Push.
*
* @param payloadString payload of a push.
* @return PushResult. Can be printed to a JSON.
* @throws APIConnectionException
* @throws APIRequestException
*/
public PushResult sendPush(String payloadString) throws APIConnectionException, APIRequestException {
return _pushClient.sendPush(payloadString);
}
/**
* Validate a push action, but do NOT send it actually.
*
* @param paylaod
* @return
* @throws APIConnectionException
* @throws APIRequestException
*/
public PushResult sendPushValidate(PushPayload paylaod) throws APIConnectionException, APIRequestException {
return _pushClient.sendPushValidate(paylaod);
}
public PushResult sendPushValidate(String payloadString) throws APIConnectionException, APIRequestException {
return _pushClient.sendPushValidate(payloadString);
}
// ------------------------------- Report API
/**
* Get received report.
*
* @param msgIds 100 msgids to batch getting is supported.
* @return ReceivedResult. Can be printed to JSON.
* @throws APIConnectionException
* @throws APIRequestException
*/
public ReceivedsResult getReportReceiveds(String msgIds) throws APIConnectionException, APIRequestException {
return _reportClient.getReceiveds(msgIds);
}
public UsersResult getReportUsers(TimeUnit timeUnit, String start, int duration) throws APIConnectionException, APIRequestException {
return _reportClient.getUsers(timeUnit, start, duration);
}
public MessagesResult getReportMessages(String msgIds) throws APIConnectionException, APIRequestException {
return _reportClient.getMessages(msgIds);
}
// ------------------------------ Shortcuts - notification
/**
* Shortcut
*/
public PushResult sendNotificationAll(String alert) throws APIConnectionException, APIRequestException {
PushPayload payload = PushPayload.alertAll(alert);
return _pushClient.sendPush(payload);
}
/**
* Shortcut
*/
public PushResult sendAndroidNotificationWithAlias(String title, String alert,
Map<String, String> extras, String... alias)
throws APIConnectionException, APIRequestException {
PushPayload payload = PushPayload.newBuilder()
.setPlatform(Platform.android())
.setAudience(Audience.alias(alias))
.setNotification(Notification.android(alert, title, extras))
.build();
return _pushClient.sendPush(payload);
}
/**
* Shortcut
*/
public PushResult sendAndroidNotificationWithRegistrationID(String title, String alert,
Map<String, String> extras, String... registrationID)
throws APIConnectionException, APIRequestException {
PushPayload payload = PushPayload.newBuilder()
.setPlatform(Platform.android())
.setAudience(Audience.registrationId(registrationID))
.setNotification(Notification.android(alert, title, extras))
.build();
return _pushClient.sendPush(payload);
}
/**
* Shortcut
*/
public PushResult sendIosNotificationWithAlias(String alert, Map<String, String> extras, String... alias)
throws APIConnectionException, APIRequestException {
PushPayload payload = PushPayload.newBuilder()
.setPlatform(Platform.ios())
.setAudience(Audience.alias(alias))
.setNotification(Notification.ios(alert, extras))
.build();
return _pushClient.sendPush(payload);
}
/**
* Send an iOS notification with alias.
* If you want to send alert as a Json object, maybe this method is what you needed.
*
* @param alert The wrapper of APNs alert.
* @param extras The extra params.
* @param alias The alias list.
* @return
* @throws APIConnectionException
* @throws APIRequestException
*/
public PushResult sendIosNotificationWithAlias(IosAlert alert, Map<String, String> extras, String... alias)
throws APIConnectionException, APIRequestException {
PushPayload payload = PushPayload.newBuilder()
.setPlatform(Platform.ios())
.setAudience(Audience.alias(alias))
.setNotification(Notification.ios(alert, extras))
.build();
return _pushClient.sendPush(payload);
}
/**
* Send an iOS notification with alias.
* If you want to send alert as a Json object, maybe this method is what you needed.
*
* @param alert The wrapper of APNs alert.
* @param extras The extra params.
* @param alias The alias list.
* @return
* @throws APIConnectionException
* @throws APIRequestException
*/
public PushResult sendIosNotificationWithAlias(JsonObject alert, Map<String, String> extras, String... alias)
throws APIConnectionException, APIRequestException {
PushPayload payload = PushPayload.newBuilder()
.setPlatform(Platform.ios())
.setAudience(Audience.alias(alias))
.setNotification(Notification.ios(alert, extras))
.build();
return _pushClient.sendPush(payload);
}
/**
* Shortcut
*/
public PushResult sendIosNotificationWithRegistrationID(String alert,
Map<String, String> extras, String... registrationID)
throws APIConnectionException, APIRequestException {
PushPayload payload = PushPayload.newBuilder()
.setPlatform(Platform.ios())
.setAudience(Audience.registrationId(registrationID))
.setNotification(Notification.ios(alert, extras))
.build();
return _pushClient.sendPush(payload);
}
/**
* Send an iOS notification with registrationIds.
* If you want to send alert as a Json object, maybe this method is what you needed.
*
* @param alert The wrapper of APNs alert.
* @param extras The extra params.
* @param registrationID The registration ids.
* @return
* @throws APIConnectionException
* @throws APIRequestException
*/
public PushResult sendIosNotificationWithRegistrationID(IosAlert alert,
Map<String, String> extras, String... registrationID)
throws APIConnectionException, APIRequestException {
PushPayload payload = PushPayload.newBuilder()
.setPlatform(Platform.ios())
.setAudience(Audience.registrationId(registrationID))
.setNotification(Notification.ios(alert, extras))
.build();
return _pushClient.sendPush(payload);
}
/**
* Send an iOS notification with registrationIds.
* If you want to send alert as a Json object, maybe this method is what you needed.
*
* @param alert The wrapper of APNs alert.
* @param extras The extra params.
* @param registrationID The registration ids.
* @return
* @throws APIConnectionException
* @throws APIRequestException
*/
public PushResult sendIosNotificationWithRegistrationID(JsonObject alert,
Map<String, String> extras, String... registrationID)
throws APIConnectionException, APIRequestException {
PushPayload payload = PushPayload.newBuilder()
.setPlatform(Platform.ios())
.setAudience(Audience.registrationId(registrationID))
.setNotification(Notification.ios(alert, extras))
.build();
return _pushClient.sendPush(payload);
}
// ---------------------- shortcuts - message
/**
* Shortcut
*/
public PushResult sendMessageAll(String msgContent) throws APIConnectionException, APIRequestException {
PushPayload payload = PushPayload.messageAll(msgContent);
return _pushClient.sendPush(payload);
}
/**
* Shortcut
*/
public PushResult sendAndroidMessageWithAlias(String title, String msgContent, String... alias)
throws APIConnectionException, APIRequestException {
PushPayload payload = PushPayload.newBuilder()
.setPlatform(Platform.android())
.setAudience(Audience.alias(alias))
.setMessage(Message.newBuilder()
.setTitle(title)
.setMsgContent(msgContent)
.build())
.build();
return _pushClient.sendPush(payload);
}
/**
* Shortcut
*/
public PushResult sendAndroidMessageWithRegistrationID(String title, String msgContent, String... registrationID)
throws APIConnectionException, APIRequestException {
PushPayload payload = PushPayload.newBuilder()
.setPlatform(Platform.android())
.setAudience(Audience.registrationId(registrationID))
.setMessage(Message.newBuilder()
.setTitle(title)
.setMsgContent(msgContent)
.build())
.build();
return _pushClient.sendPush(payload);
}
/**
* Shortcut
*/
public PushResult sendIosMessageWithAlias(String title, String msgContent, String... alias)
throws APIConnectionException, APIRequestException {
PushPayload payload = PushPayload.newBuilder()
.setPlatform(Platform.ios())
.setAudience(Audience.alias(alias))
.setMessage(Message.newBuilder()
.setTitle(title)
.setMsgContent(msgContent)
.build())
.build();
return _pushClient.sendPush(payload);
}
/**
* Shortcut
*/
public PushResult sendIosMessageWithRegistrationID(String title, String msgContent, String... registrationID)
throws APIConnectionException, APIRequestException {
PushPayload payload = PushPayload.newBuilder()
.setPlatform(Platform.ios())
.setAudience(Audience.registrationId(registrationID))
.setMessage(Message.newBuilder()
.setTitle(title)
.setMsgContent(msgContent)
.build())
.build();
return _pushClient.sendPush(payload);
}
/**
* Shortcut
*/
public PushResult sendMessageWithRegistrationID(String title, String msgContent, String... registrationID)
throws APIConnectionException, APIRequestException {
PushPayload payload = PushPayload.newBuilder()
.setPlatform(Platform.all())
.setAudience(Audience.registrationId(registrationID))
.setMessage(Message.newBuilder()
.setTitle(title)
.setMsgContent(msgContent)
.build())
.build();
return _pushClient.sendPush(payload);
}
// ----------------------- Device
public TagAliasResult getDeviceTagAlias(String registrationId)
throws APIConnectionException, APIRequestException {
return _deviceClient.getDeviceTagAlias(registrationId);
}
public DefaultResult updateDeviceTagAlias(String registrationId, boolean clearAlias, boolean clearTag)
throws APIConnectionException, APIRequestException {
return _deviceClient.updateDeviceTagAlias(registrationId, clearAlias, clearTag);
}
public DefaultResult updateDeviceTagAlias(String registrationId, String alias,
Set<String> tagsToAdd, Set<String> tagsToRemove)
throws APIConnectionException, APIRequestException {
return _deviceClient.updateDeviceTagAlias(registrationId, alias, tagsToAdd, tagsToRemove);
}
public TagListResult getTagList()
throws APIConnectionException, APIRequestException {
return _deviceClient.getTagList();
}
public BooleanResult isDeviceInTag(String theTag, String registrationID)
throws APIConnectionException, APIRequestException {
return _deviceClient.isDeviceInTag(theTag, registrationID);
}
public DefaultResult addRemoveDevicesFromTag(String theTag,
Set<String> toAddUsers, Set<String> toRemoveUsers)
throws APIConnectionException, APIRequestException {
return _deviceClient.addRemoveDevicesFromTag(theTag, toAddUsers,
toRemoveUsers);
}
public DefaultResult deleteTag(String theTag, String platform)
throws APIConnectionException, APIRequestException {
return _deviceClient.deleteTag(theTag, platform);
}
public AliasDeviceListResult getAliasDeviceList(String alias,
String platform) throws APIConnectionException, APIRequestException {
return _deviceClient.getAliasDeviceList(alias, platform);
}
public DefaultResult deleteAlias(String alias, String platform)
throws APIConnectionException, APIRequestException {
return _deviceClient.deleteAlias(alias, platform);
}
public Map<String, OnlineStatus> getUserOnlineStatus(String... registrationIds)
throws APIConnectionException, APIRequestException
{
return _deviceClient.getUserOnlineStatus(registrationIds);
}
// ----------------------- Schedule
/**
* Create a single schedule.
* @param name The schedule name.
* @param time The push time, format is 'yyyy-MM-dd HH:mm:ss'
* @param push The push payload.
* @return The created scheduleResult instance.
* @throws APIConnectionException
* @throws APIRequestException
*/
public ScheduleResult createSingleSchedule(String name, String time, PushPayload push)
throws APIConnectionException, APIRequestException {
TriggerPayload trigger = TriggerPayload.newBuilder()
.setSingleTime(time)
.buildSingle();
SchedulePayload payload = SchedulePayload.newBuilder()
.setName(name)
.setEnabled(true)
.setTrigger(trigger)
.setPush(push)
.build();
return _scheduleClient.createSchedule(payload);
}
/**
* Create a daily schedule push everyday.
* @param name The schedule name.
* @param start The schedule comes into effect date, format 'yyyy-MM-dd HH:mm:ss'.
* @param end The schedule expiration date, format 'yyyy-MM-dd HH:mm:ss'.
* @param time The push time, format 'HH:mm:ss'
* @param push The push payload.
* @return The created scheduleResult instance.
* @throws APIConnectionException
* @throws APIRequestException
*/
public ScheduleResult createDailySchedule(String name, String start, String end, String time, PushPayload push)
throws APIConnectionException, APIRequestException {
return createPeriodicalSchedule(name, start, end, time, TimeUnit.DAY, 1, null, push);
}
/**
* Create a daily schedule push with a custom frequency.
* @param name The schedule name.
* @param start The schedule comes into effect date, format 'yyyy-MM-dd HH:mm:ss'.
* @param end The schedule expiration date, format 'yyyy-MM-dd HH:mm:ss'.
* @param time The push time, format 'HH:mm:ss'
* @param frequency The custom frequency.
* @param push The push payload.
* @return The created scheduleResult instance.
* @throws APIConnectionException
* @throws APIRequestException
*/
public ScheduleResult createDailySchedule(String name, String start, String end, String time, int frequency, PushPayload push)
throws APIConnectionException, APIRequestException {
return createPeriodicalSchedule(name, start, end, time, TimeUnit.DAY, frequency, null, push);
}
/**
* Create a weekly schedule push every week at the appointed days.
* @param name The schedule name.
* @param start The schedule comes into effect date, format 'yyyy-MM-dd HH:mm:ss'.
* @param end The schedule expiration date, format 'yyyy-MM-dd HH:mm:ss'.
* @param time The push time, format 'HH:mm:ss'
* @param days The appointed days.
* @param push The push payload.
* @return The created scheduleResult instance.
* @throws APIConnectionException
* @throws APIRequestException
*/
public ScheduleResult createWeeklySchedule(String name, String start, String end, String time, Week[] days, PushPayload push)
throws APIConnectionException, APIRequestException {
Preconditions.checkArgument(null != days && days.length > 0, "The days must not be empty.");
String[] points = new String[days.length];
for(int i = 0 ; i < days.length; i++) {
points[i] = days[i].name();
}
return createPeriodicalSchedule(name, start, end, time, TimeUnit.WEEK, 1, points, push);
}
/**
* Create a weekly schedule push with a custom frequency at the appointed days.
* @param name The schedule name.
* @param start The schedule comes into effect date, format 'yyyy-MM-dd HH:mm:ss'.
* @param end The schedule expiration date, format 'yyyy-MM-dd HH:mm:ss'.
* @param time The push time, format 'HH:mm:ss'.
* @param frequency The custom frequency.
* @param days The appointed days.
* @param push The push payload.
* @return The created scheduleResult instance.
* @throws APIConnectionException
* @throws APIRequestException
*/
public ScheduleResult createWeeklySchedule(String name, String start, String end, String time, int frequency, Week[] days, PushPayload push)
throws APIConnectionException, APIRequestException {
Preconditions.checkArgument(null != days && days.length > 0, "The days must not be empty.");
String[] points = new String[days.length];
for(int i = 0 ; i < days.length; i++) {
points[i] = days[i].name();
}
return createPeriodicalSchedule(name, start, end, time, TimeUnit.WEEK, frequency, points, push);
}
/**
* Create a monthly schedule push every month at the appointed days.
* @param name The schedule name.
* @param start The schedule comes into effect date, format 'yyyy-MM-dd HH:mm:ss'.
* @param end The schedule expiration date, format 'yyyy-MM-dd HH:mm:ss'.
* @param time The push time, format 'HH:mm:ss'.
* @param points The appointed days.
* @param push The push payload.
* @return The created scheduleResult instance.
* @throws APIConnectionException
* @throws APIRequestException
*/
public ScheduleResult createMonthlySchedule(String name, String start, String end, String time, String[] points, PushPayload push)
throws APIConnectionException, APIRequestException {
Preconditions.checkArgument(null != points && points.length > 0, "The points must not be empty.");
return createPeriodicalSchedule(name, start, end, time, TimeUnit.MONTH, 1, points, push);
}
/**
* Create a monthly schedule push with a custom frequency at the appointed days.
* @param name The schedule name.
* @param start The schedule comes into effect date, format 'yyyy-MM-dd HH:mm:ss'.
* @param end The schedule expiration date, format 'yyyy-MM-dd HH:mm:ss'.
* @param time The push time, format 'HH:mm:ss'.
* @param frequency The custom frequency.
* @param points The appointed days.
* @param push The push payload.
* @return The created scheduleResult instance.
* @throws APIConnectionException
* @throws APIRequestException
*/
public ScheduleResult createMonthlySchedule(String name, String start, String end, String time, int frequency, String[] points, PushPayload push)
throws APIConnectionException, APIRequestException {
Preconditions.checkArgument(null != points && points.length > 0, "The points must not be empty.");
return createPeriodicalSchedule(name, start, end, time, TimeUnit.MONTH, frequency, points, push);
}
/**
* Get the schedule information by the schedule id.
* @param scheduleId The schedule id.
* @return The schedule information.
* @throws APIConnectionException
* @throws APIRequestException
*/
public ScheduleResult getSchedule(String scheduleId)
throws APIConnectionException, APIRequestException {
return _scheduleClient.getSchedule(scheduleId);
}
/**
* Get the schedule list size and the first page.
* @return The schedule list size and the first page.
* @throws APIConnectionException
* @throws APIRequestException
*/
public ScheduleListResult getScheduleList()
throws APIConnectionException, APIRequestException {
return _scheduleClient.getScheduleList(1);
}
/**
* Get the schedule list by the page.
* @param page The page to search.
* @return The schedule list of the appointed page.
* @throws APIConnectionException
* @throws APIRequestException
*/
public ScheduleListResult getScheduleList(int page)
throws APIConnectionException, APIRequestException {
return _scheduleClient.getScheduleList(page);
}
/**
* Update the schedule name
* @param scheduleId The schedule id.
* @param name The new name.
* @return The schedule information after updated.
* @throws APIConnectionException
* @throws APIRequestException
*/
public ScheduleResult updateScheduleName(String scheduleId, String name)
throws APIConnectionException, APIRequestException {
SchedulePayload payload = SchedulePayload.newBuilder()
.setName(name)
.build();
return updateSchedule(scheduleId, payload);
}
/**
* Enable the schedule.
* @param scheduleId The schedule id.
* @return The schedule information after updated.
* @throws APIConnectionException
* @throws APIRequestException
*/
public ScheduleResult enableSchedule(String scheduleId)
throws APIConnectionException, APIRequestException {
SchedulePayload payload = SchedulePayload.newBuilder()
.setEnabled(true)
.build();
return updateSchedule(scheduleId, payload);
}
/**
* Disable the schedule.
* @param scheduleId The schedule id.
* @return The schedule information after updated.
* @throws APIConnectionException
* @throws APIRequestException
*/
public ScheduleResult disableSchedule(String scheduleId)
throws APIConnectionException, APIRequestException {
SchedulePayload payload = SchedulePayload.newBuilder()
.setEnabled(false)
.build();
return updateSchedule(scheduleId, payload);
}
/**
* Update the trigger of the schedule.
* @param scheduleId The schedule id.
* @param trigger The new trigger.
* @return The schedule information after updated.
* @throws APIConnectionException
* @throws APIRequestException
*/
public ScheduleResult updateScheduleTrigger(String scheduleId, TriggerPayload trigger)
throws APIConnectionException, APIRequestException {
SchedulePayload payload = SchedulePayload.newBuilder()
.setTrigger(trigger)
.build();
return updateSchedule(scheduleId, payload);
}
/**
* Update the push content of the schedule.
* @param scheduleId The schedule id.
* @param push The new push payload.
* @return The schedule information after updated.
* @throws APIConnectionException
* @throws APIRequestException
*/
public ScheduleResult updateSchedulePush(String scheduleId, PushPayload push)
throws APIConnectionException, APIRequestException {
SchedulePayload payload = SchedulePayload.newBuilder()
.setPush(push)
.build();
return updateSchedule(scheduleId, payload);
}
/**
* Update a schedule by the id.
* @param scheduleId The schedule id to update.
* @param payload The new schedule payload.
* @return The new schedule information.
* @throws APIConnectionException
* @throws APIRequestException
*/
public ScheduleResult updateSchedule(String scheduleId, SchedulePayload payload)
throws APIConnectionException, APIRequestException {
return _scheduleClient.updateSchedule(scheduleId, payload);
}
/**
* Delete a schedule by id.
* @param scheduleId The schedule id.
* @throws APIConnectionException
* @throws APIRequestException
*/
public void deleteSchedule(String scheduleId)
throws APIConnectionException, APIRequestException {
_scheduleClient.deleteSchedule(scheduleId);
}
private ScheduleResult createPeriodicalSchedule(String name, String start, String end, String time,
TimeUnit timeUnit, int frequency, String[] point, PushPayload push)
throws APIConnectionException, APIRequestException {
TriggerPayload trigger = TriggerPayload.newBuilder()
.setPeriodTime(start, end, time)
.setTimeFrequency(timeUnit, frequency, point )
.buildPeriodical();
SchedulePayload payload = SchedulePayload.newBuilder()
.setName(name)
.setEnabled(true)
.setTrigger(trigger)
.setPush(push)
.build();
return _scheduleClient.createSchedule(payload);
}
}