/** * @(#)NotificationEntityDAO.java 1.0.0 11:57:57 AM * * Idega Software hf. Source Code Licence Agreement x * * This agreement, made this 10th of February 2006 by and between * Idega Software hf., a business formed and operating under laws * of Iceland, having its principal place of business in Reykjavik, * Iceland, hereinafter after referred to as "Manufacturer" and Agura * IT hereinafter referred to as "Licensee". * 1. License Grant: Upon completion of this agreement, the source * code that may be made available according to the documentation for * a particular software product (Software) from Manufacturer * (Source Code) shall be provided to Licensee, provided that * (1) funds have been received for payment of the License for Software and * (2) the appropriate License has been purchased as stated in the * documentation for Software. As used in this License Agreement, * Licensee shall also mean the individual using or installing * the source code together with any individual or entity, including * but not limited to your employer, on whose behalf you are acting * in using or installing the Source Code. By completing this agreement, * Licensee agrees to be bound by the terms and conditions of this Source * Code License Agreement. This Source Code License Agreement shall * be an extension of the Software License Agreement for the associated * product. No additional amendment or modification shall be made * to this Agreement except in writing signed by Licensee and * Manufacturer. This Agreement is effective indefinitely and once * completed, cannot be terminated. Manufacturer hereby grants to * Licensee a non-transferable, worldwide license during the term of * this Agreement to use the Source Code for the associated product * purchased. In the event the Software License Agreement to the * associated product is terminated; (1) Licensee's rights to use * the Source Code are revoked and (2) Licensee shall destroy all * copies of the Source Code including any Source Code used in * Licensee's applications. * 2. License Limitations * 2.1 Licensee may not resell, rent, lease or distribute the * Source Code alone, it shall only be distributed as a * compiled component of an application. * 2.2 Licensee shall protect and keep secure all Source Code * provided by this this Source Code License Agreement. * All Source Code provided by this Agreement that is used * with an application that is distributed or accessible outside * Licensee's organization (including use from the Internet), * must be protected to the extent that it cannot be easily * extracted or decompiled. * 2.3 The Licensee shall not resell, rent, lease or distribute * the products created from the Source Code in any way that * would compete with Idega Software. * 2.4 Manufacturer's copyright notices may not be removed from * the Source Code. * 2.5 All modifications on the source code by Licencee must * be submitted to or provided to Manufacturer. * 3. Copyright: Manufacturer's source code is copyrighted and contains * proprietary information. Licensee shall not distribute or * reveal the Source Code to anyone other than the software * developers of Licensee's organization. Licensee may be held * legally responsible for any infringement of intellectual property * rights that is caused or encouraged by Licensee's failure to abide * by the terms of this Agreement. Licensee may make copies of the * Source Code provided the copyright and trademark notices are * reproduced in their entirety on the copy. Manufacturer reserves * all rights not specifically granted to Licensee. * * 4. Warranty & Risks: Although efforts have been made to assure that the * Source Code is correct, reliable, date compliant, and technically * accurate, the Source Code is licensed to Licensee as is and without * warranties as to performance of merchantability, fitness for a * particular purpose or use, or any other warranties whether * expressed or implied. Licensee's organization and all users * of the source code assume all risks when using it. The manufacturers, * distributors and resellers of the Source Code shall not be liable * for any consequential, incidental, punitive or special damages * arising out of the use of or inability to use the source code or * the provision of or failure to provide support services, even if we * have been advised of the possibility of such damages. In any case, * the entire liability under any provision of this agreement shall be * limited to the greater of the amount actually paid by Licensee for the * Software or 5.00 USD. No returns will be provided for the associated * License that was purchased to become eligible to receive the Source * Code after Licensee receives the source code. */ package com.idega.notifier.data.dao; import java.util.Collection; import java.util.Collections; import java.util.List; import javax.ejb.EJBLocalObject; import com.idega.core.persistence.GenericDao; import com.idega.notifier.data.NotificationEntity; import com.idega.notifier.data.NotificationReceiverEntity; import com.idega.user.data.User; /** * <p>Data access object for {@link NotificationEntity}.</p> * <p>You can report about problems to: * <a href="mailto:martynas@idega.is">Martynas Stakė</a></p> * * @version 1.0.0 Apr 9, 2013 * @author <a href="mailto:martynas@idega.is">Martynas Stakė</a> */ public interface NotificationEntityDAO extends GenericDao { public static final String BEAN_NAME = "notificationEntityDAO"; /** * * <p>Creates/updates {@link NotificationEntity} if * {@link NotificationEntity#getReceiverID()} is {@link User} in data source. * </p> * @param notificationEntity to create/update, not <code>null</code>; * @return created/updated notification entity or <code>null</code> * on failure. * @author <a href="mailto:martynas@idega.com">Martynas Stakė</a> */ public NotificationEntity update(NotificationEntity notificationEntity); /** * * <p>Creates/updates {@link NotificationEntity} if * {@link NotificationEntity#getReceiverID()} is {@link User} in data source. * </p> * @param id of {@link NotificationEntity} to be updated, new one will be * created when <code>null</code>; * @param receiver, who is owner of * {@link NotificationEntity}; * @param message text to send in notification; * @param isRead or not; * @return created/updated notification entity or <code>null</code> * on failure. * @author <a href="mailto:martynas@idega.com">Martynas Stakė</a> */ public NotificationEntity update(Long id, User receiver, String message); public NotificationEntity update(Long id, Collection<User> receivers, String message); /** * * @param notificationEntity to remove, not <code>null</code>; * @return <code>true</code> if removed, <code>false</code> * otherwise. * @author <a href="mailto:martynas@idega.com">Martynas Stakė</a> */ public boolean remove(NotificationEntity notificationEntity); /** * * @param id of {@link NotificationEntity}, not <code>null</code>; * @return {@link NotificationEntity} by given id or <code>null</code> * on failure. * @author <a href="mailto:martynas@idega.com">Martynas Stakė</a> */ public NotificationEntity getNotification(long id); /** * * @param id of {@link NotificationEntity}, not <code>null</code>; * @param receiver, who is owner of * {@link NotificationEntity}, not <code>null</code>; * @return entity by given criteria or <code>null</code> on failure. * @author <a href="mailto:martynas@idega.com">Martynas Stakė</a> */ public NotificationEntity getNotification(long id, User receiver); /** * * @return all {@link NotificationEntity}s in data source. * @author <a href="mailto:martynas@idega.com">Martynas Stakė</a> */ public List<NotificationEntity> getNotifications(); /** * * @param user who is owner of * {@link NotificationEntity}s, not <code>null</code>; * @return {@link Collection} of {@link NotificationEntity} by owner id * or {@link Collections#emptyList()} on failure. * @author <a href="mailto:martynas@idega.com">Martynas Stakė</a> */ public List<NotificationEntity> getNotifications(User user); /** * * <p>Count {@link NotificationEntity}s for {@link User}, who is owner.</p> * @param receiver, who is receiver of notification; * @param isRead - is {@link Case} read or not; * @return number of notifications or <code>null</code> on failure. * @author <a href="mailto:martynas@idega.com">Martynas Stakė</a> */ public Long countNotifications(User receiver, boolean isRead); /** * * @param notificationTargetEntityId is {@link NotificationReceiverEntity#getId()}, * not <code>null</code>; * @return {@link NotificationReceiverEntity} in data source or * <code>null</code> on failure; * @author <a href="mailto:martynas@idega.com">Martynas Stakė</a> */ public NotificationReceiverEntity getNotificationReceiver( Long notificationTargetEntityId); /** * * @param user to get entity for, not <code>null</code>; * @return entity if exists; * @author <a href="mailto:martynas@idega.com">Martynas Stakė</a> */ public NotificationReceiverEntity getNotificationReceiver( User user); /** * * <p>Creates/Updates entity in data source.</p> * @param nte is entity to update/create, not <code>null</code>; * @return created or updated entity or <code>null</code> on failure;s * @author <a href="mailto:martynas@idega.com">Martynas Stakė</a> */ public NotificationReceiverEntity update(NotificationReceiverEntity nte); /** * * <p>Creates/Updates entity in data source.</p> * @param id is {@link NotificationReceiverEntity#getId()}, new entity * created when <code>null</code>; * @param receiverId is {@link EJBLocalObject#getPrimaryKey()} of entity * to notified about. Not <code>null</code> when creating new one; * @param receiverClass is instance of {@link EJBLocalObject#getClass()}, * not <code>null</code> when creating new one; * @param read is notification was read, skipped if <code>null</code>; * @return created or updated entity or <code>null</code> on failure; * @author <a href="mailto:martynas@idega.com">Martynas Stakė</a> */ public NotificationReceiverEntity update(Long id, String receiverId, Class<? extends EJBLocalObject> receiverClass, Boolean read); }