001    /**
002     * Copyright 2005-2013 The Kuali Foundation
003     *
004     * Licensed under the Educational Community License, Version 2.0 (the "License");
005     * you may not use this file except in compliance with the License.
006     * You may obtain a copy of the License at
007     *
008     * http://www.opensource.org/licenses/ecl2.php
009     *
010     * Unless required by applicable law or agreed to in writing, software
011     * distributed under the License is distributed on an "AS IS" BASIS,
012     * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013     * See the License for the specific language governing permissions and
014     * limitations under the License.
015     */
016    package org.kuali.rice.ken.api.notification;
017    
018    import java.io.Serializable;
019    import java.util.ArrayList;
020    import java.util.Collection;
021    import java.util.List;
022    import javax.xml.bind.annotation.XmlAccessType;
023    import javax.xml.bind.annotation.XmlAccessorType;
024    import javax.xml.bind.annotation.XmlAnyElement;
025    import javax.xml.bind.annotation.XmlElement;
026    import javax.xml.bind.annotation.XmlElementWrapper;
027    import javax.xml.bind.annotation.XmlRootElement;
028    import javax.xml.bind.annotation.XmlType;
029    import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
030    
031    import org.apache.commons.collections.CollectionUtils;
032    import org.joda.time.DateTime;
033    import org.kuali.rice.core.api.CoreConstants;
034    import org.kuali.rice.core.api.mo.AbstractDataTransferObject;
035    import org.kuali.rice.core.api.mo.ModelBuilder;
036    import org.kuali.rice.core.api.util.jaxb.DateTimeAdapter;
037    import org.w3c.dom.Element;
038    
039    @XmlRootElement(name = Notification.Constants.ROOT_ELEMENT_NAME)
040    @XmlAccessorType(XmlAccessType.NONE)
041    @XmlType(name = Notification.Constants.TYPE_NAME, propOrder = {
042            Notification.Elements.PRIORITY,
043            Notification.Elements.CONTENT,
044            Notification.Elements.CHANNEL,
045            Notification.Elements.CONTENT_TYPE,
046            Notification.Elements.CREATION_DATE_TIME,
047            Notification.Elements.RECIPIENTS,
048            Notification.Elements.SENDERS,
049            Notification.Elements.AUTO_REMOVE_DATE_TIME,
050            Notification.Elements.DELIVERY_TYPE,
051            Notification.Elements.PRODUCER,
052            Notification.Elements.SEND_DATE_TIME,
053            Notification.Elements.PROCESSING_FLAG,
054            Notification.Elements.LOCKED_DATE,
055            Notification.Elements.TITLE,
056            Notification.Elements.CONTENT_MESSAGE,
057            Notification.Elements.ID,
058            CoreConstants.CommonElements.VERSION_NUMBER,
059            CoreConstants.CommonElements.OBJECT_ID,
060            CoreConstants.CommonElements.FUTURE_ELEMENTS
061    })
062    public final class Notification
063            extends AbstractDataTransferObject
064            implements NotificationContract
065    {
066    
067        @XmlElement(name = Elements.PRIORITY, required = false)
068        private final NotificationPriority priority;
069        @XmlElement(name = Elements.CONTENT, required = false)
070        private final String content;
071        @XmlElement(name = Elements.CHANNEL, required = false)
072        private final NotificationChannel channel;
073        @XmlElement(name = Elements.CONTENT_TYPE, required = false)
074        private final NotificationContentType contentType;
075        @XmlElement(name = Elements.CREATION_DATE_TIME, required = false)
076        @XmlJavaTypeAdapter(DateTimeAdapter.class)
077        private final DateTime creationDateTime;
078        @XmlElementWrapper(name = Elements.RECIPIENTS, required = false)
079        @XmlElement(name = Elements.RECIPIENT, required = false)
080        private final List<NotificationRecipient> recipients;
081        @XmlElementWrapper(name = Elements.SENDERS, required = false)
082        @XmlElement(name = Elements.SENDER, required = false)
083        private final List<NotificationSender> senders;
084        @XmlElement(name = Elements.AUTO_REMOVE_DATE_TIME, required = false)
085        @XmlJavaTypeAdapter(DateTimeAdapter.class)
086        private final DateTime autoRemoveDateTime;
087        @XmlElement(name = Elements.DELIVERY_TYPE, required = false)
088        private final String deliveryType;
089        @XmlElement(name = Elements.PRODUCER, required = false)
090        private final NotificationProducer producer;
091        @XmlElement(name = Elements.SEND_DATE_TIME, required = false)
092        @XmlJavaTypeAdapter(DateTimeAdapter.class)
093        private final DateTime sendDateTime;
094        @XmlElement(name = Elements.PROCESSING_FLAG, required = false)
095        private final String processingFlag;
096        @XmlElement(name = Elements.LOCKED_DATE, required = false)
097        @XmlJavaTypeAdapter(DateTimeAdapter.class)
098        private final DateTime lockedDate;
099        @XmlElement(name = Elements.TITLE, required = false)
100        private final String title;
101        @XmlElement(name = Elements.CONTENT_MESSAGE, required = false)
102        private final String contentMessage;
103        @XmlElement(name = Elements.ID, required = false)
104        private final Long id;
105        @XmlElement(name = CoreConstants.CommonElements.VERSION_NUMBER, required = false)
106        private final Long versionNumber;
107        @XmlElement(name = CoreConstants.CommonElements.OBJECT_ID, required = false)
108        private final String objectId;
109        @SuppressWarnings("unused")
110        @XmlAnyElement
111        private final Collection<Element> _futureElements = null;
112    
113        /**
114         * Private constructor used only by JAXB.
115         *
116         */
117        private Notification() {
118            this.priority = null;
119            this.content = null;
120            this.channel = null;
121            this.contentType = null;
122            this.creationDateTime = null;
123            this.recipients = null;
124            this.senders = null;
125            this.autoRemoveDateTime = null;
126            this.deliveryType = null;
127            this.producer = null;
128            this.sendDateTime = null;
129            this.processingFlag = null;
130            this.lockedDate = null;
131            this.title = null;
132            this.contentMessage = null;
133            this.id = null;
134            this.versionNumber = null;
135            this.objectId = null;
136        }
137    
138        private Notification(Builder builder) {
139            this.priority = builder.getPriority() == null ? null : builder.getPriority().build();
140            this.content = builder.getContent();
141            this.channel = builder.getChannel() == null ? null : builder.getChannel().build();
142            this.contentType = builder.getContentType() == null ? null : builder.getContentType().build();
143            this.creationDateTime = builder.getCreationDateTime();
144            this.recipients = new ArrayList<NotificationRecipient>();
145            if (CollectionUtils.isNotEmpty(builder.getRecipients())) {
146                for (NotificationRecipient.Builder recipient : builder.getRecipients()) {
147                    this.recipients.add(recipient.build());
148                }
149            }
150            this.senders = new ArrayList<NotificationSender>();
151            if (CollectionUtils.isNotEmpty(builder.getSenders())) {
152                for (NotificationSender.Builder sender : builder.getSenders()) {
153                    this.senders.add(sender.build());
154                }
155            }
156            this.autoRemoveDateTime = builder.getAutoRemoveDateTime();
157            this.deliveryType = builder.getDeliveryType();
158            this.producer = builder.getProducer() == null ? null : builder.getProducer().build();
159            this.sendDateTime = builder.getSendDateTime();
160            this.processingFlag = builder.getProcessingFlag();
161            this.lockedDate = builder.getLockedDate();
162            this.title = builder.getTitle();
163            this.contentMessage = builder.getContentMessage();
164            this.id = builder.getId();
165            this.versionNumber = builder.getVersionNumber();
166            this.objectId = builder.getObjectId();
167        }
168    
169        @Override
170        public NotificationPriority getPriority() {
171            return this.priority;
172        }
173    
174        @Override
175        public String getContent() {
176            return this.content;
177        }
178    
179        @Override
180        public NotificationChannel getChannel() {
181            return this.channel;
182        }
183    
184        @Override
185        public NotificationContentType getContentType() {
186            return this.contentType;
187        }
188    
189        @Override
190        public DateTime getCreationDateTime() {
191            return this.creationDateTime;
192        }
193    
194        @Override
195        public List<NotificationRecipient> getRecipients() {
196            return this.recipients;
197        }
198    
199        @Override
200        public List<NotificationSender> getSenders() {
201            return this.senders;
202        }
203    
204        @Override
205        public DateTime getAutoRemoveDateTime() {
206            return this.autoRemoveDateTime;
207        }
208    
209        @Override
210        public String getDeliveryType() {
211            return this.deliveryType;
212        }
213    
214        @Override
215        public NotificationProducer getProducer() {
216            return this.producer;
217        }
218    
219        @Override
220        public DateTime getSendDateTime() {
221            return this.sendDateTime;
222        }
223    
224        @Override
225        public String getProcessingFlag() {
226            return this.processingFlag;
227        }
228    
229        @Override
230        public DateTime getLockedDate() {
231            return this.lockedDate;
232        }
233    
234        @Override
235        public String getTitle() {
236            return this.title;
237        }
238    
239        @Override
240        public String getContentMessage() {
241            return this.contentMessage;
242        }
243    
244        @Override
245        public Long getId() {
246            return this.id;
247        }
248    
249        @Override
250        public Long getVersionNumber() {
251            return this.versionNumber;
252        }
253    
254        @Override
255        public String getObjectId() {
256            return this.objectId;
257        }
258    
259    
260        /**
261         * A builder which can be used to construct {@link Notification} instances.  Enforces the constraints of the {@link NotificationContract}.
262         *
263         */
264        public final static class Builder
265                implements Serializable, ModelBuilder, NotificationContract
266        {
267    
268            private NotificationPriority.Builder priority;
269            private String content;
270            private NotificationChannel.Builder channel;
271            private NotificationContentType.Builder contentType;
272            private DateTime creationDateTime;
273            private List<NotificationRecipient.Builder> recipients;
274            private List<NotificationSender.Builder> senders;
275            private DateTime autoRemoveDateTime;
276            private String deliveryType;
277            private NotificationProducer.Builder producer;
278            private DateTime sendDateTime;
279            private String processingFlag;
280            private DateTime lockedDate;
281            private String title;
282            private String contentMessage;
283            private Long id;
284            private Long versionNumber;
285            private String objectId;
286    
287            private Builder() {
288                // TODO modify this constructor as needed to pass any required values and invoke the appropriate 'setter' methods
289            }
290    
291            public static Builder create() {
292                // TODO modify as needed to pass any required values and add them to the signature of the 'create' method
293                return new Builder();
294            }
295    
296            public static Builder create(NotificationContract contract) {
297                if (contract == null) {
298                    throw new IllegalArgumentException("contract was null");
299                }
300                // TODO if create() is modified to accept required parameters, this will need to be modified
301                Builder builder = create();
302                builder.setPriority(contract.getPriority() == null ? null : NotificationPriority.Builder.create(contract.getPriority()));
303                builder.setContent(contract.getContent());
304                builder.setChannel(contract.getChannel() == null ? null : NotificationChannel.Builder.create(contract.getChannel()));
305                builder.setContentType(contract.getContentType() == null ? null : NotificationContentType.Builder.create(contract.getContentType()));
306                builder.setCreationDateTime(contract.getCreationDateTime());
307                if (contract.getRecipients() != null) {
308                    List<NotificationRecipient.Builder> tempRecipients = new ArrayList<NotificationRecipient.Builder>();
309                    for (NotificationRecipientContract recipient : contract.getRecipients()) {
310                        tempRecipients.add(NotificationRecipient.Builder.create(recipient));
311                    }
312                    builder.setRecipients(tempRecipients);
313                }
314                if (contract.getSenders() != null) {
315                    List<NotificationSender.Builder> tempSenders = new ArrayList<NotificationSender.Builder>();
316                    for (NotificationSenderContract sender : contract.getSenders()) {
317                        tempSenders.add(NotificationSender.Builder.create(sender));
318                    }
319                    builder.setSenders(tempSenders);
320                }
321                builder.setAutoRemoveDateTime(contract.getAutoRemoveDateTime());
322                builder.setDeliveryType(contract.getDeliveryType());
323                builder.setProducer(contract.getProducer() == null ? null : NotificationProducer.Builder.create(contract.getProducer()));
324                builder.setSendDateTime(contract.getSendDateTime());
325                builder.setProcessingFlag(contract.getProcessingFlag());
326                builder.setLockedDate(contract.getLockedDate());
327                builder.setTitle(contract.getTitle());
328                builder.setContentMessage(contract.getContentMessage());
329                builder.setId(contract.getId());
330                builder.setVersionNumber(contract.getVersionNumber());
331                builder.setObjectId(contract.getObjectId());
332                return builder;
333            }
334    
335            public Notification build() {
336                return new Notification(this);
337            }
338    
339            @Override
340            public NotificationPriority.Builder getPriority() {
341                return this.priority;
342            }
343    
344            @Override
345            public String getContent() {
346                return this.content;
347            }
348    
349            @Override
350            public NotificationChannel.Builder getChannel() {
351                return this.channel;
352            }
353    
354            @Override
355            public NotificationContentType.Builder getContentType() {
356                return this.contentType;
357            }
358    
359            @Override
360            public DateTime getCreationDateTime() {
361                return this.creationDateTime;
362            }
363    
364            @Override
365            public List<NotificationRecipient.Builder> getRecipients() {
366                return this.recipients;
367            }
368    
369            @Override
370            public List<NotificationSender.Builder> getSenders() {
371                return this.senders;
372            }
373    
374            @Override
375            public DateTime getAutoRemoveDateTime() {
376                return this.autoRemoveDateTime;
377            }
378    
379            @Override
380            public String getDeliveryType() {
381                return this.deliveryType;
382            }
383    
384            @Override
385            public NotificationProducer.Builder getProducer() {
386                return this.producer;
387            }
388    
389            @Override
390            public DateTime getSendDateTime() {
391                return this.sendDateTime;
392            }
393    
394            @Override
395            public String getProcessingFlag() {
396                return this.processingFlag;
397            }
398    
399            @Override
400            public DateTime getLockedDate() {
401                return this.lockedDate;
402            }
403    
404            @Override
405            public String getTitle() {
406                return this.title;
407            }
408    
409            @Override
410            public String getContentMessage() {
411                return this.contentMessage;
412            }
413    
414            @Override
415            public Long getId() {
416                return this.id;
417            }
418    
419            @Override
420            public Long getVersionNumber() {
421                return this.versionNumber;
422            }
423    
424            @Override
425            public String getObjectId() {
426                return this.objectId;
427            }
428    
429            public void setPriority(NotificationPriority.Builder priority) {
430                this.priority = priority;
431            }
432    
433            public void setContent(String content) {
434                this.content = content;
435            }
436    
437            public void setChannel(NotificationChannel.Builder channel) {
438                this.channel = channel;
439            }
440    
441            public void setContentType(NotificationContentType.Builder contentType) {
442                this.contentType = contentType;
443            }
444    
445            public void setCreationDateTime(DateTime creationDateTime) {
446                this.creationDateTime = creationDateTime;
447            }
448    
449            public void setRecipients(List<NotificationRecipient.Builder> recipients) {
450                this.recipients = recipients;
451            }
452    
453            public void setSenders(List<NotificationSender.Builder> senders) {
454                this.senders = senders;
455            }
456    
457            public void setAutoRemoveDateTime(DateTime autoRemoveDateTime) {
458                this.autoRemoveDateTime = autoRemoveDateTime;
459            }
460    
461            public void setDeliveryType(String deliveryType) {
462                this.deliveryType = deliveryType;
463            }
464    
465            public void setProducer(NotificationProducer.Builder producer) {
466                this.producer = producer;
467            }
468    
469            public void setSendDateTime(DateTime sendDateTime) {
470                this.sendDateTime = sendDateTime;
471            }
472    
473            public void setProcessingFlag(String processingFlag) {
474                this.processingFlag = processingFlag;
475            }
476    
477            public void setLockedDate(DateTime lockedDate) {
478                this.lockedDate = lockedDate;
479            }
480    
481            public void setTitle(String title) {
482                this.title = title;
483            }
484    
485            public void setContentMessage(String contentMessage) {
486                this.contentMessage = contentMessage;
487            }
488    
489            public void setId(Long id) {
490                this.id = id;
491            }
492    
493            public void setVersionNumber(Long versionNumber) {
494                this.versionNumber = versionNumber;
495            }
496    
497            public void setObjectId(String objectId) {
498                this.objectId = objectId;
499            }
500    
501        }
502    
503    
504        /**
505         * Defines some internal constants used on this class.
506         *
507         */
508        static class Constants {
509    
510            final static String ROOT_ELEMENT_NAME = "notification";
511            final static String TYPE_NAME = "NotificationType";
512    
513        }
514    
515    
516        /**
517         * A private class which exposes constants which define the XML element names to use when this object is marshalled to XML.
518         *
519         */
520        static class Elements {
521    
522            final static String PRIORITY = "priority";
523            final static String CONTENT = "content";
524            final static String CHANNEL = "channel";
525            final static String CONTENT_TYPE = "contentType";
526            final static String CREATION_DATE_TIME = "creationDateTime";
527            final static String LOCK_VER_NBR = "lockVerNbr";
528            final static String RECIPIENTS = "recipients";
529            final static String RECIPIENT = "recipient";
530            final static String SENDERS = "senders";
531            final static String SENDER = "sender";
532            final static String AUTO_REMOVE_DATE_TIME = "autoRemoveDateTime";
533            final static String DELIVERY_TYPE = "deliveryType";
534            final static String PRODUCER = "producer";
535            final static String SEND_DATE_TIME = "sendDateTime";
536            final static String PROCESSING_FLAG = "processingFlag";
537            final static String LOCKED_DATE = "lockedDate";
538            final static String TITLE = "title";
539            final static String CONTENT_MESSAGE = "contentMessage";
540            final static String ID = "id";
541    
542        }
543    
544    }