Skip to content

Commit

Permalink
Merge pull request apache#1663, add version&group to @service annotat…
Browse files Browse the repository at this point in the history
…ion bean name.
  • Loading branch information
mercyblitz authored and chickenlj committed Apr 24, 2018
1 parent a2a7706 commit d07c64f
Showing 1 changed file with 27 additions and 4 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -71,6 +71,8 @@
public class ServiceAnnotationBeanPostProcessor implements BeanDefinitionRegistryPostProcessor, EnvironmentAware,
ResourceLoaderAware, BeanClassLoaderAware {

private static final String SEPARATOR = ":";

private final Logger logger = LoggerFactory.getLogger(getClass());

private final Set<String> packagesToScan;
Expand Down Expand Up @@ -254,7 +256,7 @@ private void registerServiceBean(BeanDefinitionHolder beanDefinitionHolder, Bean
buildServiceBeanDefinition(service, interfaceClass, annotatedServiceBeanName);

// ServiceBean Bean name
String beanName = generateServiceBeanName(interfaceClass, annotatedServiceBeanName);
String beanName = generateServiceBeanName(service, interfaceClass, annotatedServiceBeanName);

if (scanner.checkCandidate(beanName, serviceBeanDefinition)) { // check duplicated candidate bean
registry.registerBeanDefinition(beanName, serviceBeanDefinition);
Expand All @@ -279,14 +281,35 @@ private void registerServiceBean(BeanDefinitionHolder beanDefinitionHolder, Bean
/**
* Generates the bean name of {@link ServiceBean}
*
* @param service
* @param interfaceClass the class of interface annotated {@link Service}
* @param annotatedServiceBeanName the bean name of annotated {@link Service}
* @return ServiceBean@interfaceClassName#annotatedServiceBeanName
* @since 2.5.9
*/
private String generateServiceBeanName(Class<?> interfaceClass, String annotatedServiceBeanName) {
private String generateServiceBeanName(Service service, Class<?> interfaceClass, String annotatedServiceBeanName) {

StringBuilder beanNameBuilder = new StringBuilder(ServiceBean.class.getSimpleName());

beanNameBuilder.append(SEPARATOR).append(annotatedServiceBeanName);

String interfaceClassName = interfaceClass.getName();

beanNameBuilder.append(SEPARATOR).append(interfaceClassName);

String version = service.version();

if (StringUtils.hasText(version)) {
beanNameBuilder.append(SEPARATOR).append(version);
}

String group = service.group();

if (StringUtils.hasText(group)) {
beanNameBuilder.append(SEPARATOR).append(group);
}

return "ServiceBean@" + interfaceClass.getName() + "#" + annotatedServiceBeanName;
return beanNameBuilder.toString();

}

Expand Down Expand Up @@ -477,4 +500,4 @@ public void setBeanClassLoader(ClassLoader classLoader) {
this.classLoader = classLoader;
}

}
}

0 comments on commit d07c64f

Please sign in to comment.