///////////////////////////////////////////////////////////////////////////// // // Project ProjectForge Community Edition // www.projectforge.org // // Copyright (C) 2001-2014 Kai Reinhard (k.reinhard@micromata.de) // // ProjectForge is dual-licensed. // // This community edition 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; version 3 of the License. // // This community edition 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 this program; if not, see http://www.gnu.org/licenses/. // ///////////////////////////////////////////////////////////////////////////// package org.projectforge.plugins.licensemanagement; import java.util.List; import org.projectforge.continuousdb.UpdateEntry; import org.projectforge.plugins.core.AbstractPlugin; import org.projectforge.registry.RegistryEntry; import org.projectforge.user.UserPrefArea; import org.projectforge.web.MenuItemDef; import org.projectforge.web.MenuItemDefId; /** * @author Kai Reinhard (k.reinhard@micromata.de) */ public class LicenseManagementPlugin extends AbstractPlugin { public static final String ID = "licenseManagement"; public static final String RESOURCE_BUNDLE_NAME = LicenseManagementPlugin.class.getPackage().getName() + ".LicenseManagementI18nResources"; static UserPrefArea USER_PREF_AREA; // The order of the entities is important for xml dump and imports as well as for test cases (order for deleting objects at the end of // each test). // The entities are inserted in ascending order and deleted in descending order. private static final Class< ? >[] PERSISTENT_ENTITIES = new Class< ? >[] { LicenseDO.class}; /** * This dao should be defined in pluginContext.xml (as resources) for proper initialization. */ private LicenseDao licenseDao; @Override public Class< ? >[] getPersistentEntities() { return PERSISTENT_ENTITIES; } /** * @see org.projectforge.plugins.core.AbstractPlugin#initialize() */ @Override protected void initialize() { // DatabaseUpdateDao is needed by the updater: LicenseManagementPluginUpdates.dao = getDatabaseUpdateDao(); final RegistryEntry entry = new RegistryEntry(ID, LicenseDao.class, licenseDao, "plugins.licensemanagement"); // The LicenseDao is automatically available by the scripting engine! register(entry); // Register the web part: registerWeb(ID, LicenseListPage.class, LicenseEditPage.class); // Register the menu entry as sub menu entry of the misc menu: final MenuItemDef parentMenu = getMenuItemDef(MenuItemDefId.MISC); registerMenuItem(new MenuItemDef(parentMenu, ID, 10, "plugins.licensemanagement.menu", LicenseListPage.class)); // Define the access management: registerRight(new LicenseManagementRight()); // All the i18n stuff: addResourceBundle(RESOURCE_BUNDLE_NAME); } /** * Setter is called by the Spring framework with a proper initialized data access object (defined in pluginContext.xml). * @param licenseDao the licenseDao to set */ public void setLicenseDao(final LicenseDao licenseDao) { this.licenseDao = licenseDao; } /** * @see org.projectforge.plugins.core.AbstractPlugin#getUpdateEntries() */ @Override public List<UpdateEntry> getUpdateEntries() { return LicenseManagementPluginUpdates.getUpdateEntries(); } /** * @see org.projectforge.plugins.core.AbstractPlugin#getInitializationUpdateEntry() */ @Override public UpdateEntry getInitializationUpdateEntry() { return LicenseManagementPluginUpdates.getInitializationUpdateEntry(); } }