/* ===============================================================================
*
* Part of the InfoGlue Content Management Platform (www.infoglue.org)
*
* ===============================================================================
*
* Copyright (C)
*
* This program is free software; you can redistribute it and/or modify it under
* the terms of the GNU General Public License version 2, as published by the
* Free Software Foundation. See the file LICENSE.html for more information.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY, including the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along with
* this program; if not, write to the Free Software Foundation, Inc. / 59 Temple
* Place, Suite 330 / Boston, MA 02111-1307 / USA.
*
* ===============================================================================
*/
package org.infoglue.calendar.entities;
import java.util.ArrayList;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
/**
* This class represents a single calendar object. A calendar is called upon with a key/name.
*
* @author mattias
*
* @hibernate.class table="Calendar"
*/
public class Calendar implements BaseEntity
{
private Long id;
//private String owner;
private String name;
private String description;
private Set events = new HashSet();
private Set publishedEvents = new HashSet();
private Set waitingEvents = new HashSet();
private Set workingEvents = new HashSet();
private Set subscriptions = new HashSet();
private Set languages = new HashSet();
private Set roles = new HashSet();
private Set groups = new HashSet();
private EventType eventType;
/**
* @hibernate.id generator-class="native" type="long" column="id" unsaved-value="null"
*
* @return long
*/
public Long getId()
{
return this.id;
}
public void setId(Long id)
{
this.id = id;
}
/**
* @hibernate.property name="getOwner" column="owner" type="string" not-null="false" unique="false"
*
* @return String
*/
/*
public String getOwner()
{
return owner;
}
public void setOwner(String owner)
{
this.owner = owner;
}
*/
/**
* @hibernate.property name="getName" column="name" type="string" not-null="false" unique="true"
*
* @return String
*/
public String getName()
{
return this.name;
}
public void setName(String name)
{
this.name = name;
}
/**
* @hibernate.property name="getDescription" column="description" type="string" not-null="false" unique="false"
*
* @return String
*/
public String getDescription()
{
return description;
}
public void setDescription(String description)
{
this.description = description;
}
/**
* @hibernate.set lazy="false"
* @hibernate.collection-key column="calendar_id"
* @hibernate.collection-one-to-many class="org.infoglue.calendar.entities.Event"
*
* @return Set
*/
public Set getEvents()
{
return events;
}
public void setEvents(Set events)
{
this.events = events;
}
/**
* @hibernate.set lazy="true"
* @hibernate.collection-key column="calendar_id"
* @hibernate.collection-one-to-many class="org.infoglue.calendar.entities.Event"
*
* @return Set
*/
public Set getPublishedEvents()
{
return publishedEvents;
}
public void setPublishedEvents(Set publishedEvents)
{
this.publishedEvents = publishedEvents;
}
/**
* @hibernate.set lazy="true"
* @hibernate.collection-key column="calendar_id"
* @hibernate.collection-one-to-many class="org.infoglue.calendar.entities.Event"
*
* @return Set
*/
public Set getWaitingEvents()
{
return waitingEvents;
}
public void setWaitingEvents(Set waitingEvents)
{
this.waitingEvents = waitingEvents;
}
public EventType getEventType()
{
return eventType;
}
public void setEventType(EventType eventType)
{
this.eventType = eventType;
}
/**
* @hibernate.set lazy="true"
* @hibernate.collection-key column="calendar_id"
* @hibernate.collection-one-to-many class="org.infoglue.calendar.entities.Event"
*
* @return Set
*/
public Set getWorkingEvents()
{
return workingEvents;
}
public void setWorkingEvents(Set workingEvents)
{
this.workingEvents = workingEvents;
}
/**
* @hibernate.set lazy="true"
* @hibernate.collection-key column="calendar_id"
* @hibernate.collection-one-to-many class="org.infoglue.calendar.entities.Role"
*
* @return Set
*/
public Set getOwningRoles()
{
return roles;
}
public void setOwningRoles(Set roles)
{
this.roles = roles;
}
/**
* @hibernate.set lazy="true"
* @hibernate.collection-key column="calendar_id"
* @hibernate.collection-one-to-many class="org.infoglue.calendar.entities.Group"
*
* @return Set
*/
public Set getOwningGroups()
{
return groups;
}
public void setOwningGroups(Set groups)
{
this.groups = groups;
}
/**
* @hibernate.set lazy="true"
* @hibernate.collection-key column="calendar_id"
* @hibernate.collection-one-to-many class="org.infoglue.calendar.entities.Subscriber"
*
* @return Set
*/
public Set getSubscriptions()
{
return subscriptions;
}
public void setSubscriptions(Set subscriptions)
{
this.subscriptions = subscriptions;
}
public Set getLanguages()
{
return languages;
}
public void setLanguages(Set languages)
{
this.languages = languages;
}
public String getLocalizedName(String isoCode, String fallbackIsoCode)
{
return this.getName();
}
}