001    /*
002     * ----------------------------------------------------------------------
003     * Copyright (C) 2009 Enrique Lara (k957@68k.org)
004     *
005     * TinLizard is free software; you can redistribute it and/or
006     * modify it under the terms of the GNU Lesser General Public License
007     * as published by the Free Software Foundation; either version 3.0
008     * of the License, or (at your option) any later version.
009     *
010     * TinLizard is distributed in the hope that it will be useful,
011     * but WITHOUT ANY WARRANTY; without even the implied warranty of
012     * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
013     * GNU Lesser General Public License for more details.
014     *
015     * You should have received a copy of the GNU Lesser General Public License
016     * along with TinLizard. If not, see http://www.gnu.org/licenses/.
017     * ----------------------------------------------------------------------
018     */
019    package tinlizard.dao;
020    
021    import java.io.File;
022    import java.io.Writer;
023    import java.util.Locale;
024    
025    /**
026     * Dao to permit mashing-in external, customizable, templates and resources.
027     */
028    public interface MashDao {
029        /** The Plexus role identifier. */
030        String ROLE = MashDao.class.getName();
031    
032        File getResourcesFile(String path);
033    
034        void applyTemplate(Object it, String template, Writer out, Locale locale, String username);
035    }