Move default TenantResolver registration in hawkbit-core (#2778)
Signed-off-by: Avgustin Marinov <Avgustin.Marinov@bosch.com>
This commit is contained in:
@@ -17,10 +17,7 @@ import io.micrometer.common.KeyValue;
|
||||
import io.micrometer.common.KeyValues;
|
||||
import io.micrometer.core.instrument.Tag;
|
||||
import io.micrometer.observation.ObservationRegistry;
|
||||
import lombok.AccessLevel;
|
||||
import lombok.NoArgsConstructor;
|
||||
import lombok.NonNull;
|
||||
import org.eclipse.hawkbit.tenancy.TenantAware.TenantResolver;
|
||||
import org.springframework.beans.factory.ObjectProvider;
|
||||
import org.springframework.boot.actuate.autoconfigure.observation.ObservationProperties;
|
||||
import org.springframework.boot.actuate.autoconfigure.observation.web.servlet.WebMvcObservationAutoConfiguration;
|
||||
@@ -29,35 +26,48 @@ import org.springframework.boot.actuate.metrics.data.RepositoryTagsProvider;
|
||||
import org.springframework.boot.autoconfigure.AutoConfiguration;
|
||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnBean;
|
||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
|
||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
|
||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
|
||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnWebApplication;
|
||||
import org.springframework.boot.autoconfigure.security.SecurityProperties;
|
||||
import org.springframework.boot.web.servlet.FilterRegistrationBean;
|
||||
import org.springframework.context.annotation.Bean;
|
||||
import org.springframework.context.annotation.Primary;
|
||||
import org.springframework.data.repository.core.support.RepositoryMethodInvocationListener.RepositoryMethodInvocation;
|
||||
import org.springframework.data.repository.core.support.RepositoryMethodInvocationListener;
|
||||
import org.springframework.http.server.observation.DefaultServerRequestObservationConvention;
|
||||
import org.springframework.http.server.observation.ServerRequestObservationContext;
|
||||
import org.springframework.http.server.observation.ServerRequestObservationConvention;
|
||||
import org.springframework.web.filter.ServerHttpObservationFilter;
|
||||
|
||||
@NoArgsConstructor(access = AccessLevel.PRIVATE)
|
||||
public class TenantMetricsConfiguration {
|
||||
@AutoConfiguration
|
||||
public class DefaultTenantConfiguration {
|
||||
|
||||
public static final String TENANT_TAG = "tenant";
|
||||
|
||||
@Bean
|
||||
@ConditionalOnMissingBean
|
||||
TenantAware.TenantResolver tenantResolver() {
|
||||
return new TenantAware.DefaultTenantResolver();
|
||||
}
|
||||
|
||||
@Bean
|
||||
@ConditionalOnMissingBean
|
||||
TenantAwareCacheManager cacheManager() {
|
||||
return TenantAwareCacheManager.getInstance();
|
||||
}
|
||||
|
||||
@AutoConfiguration(afterName = {
|
||||
"org.springframework.boot.actuate.autoconfigure.observation.ObservationAutoConfiguration",
|
||||
"org.eclipse.hawkbit.autoconfigure.security.SecurityAutoConfiguration" })
|
||||
@ConditionalOnProperty(name = "hawkbit.metrics.tenancy.web.enabled", havingValue = "true", matchIfMissing = true)
|
||||
@ConditionalOnWebApplication(type = ConditionalOnWebApplication.Type.SERVLET)
|
||||
@ConditionalOnClass(name = { "org.springframework.web.servlet.DispatcherServlet", "io.micrometer.observation.Observation" })
|
||||
@ConditionalOnBean({ ObservationRegistry.class, TenantResolver.class })
|
||||
@ConditionalOnBean({ ObservationRegistry.class, TenantAware.TenantResolver.class })
|
||||
public static class WebConfig {
|
||||
|
||||
@Bean
|
||||
@Primary
|
||||
public DefaultServerRequestObservationConvention serverRequestObservationConvention(final TenantResolver tenantResolver) {
|
||||
public DefaultServerRequestObservationConvention serverRequestObservationConvention(final TenantAware.TenantResolver tenantResolver) {
|
||||
return new DefaultServerRequestObservationConvention() {
|
||||
|
||||
@NonNull
|
||||
@@ -94,15 +104,15 @@ public class TenantMetricsConfiguration {
|
||||
@ConditionalOnClass(name = {
|
||||
"io.micrometer.core.instrument.Tag",
|
||||
"org.springframework.data.repository.core.support.RepositoryMethodInvocationListener" })
|
||||
@ConditionalOnBean(TenantResolver.class)
|
||||
@ConditionalOnBean(TenantAware.TenantResolver.class)
|
||||
public static class RepositoryConfig {
|
||||
|
||||
@Bean
|
||||
public RepositoryTagsProvider repositoryTagsProvider(final TenantResolver tenantResolver) {
|
||||
public RepositoryTagsProvider repositoryTagsProvider(final TenantAware.TenantResolver tenantResolver) {
|
||||
return new DefaultRepositoryTagsProvider() {
|
||||
|
||||
@Override
|
||||
public Iterable<Tag> repositoryTags(final RepositoryMethodInvocation invocation) {
|
||||
public Iterable<Tag> repositoryTags(final RepositoryMethodInvocationListener.RepositoryMethodInvocation invocation) {
|
||||
final Iterable<Tag> defaultTags = super.repositoryTags(invocation);
|
||||
final String tenant = Optional.ofNullable(tenantResolver.resolveTenant()).orElse("n/a");
|
||||
return () -> {
|
||||
@@ -1,24 +0,0 @@
|
||||
/**
|
||||
* Copyright (c) 2025 Contributors to the Eclipse Foundation
|
||||
*
|
||||
* This program and the accompanying materials are made
|
||||
* available under the terms of the Eclipse Public License 2.0
|
||||
* which is available at https://www.eclipse.org/legal/epl-2.0/
|
||||
*
|
||||
* SPDX-License-Identifier: EPL-2.0
|
||||
*/
|
||||
package org.eclipse.hawkbit.tenancy;
|
||||
|
||||
import lombok.AccessLevel;
|
||||
import lombok.NoArgsConstructor;
|
||||
import org.springframework.context.annotation.Bean;
|
||||
import org.springframework.context.annotation.Configuration;
|
||||
|
||||
@Configuration
|
||||
public class TenantCacheConfiguration {
|
||||
|
||||
@Bean
|
||||
TenantAwareCacheManager cacheManager() {
|
||||
return TenantAwareCacheManager.getInstance();
|
||||
}
|
||||
}
|
||||
@@ -1,3 +1,3 @@
|
||||
org.eclipse.hawkbit.tenancy.TenantCacheConfiguration
|
||||
org.eclipse.hawkbit.tenancy.TenantMetricsConfiguration.WebConfig
|
||||
org.eclipse.hawkbit.tenancy.TenantMetricsConfiguration.RepositoryConfig
|
||||
org.eclipse.hawkbit.tenancy.DefaultTenantConfiguration
|
||||
org.eclipse.hawkbit.tenancy.DefaultTenantConfiguration.WebConfig
|
||||
org.eclipse.hawkbit.tenancy.DefaultTenantConfiguration.RepositoryConfig
|
||||
|
||||
Reference in New Issue
Block a user