diff --git a/spring-boot-actuator/pom.xml b/spring-boot-actuator/pom.xml
index cf323298cba4..10b6905d4a3d 100644
--- a/spring-boot-actuator/pom.xml
+++ b/spring-boot-actuator/pom.xml
@@ -213,6 +213,11 @@
spring-security-config
true
+
+ org.springframework.session
+ spring-session
+ true
+
org.apache.tomcat.embed
tomcat-embed-core
diff --git a/spring-boot-actuator/src/main/java/org/springframework/boot/actuate/autoconfigure/EndpointAutoConfiguration.java b/spring-boot-actuator/src/main/java/org/springframework/boot/actuate/autoconfigure/EndpointAutoConfiguration.java
index e52e2935684e..3ac5f16ab279 100644
--- a/spring-boot-actuator/src/main/java/org/springframework/boot/actuate/autoconfigure/EndpointAutoConfiguration.java
+++ b/spring-boot-actuator/src/main/java/org/springframework/boot/actuate/autoconfigure/EndpointAutoConfiguration.java
@@ -40,6 +40,7 @@
import org.springframework.boot.actuate.endpoint.MetricsEndpoint;
import org.springframework.boot.actuate.endpoint.PublicMetrics;
import org.springframework.boot.actuate.endpoint.RequestMappingEndpoint;
+import org.springframework.boot.actuate.endpoint.SessionEndpoint;
import org.springframework.boot.actuate.endpoint.ShutdownEndpoint;
import org.springframework.boot.actuate.endpoint.TraceEndpoint;
import org.springframework.boot.actuate.health.HealthAggregator;
@@ -61,6 +62,7 @@
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.annotation.AnnotationAwareOrderComparator;
+import org.springframework.session.FindByIndexNameSessionRepository;
import org.springframework.web.servlet.handler.AbstractHandlerMethodMapping;
/**
@@ -216,4 +218,17 @@ public RequestMappingEndpoint requestMappingEndpoint() {
}
+ @Configuration
+ @ConditionalOnBean(FindByIndexNameSessionRepository.class)
+ @ConditionalOnClass(FindByIndexNameSessionRepository.class)
+ static class SessionEndpointConfiguration {
+
+ @Bean
+ @ConditionalOnMissingBean
+ public SessionEndpoint sessionEndpoint() {
+ return new SessionEndpoint();
+ }
+
+ }
+
}
diff --git a/spring-boot-actuator/src/main/java/org/springframework/boot/actuate/autoconfigure/EndpointWebMvcManagementContextConfiguration.java b/spring-boot-actuator/src/main/java/org/springframework/boot/actuate/autoconfigure/EndpointWebMvcManagementContextConfiguration.java
index b3ac138bd1dd..75fc25911279 100644
--- a/spring-boot-actuator/src/main/java/org/springframework/boot/actuate/autoconfigure/EndpointWebMvcManagementContextConfiguration.java
+++ b/spring-boot-actuator/src/main/java/org/springframework/boot/actuate/autoconfigure/EndpointWebMvcManagementContextConfiguration.java
@@ -26,6 +26,7 @@
import org.springframework.boot.actuate.endpoint.EnvironmentEndpoint;
import org.springframework.boot.actuate.endpoint.HealthEndpoint;
import org.springframework.boot.actuate.endpoint.MetricsEndpoint;
+import org.springframework.boot.actuate.endpoint.SessionEndpoint;
import org.springframework.boot.actuate.endpoint.ShutdownEndpoint;
import org.springframework.boot.actuate.endpoint.mvc.EndpointHandlerMapping;
import org.springframework.boot.actuate.endpoint.mvc.EndpointHandlerMappingCustomizer;
@@ -35,6 +36,7 @@
import org.springframework.boot.actuate.endpoint.mvc.MetricsMvcEndpoint;
import org.springframework.boot.actuate.endpoint.mvc.MvcEndpoint;
import org.springframework.boot.actuate.endpoint.mvc.MvcEndpoints;
+import org.springframework.boot.actuate.endpoint.mvc.SessionMvcEndpoint;
import org.springframework.boot.actuate.endpoint.mvc.ShutdownMvcEndpoint;
import org.springframework.boot.autoconfigure.condition.ConditionOutcome;
import org.springframework.boot.autoconfigure.condition.ConditionalOnBean;
@@ -55,6 +57,7 @@
* Configuration to expose {@link Endpoint} instances over Spring MVC.
*
* @author Dave Syer
+ * @author Eddú Meléndez
* @since 1.3.0
*/
@ManagementContextConfiguration
@@ -167,6 +170,13 @@ public ShutdownMvcEndpoint shutdownMvcEndpoint(ShutdownEndpoint delegate) {
return new ShutdownMvcEndpoint(delegate);
}
+ @Bean
+ @ConditionalOnBean(SessionEndpoint.class)
+ @ConditionalOnEnabledEndpoint(value = "session", enabledByDefault = false)
+ public SessionMvcEndpoint sessionMvcEndpoint(SessionEndpoint delegate) {
+ return new SessionMvcEndpoint(delegate);
+ }
+
private static class LogFileCondition extends SpringBootCondition {
@Override
diff --git a/spring-boot-actuator/src/main/java/org/springframework/boot/actuate/endpoint/SessionEndpoint.java b/spring-boot-actuator/src/main/java/org/springframework/boot/actuate/endpoint/SessionEndpoint.java
new file mode 100644
index 000000000000..3571003e013a
--- /dev/null
+++ b/spring-boot-actuator/src/main/java/org/springframework/boot/actuate/endpoint/SessionEndpoint.java
@@ -0,0 +1,131 @@
+/*
+ * Copyright 2012-2016 the original author or authors.
+ *
+ * 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 org.springframework.boot.actuate.endpoint;
+
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.boot.context.properties.ConfigurationProperties;
+import org.springframework.session.ExpiringSession;
+import org.springframework.session.FindByIndexNameSessionRepository;
+
+/**
+ * {@link Endpoint} to manage web sessions.
+ *
+ * @author Eddú Meléndez
+ * @since 1.4.0
+ */
+@ConfigurationProperties("endpoints.session")
+public class SessionEndpoint implements Endpoint