/* =============================================================================== * * 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.cms.applications.workflowtool.function; import java.util.HashMap; import java.util.Map; import com.opensymphony.workflow.WorkflowException; /** * */ public abstract class CategoryProvider extends InfoglueFunction { /** * */ public static final String CATEGORIES_PARAMETER = "categories"; /** * */ private Map categories; /** * Method used for initializing the function; will be called before <code>execute</code> is called. * <p><strong>Note</strong>! You must call <code>super.initialize()</code> first.</p> * * @throws WorkflowException if an error occurs during the initialization. */ protected void initialize() throws WorkflowException { super.initialize(); if(parameterExists(CATEGORIES_PARAMETER)) { categories = (Map) getParameter(CATEGORIES_PARAMETER); } else { categories = new HashMap(); setParameter(CATEGORIES_PARAMETER, categories); } } /** * */ protected Map getCategories() { return categories; } }