/*
*
* Copyright 2005 AgileTec s.r.l. (http://www.agiletec.it) All rights reserved.
*
* This file is part of jAPS software.
* jAPS is a free software;
* you can redistribute it and/or modify it
* under the terms of the GNU General Public License (GPL) as published by the Free Software Foundation; version 2.
*
* See the file License for the specific language governing permissions
* and limitations under the License
*
*
*
* Copyright 2005 AgileTec s.r.l. (http://www.agiletec.it) All rights reserved.
*
*/
package com.agiletec.aps.system.services.category;
import java.util.List;
import com.agiletec.aps.system.common.tree.ITreeNodeManager;
import com.agiletec.aps.system.exception.ApsSystemException;
/**
* Interfaccia base per i Manager delegati alla gestione delle categorie.
* @author E.Santoboni
*/
public interface ICategoryManager extends ITreeNodeManager {
/**
* Aggiunge una categoria al db.
* @param category La categoria da aggiungere.
* @throws ApsSystemException In caso di errore nell'accesso al db.
*/
public void addCategory(Category category) throws ApsSystemException;
/**
* Cancella una categoria.
* @param code Il codice della categoria da eliminare.
* @throws ApsSystemException in caso di errore nell'accesso al db.
*/
public void deleteCategory(String code) throws ApsSystemException;
/**
* Aggiorna una categoria nel db.
* @param category La categoria da modificare.
* @throws ApsSystemException In caso di errore nell'accesso al db.
*/
public void updateCategory(Category category) throws ApsSystemException;
/**
* Restituisce la radice dell'albero delle categorie
* @return la categoria radice
*/
public Category getRoot();
/**
* Restituisce la categoria corrispondente al codice immesso.
* @param categoryCode Il codice della categoria da restituire.
* @return La categoria richiesta.
*/
public Category getCategory(String categoryCode);
/**
* Restituisce una lista piatta delle categorie disponibili,
* ordinate secondo la gerarchia dell'albero delle categorie.
* La categoria root non viene inclusa nella lista.
* @return La lista piatta delle categorie disponibili.
*/
public List<Category> getCategoriesList();
}