/*
* 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;
}
}