All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.sakaiproject.signup.model.SignupMeeting Maven / Gradle / Ivy

/**
 * Copyright (c) 2007-2014 The Apereo Foundation
 *
 * Licensed under the Educational Community 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://opensource.org/licenses/ecl2
 *
 * 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.
 */
/*
* Licensed to The Apereo Foundation under one or more contributor license
* agreements. See the NOTICE file distributed with this work for
* additional information regarding copyright ownership.
*
* The Apereo Foundation licenses this file to you under the Educational 
* Community 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://opensource.org/licenses/ecl2.txt
* 
* 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.sakaiproject.signup.model;

import java.util.ArrayList;
import java.util.Calendar;
import java.util.Date;
import java.util.List;
import java.util.StringTokenizer;
import java.util.UUID;

import org.sakaiproject.signup.logic.Permission;
import org.sakaiproject.signup.logic.SignupMessageTypes;

import lombok.AccessLevel;
import lombok.Getter;
import lombok.Setter;

/**
 * 

* This class holds the information for signup meeting/event. This object is * mapped directly to the DB storage by Hibernate *

*/ /** * @author gl256 * */ @Getter @Setter public class SignupMeeting implements MeetingTypes, SignupMessageTypes { private Long id; private Long recurrenceId; @SuppressWarnings("unused") private int version; private String title; private String description; private String location; private String category; /* sakai user id */ private String creatorUserId; private String coordinatorIds; private Date startTime; private Date endTime; private Date signupBegins; private Date signupDeadline; private boolean canceled; private boolean locked; private String meetingType; /*once,daily,weekdays,weekly,biweekly */ private String repeatType; private boolean allowWaitList; private boolean allowComment; private boolean autoReminder; private boolean eidInputMode; private boolean receiveEmailByOwner; private boolean sendEmailByOwner; private List signupTimeSlots; private List signupSites; private List signupAttachments; private Permission permission; //private boolean emailAttendeesOnly = false; private String sendEmailToSelectedPeopleOnly; private boolean allowAttendance; private boolean createGroups; private Integer maxNumOfSlots; //numbers of occurrences private int repeatNum; private boolean applyToAllRecurMeetings; /* For RESTful case to pass siteId for email*/ private String currentSiteId; private Calendar cal = Calendar.getInstance(); private Date repeatUntil; private boolean inMultipleCalendarBlocks = false; /** * ICS VEvent created for this meeting */ private net.fortuna.ical4j.model.component.VEvent vevent; /** * For tracking the event so that we can issue updates, persisted, generated once, never updated. */ @Setter(AccessLevel.PRIVATE) private String uuid; public SignupMeeting() { //set the meeting UUID only at construction time uuid = UUID.randomUUID().toString(); } /** * get how many slots allowed for one user to sign in in this meeting * * @return Integer. */ public Integer getMaxNumOfSlots() { if(maxNumOfSlots == null){ maxNumOfSlots= new Integer(1);//default } return maxNumOfSlots; } /** * special setter. * * @param endTime * the end time of the event/meeting */ public void setEndTime(Date endTime) { this.endTime = truncateSeconds(endTime); } /** * This method obtains the number of time slots in the event/meeting * * @return the number of time slots */ public int getNoOfTimeSlots() { return (signupTimeSlots == null) ? 0 : signupTimeSlots.size(); } /** * special setter * * @param signupBegins * a time when the signup process starts */ public void setSignupBegins(Date signupBegins) { this.signupBegins = truncateSeconds(signupBegins); } /** * special setter * * @param signupDeadLine * the time when signup process stops */ public void setSignupDeadline(Date signupDeadLine) { this.signupDeadline = truncateSeconds(signupDeadLine); } /** * special setter * * @param startTime * the time when the event/meeting starts */ public void setStartTime(Date startTime) { this.startTime = truncateSeconds(startTime); } /** * get the maximum nubmer of the attendees, which is allowed in one time * slot * * @return the maximum nubmer of the attendees */ public int getMaxNumberOfAttendees() { if (signupTimeSlots == null || signupTimeSlots.isEmpty()) { return 0; } return signupTimeSlots.get(0).getMaxNoOfAttendees(); } /** * test if two event/meeting objects are equal */ public boolean equals(Object object) { if (object == null || !(object instanceof SignupMeeting)) { return false; } SignupMeeting other = (SignupMeeting) object; if (id == null) { return false; } return id.equals(other.getId()); } @Override public int hashCode() { final int prime = 31; int result = 1; result = prime * result + ((description == null) ? 0 : description.hashCode()); result = prime * result + ((id == null) ? 0 : id.hashCode()); result = prime * result + ((title == null) ? 0 : title.hashCode()); return result; } /** * This method will obtain the SignupTimeslot object according to the * timeslot Id * * @param timeslotId * a timeslot Id * @return a SignupTimeslot object */ public SignupTimeslot getTimeslot(Long timeslotId) { if (signupTimeSlots == null) { return null; } for (SignupTimeslot timeslot : signupTimeSlots) { if (timeslot.getId().equals(timeslotId)) { return timeslot; } } return null; } /** * This method will obtain the number of participants signed * * @return a int */ public int getParticipantsNum() { return signupTimeSlots == null ? 0 : signupTimeSlots.stream().map(t -> t.getAttendees().size()).reduce(Integer::sum).orElse(0); } /** * This method will check if the event/meeting is already expired * * @return true if the event/meeting is expired */ public boolean isMeetingExpired() { Date today = new Date(); // pastMeeting => today>endDate => value>0 int value = today.compareTo(endTime); return value > 0; } /** * This method will check if the current time has already passed the signup * deadline * * @return true if the current time has already passed the signup deadline */ public boolean isPassedDeadline() { Date today = new Date(); int value = today.compareTo(signupDeadline); return value > 0; } /** * This will test if the event/meeting is cross days * * @return true if the event/meeting is cross days */ public boolean isMeetingCrossDays() { cal.setTime(getStartTime()); int startingDay = cal.get(Calendar.DAY_OF_YEAR); cal.setTime(getEndTime()); int endingDay = cal.get(Calendar.DAY_OF_YEAR); return (startingDay != endingDay); } /** * This will test if the event/meeting is started to sign up * * @return true if the sign-up begin time is before current time. */ public boolean isStartToSignUp() { return signupBegins.before(new Date()); } /** * Set the second value to zero. it only need to accurate to minutes level. * Otherwise it may cause one minute shorter display confusion * * @param time * a Date object * @return a Date object */ private Date truncateSeconds(Date time) { /* set second to zero */ if (time == null) { return null; } Calendar cal = Calendar.getInstance(); cal.setTime(time); cal.set(Calendar.SECOND, 0); cal.set(Calendar.MILLISECOND, 0); return cal.getTime(); } public boolean isRecurredMeeting() { if (recurrenceId != null || DAILY.equals(getRepeatType()) || WEEKLY.equals(getRepeatType()) || BIWEEKLY.equals(getRepeatType()) || WEEKDAYS.equals(getRepeatType())) { return true; } else { return false; } } public boolean hasSignupAttachments(){ if(this.signupAttachments ==null || this.signupAttachments.isEmpty()) { return false; } else { return true; } } /** * Breaks up the coordinatorIds string into a list object * @return a list of coordinator id strings */ public List getCoordinatorIdsList(){ List coUsers = new ArrayList(); if(coordinatorIds != null && coordinatorIds.trim().length()>0){ StringTokenizer userIdTokens = new StringTokenizer(coordinatorIds,"|"); while(userIdTokens.hasMoreTokens()){ String uId = userIdTokens.nextToken(); coUsers.add(uId); } } return coUsers; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy