View Javadoc

1   /*
2    * Copyright 2006-2008 the original author or authors.
3    * 
4    * Licensed under the Apache License, Version 2.0 (the "License");
5    * you may not use this file except in compliance with the License.
6    * You may obtain a copy of the License at
7    * 
8    *      http://www.apache.org/licenses/LICENSE-2.0
9    * 
10   * Unless required by applicable law or agreed to in writing, software
11   * distributed under the License is distributed on an "AS IS" BASIS,
12   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13   * See the License for the specific language governing permissions and
14   * limitations under the License.
15   *
16   * Created on 25-Jan-2006 by Adrian Colyer
17   */
18  
19  package org.springframework.osgi.service.exporter;
20  
21  import java.util.Map;
22  
23  /**
24   * An OsgiServicePropertiesResolver is responsible for providing the properties
25   * that a bean exposed as a service will be published with.
26   * 
27   * @author Adrian Colyer
28   * 
29   * @see org.springframework.osgi.service.exporter.support.OsgiServiceFactoryBean
30   */
31  public interface OsgiServicePropertiesResolver {
32  
33  	/**
34  	 * Predefined property indicating the bean name of an exported Spring
35  	 * managed object.
36  	 */
37  	String BEAN_NAME_PROPERTY_KEY = "org.springframework.osgi.bean.name";
38  
39  
40  	/**
41  	 * Returns a map containing the service properties associated with the given
42  	 * Spring managed bean identified by its name.
43  	 * 
44  	 * @param beanName Spring managed bean name
45  	 * @return map containing the service properties
46  	 */
47  	Map getServiceProperties(String beanName);
48  
49  }