Coverage Report - org.kuali.rice.ken.bo.NotificationChannel
 
Classes in this File Line Coverage Branch Coverage Complexity
NotificationChannel
0%
0/36
N/A
1
 
 1  
 /*
 2  
  * Copyright 2007-2008 The Kuali Foundation
 3  
  * 
 4  
  * Licensed under the Educational Community License, Version 2.0 (the "License");
 5  
  * you may not use this file except in compliance with the License.
 6  
  * You may obtain a copy of the License at
 7  
  * 
 8  
  * http://www.opensource.org/licenses/ecl2.php
 9  
  * 
 10  
  * Unless required by applicable law or agreed to in writing, software
 11  
  * distributed under the License is distributed on an "AS IS" BASIS,
 12  
  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 13  
  * See the License for the specific language governing permissions and
 14  
  * limitations under the License.
 15  
  */
 16  
 package org.kuali.rice.ken.bo;
 17  
 
 18  
 import java.util.ArrayList;
 19  
 import java.util.List;
 20  
 
 21  
 import javax.persistence.CascadeType;
 22  
 import javax.persistence.Column;
 23  
 import javax.persistence.Entity;
 24  
 import javax.persistence.FetchType;
 25  
 import javax.persistence.Id;
 26  
 import javax.persistence.JoinColumn;
 27  
 import javax.persistence.JoinTable;
 28  
 import javax.persistence.ManyToMany;
 29  
 import javax.persistence.OneToMany;
 30  
 import javax.persistence.Table;
 31  
 import javax.persistence.Transient;
 32  
 
 33  
 /**
 34  
  * This class represents and instance of a Notification Channel. A Notification Channel is correlated to a specific class of
 35  
  * notification, or in other words a specific business purpose. For instance, all overdue books from a specific library could
 36  
  * be a channel or a channel for concerts coming to campus could be another channel.
 37  
  * 
 38  
  * @author Kuali Rice Team (rice.collab@kuali.org)
 39  
  */
 40  
 @Entity
 41  
 @Table(name = "KREN_CHNL_T")
 42  
 public class NotificationChannel {
 43  
     @Id
 44  
     @Column(name = "CHNL_ID")
 45  
     private Long id;
 46  
     @Column(name = "NM", nullable = false)
 47  
     private String name;
 48  
     @Column(name = "DESC_TXT", nullable = false)
 49  
     private String description;
 50  
     @Column(name = "SUBSCRB_IND", nullable = false)
 51  
     private boolean subscribable;
 52  
 
 53  
     // List references
 54  
     @OneToMany(cascade = {CascadeType.PERSIST, CascadeType.REMOVE, CascadeType.MERGE}, targetEntity = org.kuali.rice.ken.bo.NotificationRecipientList.class, mappedBy = "channel")
 55  
     private List<NotificationRecipientList> recipientLists;
 56  
     @ManyToMany(fetch = FetchType.EAGER, cascade = {CascadeType.PERSIST, CascadeType.MERGE})
 57  
     @JoinTable(name = "NOTIFICATION_CHANNEL_PRODUCERS", joinColumns = @JoinColumn(name = "CHNL_ID"), inverseJoinColumns = @JoinColumn(name = "PRODCR_ID"))
 58  
     private List<NotificationProducer> producers;
 59  0
     @Transient
 60  
     private List<NotificationChannelReviewer> reviewers = new ArrayList<NotificationChannelReviewer>();
 61  0
     @Transient
 62  
     private List<UserChannelSubscription> subscriptions = new ArrayList<UserChannelSubscription>();
 63  
 
 64  
     /**
 65  
      * Constructs a NotificationChannel instance.
 66  
      */
 67  
     public NotificationChannel() {
 68  0
         super();
 69  0
         recipientLists = new ArrayList<NotificationRecipientList>();
 70  0
         producers = new ArrayList<NotificationProducer>();
 71  0
     }
 72  
 
 73  
     /**
 74  
      * Gets the recipientLists attribute.
 75  
      * 
 76  
      * @return Returns the recipientLists.
 77  
      */
 78  
     public List<NotificationRecipientList> getRecipientLists() {
 79  0
         return recipientLists;
 80  
     }
 81  
 
 82  
     /**
 83  
      * Sets the recipientLists attribute value.
 84  
      * 
 85  
      * @param recipientLists
 86  
      *            The recipientLists to set.
 87  
      */
 88  
     public void setRecipientLists(List<NotificationRecipientList> recipientLists) {
 89  0
         this.recipientLists = recipientLists;
 90  0
     }
 91  
 
 92  
     /**
 93  
      * This method adds a recipient list to the overall set of recipient lists that are associated with this channnel.
 94  
      * 
 95  
      * @param recipientList
 96  
      */
 97  
     public void addRecipientList(NotificationRecipientList recipientList) {
 98  0
         this.recipientLists.add(recipientList);
 99  0
     }
 100  
 
 101  
     /**
 102  
      * This method removes a recipient list object from the overall list.
 103  
      * 
 104  
      * @param recipientList
 105  
      */
 106  
     public void removeRecipientList(NotificationRecipientList recipientList) {
 107  0
         this.recipientLists.remove(recipientList);
 108  0
     }
 109  
 
 110  
     /**
 111  
      * Gets the description attribute.
 112  
      * 
 113  
      * @return Returns the description.
 114  
      */
 115  
     public String getDescription() {
 116  0
         return description;
 117  
     }
 118  
 
 119  
     /**
 120  
      * Sets the description attribute value.
 121  
      * 
 122  
      * @param description
 123  
      *            The description to set.
 124  
      */
 125  
     public void setDescription(String description) {
 126  0
         this.description = description;
 127  0
     }
 128  
 
 129  
     /**
 130  
      * Gets the id attribute.
 131  
      * 
 132  
      * @return Returns the id.
 133  
      */
 134  
     public Long getId() {
 135  0
         return id;
 136  
     }
 137  
 
 138  
     /**
 139  
      * Sets the id attribute value.
 140  
      * 
 141  
      * @param id
 142  
      *            The id to set.
 143  
      */
 144  
     public void setId(Long id) {
 145  0
         this.id = id;
 146  0
     }
 147  
 
 148  
     /**
 149  
      * Gets the name attribute.
 150  
      * 
 151  
      * @return Returns the name.
 152  
      */
 153  
     public String getName() {
 154  0
         return name;
 155  
     }
 156  
 
 157  
     /**
 158  
      * Sets the name attribute value.
 159  
      * 
 160  
      * @param name
 161  
      *            The name to set.
 162  
      */
 163  
     public void setName(String name) {
 164  0
         this.name = name;
 165  0
     }
 166  
 
 167  
     /**
 168  
      * Gets the subscribable attribute.
 169  
      * 
 170  
      * @return Returns the subscribable.
 171  
      */
 172  
     public boolean isSubscribable() {
 173  0
         return subscribable;
 174  
     }
 175  
 
 176  
     /**
 177  
      * Sets the subscribable attribute value.
 178  
      * 
 179  
      * @param subscribable
 180  
      *            The subscribable to set.
 181  
      */
 182  
     public void setSubscribable(boolean subscribable) {
 183  0
         this.subscribable = subscribable;
 184  0
     }
 185  
 
 186  
     /**
 187  
      * Gets the producers attribute.
 188  
      * 
 189  
      * @return Returns the producers.
 190  
      */
 191  
     public List<NotificationProducer> getProducers() {
 192  0
         return producers;
 193  
     }
 194  
 
 195  
     /**
 196  
      * Sets the producers attribute value.
 197  
      * 
 198  
      * @param producers
 199  
      *            The producers to set.
 200  
      */
 201  
     public void setProducers(List<NotificationProducer> producers) {
 202  0
         this.producers = producers;
 203  0
     }
 204  
 
 205  
     /**
 206  
      * Gets the list of reviewers for notification publications to this channel
 207  
      * 
 208  
      * @return the list of reviewers for notification publications to this channel
 209  
      */
 210  
     public List<NotificationChannelReviewer> getReviewers() {
 211  0
         return reviewers;
 212  
     }
 213  
 
 214  
     /**
 215  
      * Sets the list of reviewers for notification publications to this channel
 216  
      * 
 217  
      * @param reviewers
 218  
      *            the list of reviewers for notification publications to this channel
 219  
      */
 220  
     public void setReviewers(List<NotificationChannelReviewer> reviewers) {
 221  0
         this.reviewers = reviewers;
 222  0
     }
 223  
 
 224  
     /**
 225  
      * Gets the list of subscriptions to this channel
 226  
      * 
 227  
      * @return the list of subscriptions to this channel
 228  
      */
 229  
     public List<UserChannelSubscription> getSubscriptions() {
 230  0
         return subscriptions;
 231  
     }
 232  
 
 233  
     /**
 234  
      * Sets the list of subscriptions to this channel
 235  
      * 
 236  
      * @param subscriptions
 237  
      *            the list of subscriptions to this channel
 238  
      */
 239  
     public void setSubscriptions(List<UserChannelSubscription> subscriptions) {
 240  0
         this.subscriptions = subscriptions;
 241  0
     }
 242  
 
 243  
     /**
 244  
      * Compares the id values of each NotificationChannel object.
 245  
      * 
 246  
      * @see java.lang.Object#equals(java.lang.Object)
 247  
      */
 248  
     @Override
 249  
     public boolean equals(Object obj) {
 250  0
         NotificationChannel channelToCompare = (NotificationChannel) obj;
 251  0
         return this.getId().equals(channelToCompare.getId());
 252  
     }
 253  
 
 254  
 }