All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.backendless.GeneralMessaging Maven / Gradle / Ivy

/*
 * ********************************************************************************************************************
 *  

* BACKENDLESS.COM CONFIDENTIAL *

* ******************************************************************************************************************** *

* Copyright 2012 BACKENDLESS.COM. All Rights Reserved. *

* NOTICE: All information contained herein is, and remains the property of Backendless.com and its suppliers, * if any. The intellectual and technical concepts contained herein are proprietary to Backendless.com and its * suppliers and may be covered by U.S. and Foreign Patents, patents in process, and are protected by trade secret * or copyright law. Dissemination of this information or reproduction of this material is strictly forbidden * unless prior written permission is obtained from Backendless.com. *

* ******************************************************************************************************************** */ package com.backendless;/* * ******************************************************************************************************************** *

* BACKENDLESS.COM CONFIDENTIAL *

* ******************************************************************************************************************** *

* Copyright 2012 BACKENDLESS.COM. All Rights Reserved. *

* NOTICE: All information contained herein is, and remains the property of Backendless.com and its suppliers, * if any. The intellectual and technical concepts contained herein are proprietary to Backendless.com and its * suppliers and may be covered by U.S. and Foreign Patents, patents in process, and are protected by trade secret * or copyright law. Dissemination of this information or reproduction of this material is strictly forbidden * unless prior written permission is obtained from Backendless.com. *

* ******************************************************************************************************************** */ import com.backendless.async.callback.AsyncCallback; import com.backendless.exceptions.BackendlessException; import com.backendless.exceptions.BackendlessFault; import com.backendless.exceptions.ExceptionMessage; import com.backendless.messaging.BodyParts; import com.backendless.messaging.DeliveryOptions; import com.backendless.messaging.EmailEnvelope; import com.backendless.messaging.Message; import com.backendless.messaging.MessageStatus; import com.backendless.messaging.PublishOptions; import com.backendless.messaging.PublishStatusEnum; import com.backendless.messaging.PushBroadcastMask; import com.backendless.push.DeviceRegistrationResult; import com.backendless.push.DeviceRegistrationUtil; import com.backendless.rt.messaging.Channel; import com.backendless.rt.messaging.ChannelFactory; import weborb.types.Types; import java.util.ArrayList; import java.util.Arrays; import java.util.Date; import java.util.List; import java.util.Map; class GeneralMessaging implements Messaging { final static String MESSAGING_MANAGER_SERVER_ALIAS = "com.backendless.services.messaging.MessagingService"; final static String EMAIL_MANAGER_SERVER_ALIAS = "com.backendless.services.mail.CustomersEmailService"; final static String EMAIL_TEMPLATE_SENDER_SERVER_ALIAS = "com.backendless.services.mail.EmailTemplateSender"; final static String DEFAULT_CHANNEL_NAME = "default"; static final ChannelFactory chanelFactory = new ChannelFactory(); static final ContextHandler contextHandler = BackendlessInjector.getInstance().getContextHandler(); static final BackendlessPrefs prefs = BackendlessInjector.getInstance().getPrefs(); static final GeneralMessaging instance = new GeneralMessaging(); protected GeneralMessaging() { Types.addClientClassMapping( "com.backendless.management.DeviceRegistrationDto", DeviceRegistration.class ); Types.addClientClassMapping( "com.backendless.services.messaging.PublishOptions", PublishOptions.class ); Types.addClientClassMapping( "com.backendless.services.messaging.DeliveryOptions", DeliveryOptions.class ); Types.addClientClassMapping( "com.backendless.services.messaging.Message", Message.class ); } static GeneralMessaging getInstance() { return instance; } public void registerDevice() { registerDevice( (List) null ); } public void registerDevice( AsyncCallback callback ) { registerDevice( null, callback ); } public void registerDevice( List channels ) { registerDevice( channels, (Date) null ); } public void registerDevice( List channels, Date expiration ) { registerDevice( channels, expiration, null ); } public void registerDevice( List channels, AsyncCallback callback ) { registerDevice( channels, null, callback ); } public void registerDevice( List channels, Date expiration, AsyncCallback callback ) { throw new UnsupportedOperationException( ExceptionMessage.NOT_ANDROID ); } protected void checkChannelName( String channelName ) { if( channelName == null ) throw new IllegalArgumentException( ExceptionMessage.NULL_CHANNEL_NAME ); if( channelName.equals( "" ) ) throw new IllegalArgumentException( ExceptionMessage.NULL_CHANNEL_NAME ); } public void unregisterDevice() { unregisterDevice( (List) null ); } public void unregisterDevice( List channels ) { unregisterDevice( channels, null ); } public void unregisterDevice( AsyncCallback callback ) { unregisterDevice( null, callback ); } public void unregisterDevice( final List channels, final AsyncCallback callback ) { throw new UnsupportedOperationException( ExceptionMessage.NOT_ANDROID ); } public boolean refreshDeviceToken( String newDeviceToken ) { return Invoker.invokeSync( DeviceRegistrationUtil.getDeviceRegistrationManagerServerAlias(), "refreshDeviceToken", new Object[] { prefs.getDeviceId(), newDeviceToken } ); } public void refreshDeviceToken( String newDeviceToken, final AsyncCallback responder ) { Invoker.invokeAsync( DeviceRegistrationUtil.getDeviceRegistrationManagerServerAlias(), "refreshDeviceToken", new Object[] { prefs.getDeviceId(), newDeviceToken }, responder ); } public DeviceRegistration getDeviceRegistration() { return getRegistrations(); } public DeviceRegistration getRegistrations() { return Invoker.invokeSync( DeviceRegistrationUtil.getDeviceRegistrationManagerServerAlias(), "getDeviceRegistrationByDeviceId", new Object[] { prefs.getDeviceId() } ); } public void getDeviceRegistration( AsyncCallback responder ) { getRegistrations( responder ); } public void getRegistrations( AsyncCallback responder ) { Invoker.invokeAsync( DeviceRegistrationUtil.getDeviceRegistrationManagerServerAlias(), "getDeviceRegistrationByDeviceId", new Object[] { prefs.getDeviceId() }, responder ); } /** * Publishes message to "default" channel. The message is not a push notification, it does not have any headers and * does not go into any subtopics. * * @param message object to publish. The object can be of any data type - a primitive value, String, Date, a * user-defined complex type, a collection or an array of these types. * @return a data structure which contains ID of the published message and the status of the publish operation. * @throws BackendlessException */ public MessageStatus publish( Object message ) { if( message instanceof PublishOptions || message instanceof DeliveryOptions ) throw new IllegalArgumentException( ExceptionMessage.INCORRECT_MESSAGE_TYPE ); return publish( null, message ); } /** * Publishes message to specified channel. The message is not a push notification, it does not have any headers and * does not go into any subtopics. * * @param channelName name of a channel to publish the message to. If the channel does not exist, Backendless * automatically creates it. * @param message object to publish. The object can be of any data type - a primitive value, String, Date, a * user-defined complex type, a collection or an array of these types. * @return ${@link com.backendless.messaging.MessageStatus} - a data structure which contains ID of the published * message and the status of the publish operation. * @throws BackendlessException */ public MessageStatus publish( String channelName, Object message ) { return publish( channelName, message, new PublishOptions() ); } /** * Publishes message to specified channel. The message is not a push notification, it may have headers and/or subtopic * defined in the publishOptions argument. * * @param channelName name of a channel to publish the message to. If the channel does not exist, Backendless * automatically creates it. * @param message object to publish. The object can be of any data type - a primitive value, String, Date, a * user-defined complex type, a collection or an array of these types. * @param publishOptions an instance of ${@link PublishOptions}. When provided may contain * publisher ID (an arbitrary, application-specific string value identifying the publisher), * subtopic value and/or a collection of headers. * @return a data structure which contains ID of the published message and the status of the publish operation. */ public MessageStatus publish( String channelName, Object message, PublishOptions publishOptions ) { return publish( channelName, message, publishOptions, new DeliveryOptions() ); } /** * Publishes message to specified channel.The message may be configured as a push notification. It may have headers * and/or subtopic defined in the publishOptions argument. * * @param channelName name of a channel to publish the message to. If the channel does not exist, Backendless * automatically creates it. * @param message object to publish. The object can be of any data type - a primitive value, String, Date, a * user-defined complex type, a collection or an array of these types. * @param publishOptions an instance of ${@link PublishOptions}. When provided may contain * publisher ID (an arbitrary, application-specific string value identifying the publisher), * subtopic value and/or a collection of headers. * @param deliveryOptions an instance of ${@link DeliveryOptions}. When provided may specify * options for message delivery such as: deliver as a push notification, deliver to specific * devices (or a group of devices grouped by the operating system), delayed delivery or repeated * delivery. * @return a data structure which contains ID of the published message and the status of the publish operation. */ public MessageStatus publish( String channelName, Object message, PublishOptions publishOptions, DeliveryOptions deliveryOptions ) { channelName = getCheckedChannelName( channelName ); if( message == null ) throw new IllegalArgumentException( ExceptionMessage.NULL_MESSAGE ); if( deliveryOptions.getPushBroadcast() == 0 && deliveryOptions.getPushSinglecast().isEmpty() ) { deliveryOptions.setPushBroadcast( PushBroadcastMask.ALL ); } return Invoker.invokeSync( MESSAGING_MANAGER_SERVER_ALIAS, "publish", new Object[] { channelName, message, publishOptions, deliveryOptions } ); } protected String getCheckedChannelName( String channelName ) { if( channelName == null ) return DEFAULT_CHANNEL_NAME; if( channelName.equals( "" ) ) return DEFAULT_CHANNEL_NAME; return channelName; } /** * Publishes message to "default" channel. The message is not a push notification, it does not have any headers and * does not go into any subtopics. * * @param message object to publish. The object can be of any data type - a primitive value, String, Date, a * user-defined complex type, a collection or an array of these types. * @param publishOptions an instance of ${@link PublishOptions}. When provided may contain * publisher ID (an arbitrary, application-specific string value identifying the publisher), * subtopic value and/or a collection of headers. * @return a data structure which contains ID of the published message and the status of the publish operation. * @throws BackendlessException */ public MessageStatus publish( Object message, PublishOptions publishOptions ) { return publish( null, message, publishOptions ); } /** * Publishes message to "default" channel.The message may be configured as a push notification. It may have headers * and/or subtopic defined in the publishOptions argument. * * @param message object to publish. The object can be of any data type - a primitive value, String, Date, a * user-defined complex type, a collection or an array of these types. * @param publishOptions an instance of ${@link PublishOptions}. When provided may contain * publisher ID (an arbitrary, application-specific string value identifying the publisher), * subtopic value and/or a collection of headers. * @param deliveryOptions an instance of ${@link DeliveryOptions}. When provided may specify * options for message delivery such as: deliver as a push notification, deliver to specific * devices (or a group of devices grouped by the operating system), delayed delivery or repeated * delivery. * @return a data structure which contains ID of the published message and the status of the publish operation. */ public MessageStatus publish( Object message, PublishOptions publishOptions, DeliveryOptions deliveryOptions ) { return publish( null, message, publishOptions, deliveryOptions ); } public void publish( Object message, final AsyncCallback responder ) { publish( null, message, responder ); } public void publish( String channelName, Object message, final AsyncCallback responder ) { publish( channelName, message, new PublishOptions(), responder ); } public void publish( String channelName, Object message, PublishOptions publishOptions, final AsyncCallback responder ) { publish( channelName, message, publishOptions, new DeliveryOptions(), responder ); } public void publish( String channelName, Object message, PublishOptions publishOptions, DeliveryOptions deliveryOptions, final AsyncCallback responder ) { try { channelName = getCheckedChannelName( channelName ); if( message == null ) throw new IllegalArgumentException( ExceptionMessage.NULL_MESSAGE ); Invoker.invokeAsync( MESSAGING_MANAGER_SERVER_ALIAS, "publish", new Object[] { channelName, message, publishOptions, deliveryOptions }, responder ); } catch( Throwable e ) { if( responder != null ) responder.handleFault( new BackendlessFault( e ) ); } } public void publish( Object message, PublishOptions publishOptions, final AsyncCallback responder ) { publish( null, message, publishOptions, new DeliveryOptions(), responder ); } public void publish( Object message, PublishOptions publishOptions, DeliveryOptions deliveryOptions, final AsyncCallback responder ) { publish( null, message, publishOptions, deliveryOptions, responder ); } public MessageStatus pushWithTemplate( String templateName ) { return this.pushWithTemplate( templateName, (Map) null ); } public MessageStatus pushWithTemplate( String templateName, Map templateValues ) { if( templateName == null ) throw new IllegalArgumentException( ExceptionMessage.NULL_EMPTY_TEMPLATE_NAME ); return Invoker.invokeSync( MESSAGING_MANAGER_SERVER_ALIAS, "pushWithTemplate", new Object[] { templateName, templateValues } ); } public void pushWithTemplate( String templateName, final AsyncCallback responder ) { this.pushWithTemplate( templateName, null, responder ); } public void pushWithTemplate( String templateName, Map templateValues, final AsyncCallback responder ) { if( templateName == null ) throw new IllegalArgumentException( ExceptionMessage.NULL_EMPTY_TEMPLATE_NAME ); Invoker.invokeAsync( MESSAGING_MANAGER_SERVER_ALIAS, "pushWithTemplate", new Object[] { templateName, templateValues }, responder ); } public MessageStatus getMessageStatus( String messageId ) { if( messageId == null ) throw new IllegalArgumentException( ExceptionMessage.NULL_MESSAGE_ID ); MessageStatus messageStatus = Invoker.invokeSync( MESSAGING_MANAGER_SERVER_ALIAS, "getMessageStatus", new Object[] { messageId } ); return messageStatus; } public void getMessageStatus( String messageId, AsyncCallback responder ) { try { if( messageId == null ) throw new IllegalArgumentException( ExceptionMessage.NULL_MESSAGE_ID ); Invoker.invokeAsync( MESSAGING_MANAGER_SERVER_ALIAS, "getMessageStatus", new Object[] { messageId }, responder ); } catch( Throwable e ) { if( responder != null ) responder.handleFault( new BackendlessFault( e ) ); } } public boolean cancel( String messageId ) { if( messageId == null ) throw new IllegalArgumentException( ExceptionMessage.NULL_MESSAGE_ID ); MessageStatus cancel = Invoker.invokeSync( MESSAGING_MANAGER_SERVER_ALIAS, "cancel", new Object[] { messageId } ); return cancel.getStatus() == PublishStatusEnum.CANCELLED; } public void cancel( String messageId, AsyncCallback responder ) { try { if( messageId == null ) throw new IllegalArgumentException( ExceptionMessage.NULL_MESSAGE_ID ); Invoker.invokeAsync( MESSAGING_MANAGER_SERVER_ALIAS, "cancel", new Object[] { messageId }, responder ); } catch( Throwable e ) { if( responder != null ) responder.handleFault( new BackendlessFault( e ) ); } } public Channel subscribe() { return subscribe( DEFAULT_CHANNEL_NAME ); } public Channel subscribe( String channelName ) { return chanelFactory.create( channelName ); } public List pollMessages( String channelName, String subscriptionId ) { checkChannelName( channelName ); if( subscriptionId == null ) throw new IllegalArgumentException( ExceptionMessage.NULL_SUBSCRIPTION_ID ); Object[] result = Invoker.invokeSync( MESSAGING_MANAGER_SERVER_ALIAS, "pollMessages", new Object[] { channelName, subscriptionId } ); return result.length == 0 ? new ArrayList() : Arrays.asList( (Message[]) result ); } protected void pollMessages( String channelName, String subscriptionId, final AsyncCallback> responder ) { try { checkChannelName( channelName ); if( subscriptionId == null ) throw new IllegalArgumentException( ExceptionMessage.NULL_SUBSCRIPTION_ID ); Invoker.invokeAsync( MESSAGING_MANAGER_SERVER_ALIAS, "pollMessages", new Object[] { channelName, subscriptionId }, new AsyncCallback() { @Override public void handleResponse( Object[] response ) { if( responder != null ) responder.handleResponse( response.length == 0 ? new ArrayList() : Arrays.asList( (Message[]) response ) ); } @Override public void handleFault( BackendlessFault fault ) { if( responder != null ) responder.handleFault( fault ); } } ); } catch( Throwable e ) { if( responder != null ) responder.handleFault( new BackendlessFault( e ) ); } } public MessageStatus sendTextEmail( String subject, String messageBody, List recipients ) { return sendEmail( subject, new BodyParts( messageBody, null ), recipients, new ArrayList() ); } public MessageStatus sendTextEmail( String subject, String messageBody, String recipient ) { return sendEmail( subject, new BodyParts( messageBody, null ), Arrays.asList( recipient ), new ArrayList() ); } public MessageStatus sendHTMLEmail( String subject, String messageBody, List recipients ) { return sendEmail( subject, new BodyParts( null, messageBody ), recipients, new ArrayList() ); } public MessageStatus sendHTMLEmail( String subject, String messageBody, String recipient ) { return sendEmail( subject, new BodyParts( null, messageBody ), Arrays.asList( recipient ), new ArrayList() ); } public MessageStatus sendEmail( String subject, BodyParts bodyParts, String recipient, List attachments ) { return sendEmail( subject, bodyParts, Arrays.asList( recipient ), attachments ); } public MessageStatus sendEmail( String subject, BodyParts bodyParts, String recipient ) { return sendEmail( subject, bodyParts, Arrays.asList( recipient ), new ArrayList() ); } public MessageStatus sendEmail( String subject, BodyParts bodyParts, List recipients, List attachments ) { if( subject == null ) throw new IllegalArgumentException( ExceptionMessage.NULL_SUBJECT ); if( bodyParts == null ) throw new IllegalArgumentException( ExceptionMessage.NULL_BODYPARTS ); if( recipients == null || recipients.isEmpty() ) throw new IllegalArgumentException( ExceptionMessage.NULL_RECIPIENTS ); if( attachments == null ) throw new IllegalArgumentException( ExceptionMessage.NULL_ATTACHMENTS ); return Invoker.invokeSync( EMAIL_MANAGER_SERVER_ALIAS, "send", new Object[] { subject, bodyParts, recipients, attachments } ); } public void sendTextEmail( String subject, String messageBody, List recipients, final AsyncCallback responder ) { sendEmail( subject, new BodyParts( messageBody, null ), recipients, new ArrayList(), responder ); } public void sendTextEmail( String subject, String messageBody, String recipient, final AsyncCallback responder ) { sendEmail( subject, new BodyParts( messageBody, null ), Arrays.asList( recipient ), new ArrayList(), responder ); } public void sendHTMLEmail( String subject, String messageBody, List recipients, final AsyncCallback responder ) { sendEmail( subject, new BodyParts( null, messageBody ), recipients, new ArrayList(), responder ); } public void sendHTMLEmail( String subject, String messageBody, String recipient, final AsyncCallback responder ) { sendEmail( subject, new BodyParts( null, messageBody ), Arrays.asList( recipient ), new ArrayList(), responder ); } public void sendEmail( String subject, BodyParts bodyParts, String recipient, List attachments, final AsyncCallback responder ) { sendEmail( subject, bodyParts, Arrays.asList( recipient ), attachments, responder ); } public void sendEmail( String subject, BodyParts bodyParts, String recipient, final AsyncCallback responder ) { sendEmail( subject, bodyParts, Arrays.asList( recipient ), new ArrayList(), responder ); } public void sendEmail( String subject, BodyParts bodyParts, List recipients, List attachments, final AsyncCallback responder ) { try { if( subject == null ) throw new IllegalArgumentException( ExceptionMessage.NULL_SUBJECT ); if( bodyParts == null ) throw new IllegalArgumentException( ExceptionMessage.NULL_BODYPARTS ); if( recipients == null || recipients.isEmpty() ) throw new IllegalArgumentException( ExceptionMessage.NULL_RECIPIENTS ); if( attachments == null ) throw new IllegalArgumentException( ExceptionMessage.NULL_ATTACHMENTS ); Invoker.invokeAsync( EMAIL_MANAGER_SERVER_ALIAS, "send", new Object[] { subject, bodyParts, recipients, attachments }, responder ); } catch( Throwable e ) { if( responder != null ) responder.handleFault( new BackendlessFault( e ) ); } } public MessageStatus sendEmailFromTemplate( String templateName, EmailEnvelope envelope ) { return sendEmailFromTemplate( templateName, envelope, (Map) null ); } public MessageStatus sendEmailFromTemplate( String templateName, EmailEnvelope envelope, Map templateValues ) { return sendEmailFromTemplate( templateName, envelope, templateValues, new ArrayList() ); } public MessageStatus sendEmailFromTemplate( String templateName, EmailEnvelope envelope, List attachments ) { return sendEmailFromTemplate( templateName, envelope, null, attachments ); } public MessageStatus sendEmailFromTemplate( String templateName, EmailEnvelope envelope, Map templateValues, List attachments ) { if( templateName == null || templateName.isEmpty() ) throw new IllegalArgumentException( ExceptionMessage.NULL_EMPTY_TEMPLATE_NAME ); if( envelope == null ) throw new IllegalArgumentException( ExceptionMessage.NULL_EMAIL_ENVELOPE ); return Invoker.invokeSync( EMAIL_TEMPLATE_SENDER_SERVER_ALIAS, "sendEmails", new Object[] { templateName, envelope, templateValues, attachments } ); } public void sendEmailFromTemplate( String templateName, EmailEnvelope envelope, AsyncCallback responder ) { sendEmailFromTemplate( templateName, envelope, (Map) null, responder ); } public void sendEmailFromTemplate( String templateName, EmailEnvelope envelope, Map templateValues, AsyncCallback responder ) { sendEmailFromTemplate( templateName, envelope, templateValues, new ArrayList(), responder ); } public void sendEmailFromTemplate( String templateName, EmailEnvelope envelope, List attachments, AsyncCallback responder ) { sendEmailFromTemplate( templateName, envelope, null, attachments, responder ); } public void sendEmailFromTemplate( String templateName, EmailEnvelope envelope, Map templateValues, List attachments, AsyncCallback responder ) { try { if( templateName == null || templateName.isEmpty() ) throw new IllegalArgumentException( ExceptionMessage.NULL_EMPTY_TEMPLATE_NAME ); if( envelope == null ) throw new IllegalArgumentException( ExceptionMessage.NULL_EMAIL_ENVELOPE ); Invoker.invokeAsync( EMAIL_TEMPLATE_SENDER_SERVER_ALIAS, "sendEmails", new Object[] { templateName, envelope, templateValues, attachments }, responder ); } catch( Throwable e ) { if( responder != null ) responder.handleFault( new BackendlessFault( e ) ); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy