/* * Jitsi, the OpenSource Java VoIP and Instant Messaging client. * * Distributable under LGPL license. * See terms of license at gnu.org. */ package net.java.sip.communicator.plugin.dnsconfig; import java.util.*; import net.java.sip.communicator.service.gui.*; import net.java.sip.communicator.util.*; import org.jitsi.service.configuration.*; import org.jitsi.service.fileaccess.*; import org.osgi.framework.*; /** * OSGi bundle activator for the parallel DNS configuration form. * * @author Ingo Bauersachs */ public class DnsConfigActivator implements BundleActivator { /** * Indicates if the DNS configuration form should be disabled, i.e. * not visible to the user. */ private static final String DISABLED_PROP = "net.java.sip.communicator.plugin.dnsconfig.DISABLED"; static BundleContext bundleContext; private static FileAccessService fileAccessService; private ServiceRegistration configForm = null; /** * The ConfigurationService registered in {@link #bundleContext} * and used by the SecurityConfigActivator instance to read and * write configuration properties. */ private static ConfigurationService configurationService; /** * Starts this bundle. * @param bc the bundle context * @throws Exception if something goes wrong */ public void start(BundleContext bc) throws Exception { bundleContext = bc; Dictionary properties = new Hashtable(); properties.put(ConfigurationForm.FORM_TYPE, ConfigurationForm.ADVANCED_TYPE); // Checks if the dns configuration form is disabled. if(!getConfigurationService().getBoolean(DISABLED_PROP, false)) { configForm = bc.registerService( ConfigurationForm.class.getName(), new LazyConfigurationForm( DnsContainerPanel.class.getName(), getClass().getClassLoader(), "plugin.dnsconfig.ICON", "plugin.dnsconfig.TITLE", 2000, true), properties); } } /** * Stops this bundle. * @param bc the bundle context * @throws Exception if something goes wrong */ public void stop(BundleContext bc) throws Exception { if(configForm != null) { configForm.unregister(); } } /** * Returns the FileAccessService obtained from the bundle context. * * @return the FileAccessService obtained from the bundle context */ public static FileAccessService getFileAccessService() { if (fileAccessService == null) { fileAccessService = ServiceUtils.getService( bundleContext, FileAccessService.class); } return fileAccessService; } /** * 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; } }