/*
* Copyright (c) 2009-2011 Lockheed Martin Corporation
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.eurekastreams.server.domain;
import java.io.Serializable;
import javax.persistence.Basic;
import javax.persistence.Column;
import javax.persistence.Embeddable;
import javax.persistence.EmbeddedId;
import javax.persistence.Entity;
import org.eurekastreams.commons.model.WrappedLightEntity;
/**
* Object representing the person following a group relationship.
*/
@Entity
public class GroupFollower extends WrappedLightEntity implements Serializable
{
/**
* Serial version uid.
*/
private static final long serialVersionUID = 2197093976396575034L;
/**
* Instance of FollowerPk (Composite primary key object) for this class.
*/
@EmbeddedId
private GroupFollowerPk pk = null;
/**
* Index of the followed group in the list of followed groups for the follower.
*/
@Basic
private int groupStreamIndex = 0;
/**
* Whether to receive notifications after new activities are posted to this group.
*/
@Basic
@Column(name="receiveNewActivityNotification")
private Boolean receiveNewActivityNotifications = true;
/**
* Constructor.
*
* @param inFollowerId
* Follower id.
* @param inFollowingId
* Following id (id of Object being followed).
*/
public GroupFollower(final long inFollowerId, final long inFollowingId)
{
pk = new GroupFollowerPk(inFollowerId, inFollowingId);
}
/**
* Constructor (no-op for ORM).
*/
@SuppressWarnings("unused")
private GroupFollower()
{
}
/**
* FollowerId getter.
*
* @return Follower id.
*/
public long getFollowerId()
{
return pk.getFollowerId();
}
/**
* FollowingId getter.
*
* @return Following id (id of Object being followed).
*/
public long getFollowingId()
{
return pk.getFollowingId();
}
/**
* @param inGroupStreamIndex
* the group stream index to set
*/
public void setGroupStreamIndex(final int inGroupStreamIndex)
{
groupStreamIndex = inGroupStreamIndex;
}
/**
* @return the group stream index
*/
public int getGroupStreamIndex()
{
return groupStreamIndex;
}
/**
* @return the receiveNewActivityNotifications
*/
public boolean getReceiveNewActivityNotifications()
{
return receiveNewActivityNotifications;
}
/**
* @param inReceiveNewActivityNotifications
* the receiveNewActivityNotifications to set
*/
public void setReceiveNewActivityNotifications(final boolean inReceiveNewActivityNotifications)
{
receiveNewActivityNotifications = inReceiveNewActivityNotifications;
}
/**
* Composite primary key for follower.
*
*/
@Embeddable
public static class GroupFollowerPk implements Serializable
{
/**
* Serial version uid.
*/
private static final long serialVersionUID = -6415173783140689235L;
/**
* Follower id.
*/
@Basic
private long followerId = 0;
/**
* Following id (id of Object being followed).
*/
@Basic
private long followingId = 0;
/**
* Constructor.
*
* @param inFollowerId
* Follower id.
* @param inFollowingId
* Following id (id of Object being followed).
*/
public GroupFollowerPk(final long inFollowerId, final long inFollowingId)
{
followerId = inFollowerId;
followingId = inFollowingId;
}
/**
* Constructor (no-op for ORM).
*/
@SuppressWarnings("unused")
private GroupFollowerPk()
{
}
/**
* FollowerId getter.
*
* @return Follower id.
*/
public long getFollowerId()
{
return followerId;
}
/**
* FollowingId getter.
*
* @return Following id (id of Object being followed).
*/
public long getFollowingId()
{
return followingId;
}
/**
* Override hashCode for comparing pk object.
*
* @return The generated hashcode.
*/
@Override
public int hashCode()
{
int hashCode = 0;
hashCode ^= (new Long(followerId)).hashCode();
hashCode ^= (new Long(followingId)).hashCode();
return hashCode;
}
/**
* Override equals for comparing pk object.
*
* @param obj
* The object to compare to this one.
* @return True if obj is equal to this one, false otherwise.
*/
@Override
public boolean equals(final Object obj)
{
if (!(obj instanceof GroupFollowerPk))
{
return false;
}
GroupFollowerPk target = (GroupFollowerPk) obj;
return (target.followingId == followingId) && (target.followerId == followerId);
}
}
/**
* Enumeration for follower/following relationship status.
*
*/
public static enum GroupFollowerStatus implements Serializable
{
/**
* Follower/Following relationship is not specified.
*/
NOTSPECIFIED,
/**
* Follower/Following relationship is not allowed.
*/
DISABLED,
/**
* Follower/Following relationship is established.
*/
FOLLOWING,
/**
* Follower/Following relationship is not established.
*/
NOTFOLLOWING,
}
}