/* This file is part of OpenMyEWB. OpenMyEWB is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. OpenMyEWB is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even 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 OpenMyEWB. If not, see <http://www.gnu.org/licenses/>. OpenMyEWB is Copyright 2005-2009 Nicolas Kruchten (nicolas@kruchten.com), Francis Kung, Engineers Without Borders Canada, Michael Trauttmansdorff, Jon Fishbein, David Kadish */ package ca.myewb.controllers.actions.csv; import java.util.HashSet; import java.util.Iterator; import java.util.List; import java.util.Set; import java.util.Vector; import org.apache.velocity.context.Context; import ca.myewb.frame.Controller; import ca.myewb.frame.RedirectionException; import ca.myewb.frame.SafeHibList; import ca.myewb.model.GroupChapterModel; import ca.myewb.model.GroupModel; import ca.myewb.model.UserModel; public class ExecContactListCsv extends Controller { public void handle(Context ctx) throws Exception { GroupModel list = (GroupModel)getAndCheckFromUrl(GroupModel.class); if (!(list.getAdmin() && list.getVisible())) { throw getSecurityException("Invalid request", path + "/mailing/Mailing"); } List<UserModel> leaders = (new SafeHibList<UserModel>(hibernateSession.createQuery("SELECT u FROM UserModel u, RoleModel r " + "WHERE r.user=u AND r.group.id=? AND r.end IS NULL GROUP BY u") .setInteger(0, list.getId()))) .list(); Vector<String[]> csvData = new Vector<String[]>(); csvData.add(new String[]{"First Name", "Last Name", "Email", "Phone", "Title", "Chapter"}); Iterator listMembers = leaders.iterator(); while (listMembers.hasNext()) { UserModel theMember = (UserModel)listMembers.next(); String chapterName = ""; GroupChapterModel chapter = theMember.getChapter(); if (chapter != null) { chapterName = chapter.getName(); } csvData.add(new String[] { theMember.getFirstname(), theMember.getLastname(), theMember.getEmail(), theMember.getPhone(), theMember.getExecTitle(), chapterName }); } try { this.setInterpageVar("csvData", csvData); this.setInterpageVar("csvFileName", "execlist.csv"); } catch(IllegalStateException e) { //session timeout! throw new IllegalStateException("Session timeout on CSV!", e); } throw new RedirectionException(path + "/csvfile/execlist.csv"); } public Set<String> invisibleGroups() { Set<String> s = new HashSet<String>(); s.add("Exec"); return s; } public String oldName() { return "ExecContactListCsv"; } }