/** * MailArchiver is an application that provides services for storing and managing e-mail messages through a Web Services SOAP interface. * Copyright (C) 2012 Marcio Andre Scholl Levien and Fernando Alberto Reuter Wendt and Jose Ronaldo Nogueira Fonseca Junior * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * This program 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 Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . */ /******************************************************************************\ * * This product was developed by * * SERVIÇO FEDERAL DE PROCESSAMENTO DE DADOS (SERPRO), * * a government company established under Brazilian law (5.615/70), * at Department of Development of Porto Alegre. * \******************************************************************************/ package serpro.mailarchiver.service.dto; import javax.xml.bind.annotation.XmlRootElement; import serpro.mailarchiver.domain.metaarchive.Folder; import serpro.mailarchiver.domain.metaarchive.Message; @XmlRootElement(name="Folder") public class TFolder implements Identifiable { private String id; @Override public String getId() { return id; } @Override public void setId(String id) { this.id = id; } //-------------------------------------------------------------------------- private String name; public String getName() { return name; } public void setName(String name) { this.name = name; } //-------------------------------------------------------------------------- private String path; public String getPath() { return path; } public void setPath(String path) { this.path = path; } //-------------------------------------------------------------------------- private String parentId; public String getParentId() { return parentId; } public void setParentId(String parentId) { this.parentId = parentId; } //-------------------------------------------------------------------------- private int folderCount; public int getFolderCount() { return folderCount; } public void setFolderCount(int folderCount) { this.folderCount = folderCount; } //-------------------------------------------------------------------------- private int messageCount; public int getMessageCount() { return messageCount; } public void setMessageCount(int messageCount) { this.messageCount = messageCount; } //-------------------------------------------------------------------------- private int unseenCount; public int getUnseenCount() { return unseenCount; } public void setUnseenCount(int unseenCount) { this.unseenCount = unseenCount; } //========================================================================== public TFolder() {} public TFolder(Folder folder) { id = folder.getExternalOid(); Folder parent = folder.getParent(); parentId = (parent != null) ? parent.getExternalOid() : null; name = folder.getName(); path = folder.getRelativePath().toString().replace('\\', '/'); folderCount = folder.getChildren().size(); messageCount = folder.getMessages().size(); unseenCount = 0; for(Message message : folder.getMessages()) { if(message.isUnseen()) { ++unseenCount; } } //DEBUG //System.out.println(toString()); } @Override public String toString() { return String.format( "TFolder%n" + "%1$sid: %2$s%n" + "%1$sname: %3$s%n" + "%1$spath: %4$s%n" + "%1$sparentId: %5$s%n" + "%1$sfolderCount: %6$d%n" + "%1$smessageCount: %7$d%n" + "%1$sunseenCount: %8$d" , " " , id , name , path , parentId , folderCount , messageCount , unseenCount); } }