blob: deb212fa3e206ce7e1d47c7bcc3752ed59a8f84d [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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 org.apache.felix.scr.impl.config;
import java.io.InputStream;
import java.util.ArrayList;
import org.apache.felix.scr.impl.manager.ScrConfiguration;
import org.osgi.service.metatype.AttributeDefinition;
import org.osgi.service.metatype.MetaTypeProvider;
import org.osgi.service.metatype.ObjectClassDefinition;
/**
* The <code>ScrManagedServiceMetaTypeProvider</code> receives the Declarative
* Services Runtime configuration (by extending the {@link ScrManagedService}
* class.
* <p>
* This class is instantiated in a ServiceFactory manner by the
* {@link ScrManagedServiceServiceFactory} when the Configuration Admin service
* implementation and API is available
* <p>
* Requires OSGi Metatype Service API available
*
* @see ScrManagedServiceServiceFactory
*/
class ScrMetaTypeProvider implements MetaTypeProvider
{
private final ScrConfiguration configuration;
public ScrMetaTypeProvider(final ScrConfiguration scrConfiguration)
{
this.configuration = scrConfiguration;
}
/**
* @see org.osgi.service.metatype.MetaTypeProvider#getLocales()
*/
@Override
public String[] getLocales()
{
return null;
}
/**
* @see org.osgi.service.metatype.MetaTypeProvider#getObjectClassDefinition(java.lang.String, java.lang.String)
*/
@Override
public ObjectClassDefinition getObjectClassDefinition( String id, String locale )
{
if ( !ScrConfiguration.PID.equals( id ) )
{
return null;
}
final ArrayList<AttributeDefinition> adList = new ArrayList<>();
adList.add(new AttributeDefinitionImpl(ScrConfiguration.PROP_LOGLEVEL, "SCR Log Level",
"Allows limiting the amount of logging information sent to the OSGi LogService."
+ " Supported values are DEBUG, INFO, WARN, and ERROR. This property is not used"
+ " if a R7 LogService implementation is available as the log level can be configured"
+ " through that service. Default is ERROR.", AttributeDefinition.INTEGER,
new String[]
{ String.valueOf(this.configuration.getLogLevel()) }, 0, new String[]
{ "Debug", "Information", "Warnings", "Error" }, new String[]
{ "4", "3", "2", "1" }));
adList
.add(new AttributeDefinitionImpl(
ScrConfiguration.PROP_FACTORY_ENABLED,
"Extended Factory Components",
"Whether or not to enable the support for creating Factory Component instances based on factory configuration."
+ " This is an Apache Felix SCR specific extension, explicitly not supported by the Declarative Services "
+ "specification. Reliance on this feature prevent the component from being used with other Declarative "
+ "Services implementations. The default value is false to disable this feature.", this
.configuration.isFactoryEnabled()));
adList.add( new AttributeDefinitionImpl(
ScrConfiguration.PROP_DELAYED_KEEP_INSTANCES,
"Keep Component Instances",
"Whether or not to keep instances of delayed components once they are not referred to any more. The "
+ "Declarative Services specifications suggests that instances of delayed components are disposed off "
+ "if there is not used any longer. Setting this flag causes the components to not be disposed off "
+ "and thus prevent them from being constantly recreated if often used. Examples of such components "
+ "may be EventHandler services. The default is to dispose of unused components.", this
.configuration.keepInstances() ) );
adList.add( new AttributeDefinitionImpl(
ScrConfiguration.PROP_LOCK_TIMEOUT,
"Lock timeout milliseconds",
"How long a lock is held before releasing due to suspected deadlock",
AttributeDefinition.LONG,
new String[] { String.valueOf(this.configuration.lockTimeout())},
0, null, null) );
adList.add( new AttributeDefinitionImpl(
ScrConfiguration.PROP_STOP_TIMEOUT,
"Stop timeout milliseconds",
"How long stopping a bundle is waited for before continuing due to suspected deadlock",
AttributeDefinition.LONG,
new String[] { String.valueOf(this.configuration.stopTimeout())},
0, null, null) );
adList.add( new AttributeDefinitionImpl(
ScrConfiguration.PROP_GLOBAL_EXTENDER,
"Global Extender",
"Whether to extend all bundles whether or not visible to this bundle.",
false ) );
return new ObjectClassDefinition()
{
private final AttributeDefinition[] attrs = adList
.toArray(new AttributeDefinition[adList.size()]);
@Override
public String getName()
{
return "Apache Felix Declarative Service Implementation";
}
@Override
public InputStream getIcon(int arg0)
{
return null;
}
@Override
public String getID()
{
return ScrConfiguration.PID;
}
@Override
public String getDescription()
{
return "Configuration for the Apache Felix Declarative Services Implementation."
+ " This configuration overwrites configuration defined in framework properties of the same names.";
}
@Override
public AttributeDefinition[] getAttributeDefinitions(int filter)
{
return (filter == OPTIONAL) ? null : attrs;
}
};
}
private static class AttributeDefinitionImpl implements AttributeDefinition
{
private final String id;
private final String name;
private final String description;
private final int type;
private final String[] defaultValues;
private final int cardinality;
private final String[] optionLabels;
private final String[] optionValues;
AttributeDefinitionImpl( final String id, final String name, final String description, final boolean defaultValue )
{
this( id, name, description, BOOLEAN, new String[]
{ String.valueOf(defaultValue) }, 0, null, null );
}
AttributeDefinitionImpl( final String id, final String name, final String description, final int type,
final String[] defaultValues, final int cardinality, final String[] optionLabels,
final String[] optionValues )
{
this.id = id;
this.name = name;
this.description = description;
this.type = type;
this.defaultValues = defaultValues;
this.cardinality = cardinality;
this.optionLabels = optionLabels;
this.optionValues = optionValues;
}
@Override
public int getCardinality()
{
return cardinality;
}
@Override
public String[] getDefaultValue()
{
return defaultValues;
}
@Override
public String getDescription()
{
return description;
}
@Override
public String getID()
{
return id;
}
@Override
public String getName()
{
return name;
}
@Override
public String[] getOptionLabels()
{
return optionLabels;
}
@Override
public String[] getOptionValues()
{
return optionValues;
}
@Override
public int getType()
{
return type;
}
@Override
public String validate( String arg0 )
{
return null;
}
}
}