/* * Jitsi, the OpenSource Java VoIP and Instant Messaging client. * * Copyright @ 2015 Atlassian Pty Ltd * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package net.java.sip.communicator.plugin.contactsourceconfig; import java.util.*; import net.java.sip.communicator.plugin.securityconfig.*; import net.java.sip.communicator.service.gui.*; import net.java.sip.communicator.service.resources.*; import net.java.sip.communicator.util.*; import org.jitsi.service.configuration.*; import org.jitsi.service.resources.*; import org.osgi.framework.*; /** * @author Yana Stamcheva */ public class ContactSourceConfigActivator implements BundleActivator { /** * Indicates if the contact source config form should be disabled, i.e. * not visible to the user. */ private static final String DISABLED_PROP = "net.java.sip.communicator.plugin.contactsourceconfig.DISABLED"; /** * The {@link BundleContext} of the {@link ContactSourceConfigActivator}. */ public static BundleContext bundleContext; /** * The {@link ResourceManagementService} of the * {@link SecurityConfigActivator}. Can also be obtained from the * {@link SecurityConfigActivator#bundleContext} on demand, but we add it * here for convenience. */ private static ResourceManagementService resources; /** * The <tt>ConfigurationService</tt> registered in {@link #bundleContext} * and used by the <tt>SecurityConfigActivator</tt> instance to read and * write configuration properties. */ private static ConfigurationService configurationService; /** * The <tt>UIService</tt> registered in {@link #bundleContext}. */ private static UIService uiService; /** * Starts this plugin. * @param bc the BundleContext * @throws Exception if some of the operations executed in the start method * fails */ public void start(BundleContext bc) throws Exception { bundleContext = bc; Dictionary<String, String> properties = new Hashtable<String, String>(); // Registers the contact source panel as advanced configuration form. properties.put( ConfigurationForm.FORM_TYPE, ConfigurationForm.ADVANCED_TYPE); // Checks if the context source configuration form is disabled. if(!getConfigurationService().getBoolean(DISABLED_PROP, false)) { bundleContext.registerService( ConfigurationForm.class.getName(), new LazyConfigurationForm( ContactSourceConfigForm.class.getName(), getClass().getClassLoader(), null, "plugin.contactsourceconfig.CONTACT_SOURCE_TITLE", 101, true), properties); } } /** * Invoked when this bundle is stopped. * @param bc the BundleContext * @throws Exception if some of the operations executed in the start method * fails */ public void stop(BundleContext bc) throws Exception {} /** * Returns a reference to the ResourceManagementService implementation * currently registered in the bundle context or null if no such * implementation was found. * * @return a currently valid implementation of the ResourceManagementService */ public static ResourceManagementService getResources() { if (resources == null) { resources = ResourceManagementServiceUtils.getService(bundleContext); } return resources; } /** * Returns a reference to the ConfigurationService implementation currently * registered in the bundle context or null if no such implementation was * found. * * @return a currently valid implementation of the ConfigurationService. */ public static ConfigurationService getConfigurationService() { if (configurationService == null) { configurationService = ServiceUtils.getService( bundleContext, ConfigurationService.class); } return configurationService; } /** * Gets the <tt>UIService</tt> instance registered in the * <tt>BundleContext</tt> of the <tt>SecurityConfigActivator</tt>. * * @return the <tt>UIService</tt> instance registered in the * <tt>BundleContext</tt> of the <tt>SecurityConfigActivator</tt> */ public static UIService getUIService() { if (uiService == null) uiService = ServiceUtils.getService(bundleContext, UIService.class); return uiService; } }