7 changed files with 238 additions and 2 deletions
@ -0,0 +1,69 @@ |
|||||||
|
/* |
||||||
|
* Copyright 2012-2015 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.autoconfigure.security; |
||||||
|
|
||||||
|
import java.util.Map; |
||||||
|
|
||||||
|
import org.apache.commons.logging.Log; |
||||||
|
import org.apache.commons.logging.LogFactory; |
||||||
|
import org.springframework.boot.autoconfigure.EnableAutoConfiguration; |
||||||
|
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass; |
||||||
|
import org.springframework.context.ApplicationContext; |
||||||
|
import org.springframework.context.annotation.Bean; |
||||||
|
import org.springframework.context.annotation.Configuration; |
||||||
|
import org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder; |
||||||
|
import org.springframework.security.config.annotation.authentication.configuration.AuthenticationConfiguration; |
||||||
|
import org.springframework.security.config.annotation.authentication.configurers.GlobalAuthenticationConfigurerAdapter; |
||||||
|
|
||||||
|
/** |
||||||
|
* This works with the {@link AuthenticationConfiguration} to ensure that users are able to use: |
||||||
|
* |
||||||
|
* <pre> |
||||||
|
* public void configureGlobal(AuthenticationManagerBuilder auth) { |
||||||
|
* ... |
||||||
|
* } |
||||||
|
* </pre> |
||||||
|
* |
||||||
|
* within their classes annotated with {{@EnableAutoConfiguration}} or use {{@SpringBootApplication}}. |
||||||
|
* |
||||||
|
* @author Rob Winch |
||||||
|
*/ |
||||||
|
@Configuration |
||||||
|
@ConditionalOnClass(GlobalAuthenticationConfigurerAdapter.class) |
||||||
|
public class BootGlobalAuthenticationConfiguration { |
||||||
|
|
||||||
|
@Bean |
||||||
|
public static BootGlobalAuthenticationConfigurationAdapter bootGlobalAuthenticationConfigurationAdapter(ApplicationContext context) { |
||||||
|
return new BootGlobalAuthenticationConfigurationAdapter(context); |
||||||
|
} |
||||||
|
|
||||||
|
private static class BootGlobalAuthenticationConfigurationAdapter extends GlobalAuthenticationConfigurerAdapter { |
||||||
|
private final ApplicationContext context; |
||||||
|
private static final Log logger = LogFactory.getLog(BootGlobalAuthenticationConfiguration.class); |
||||||
|
|
||||||
|
public BootGlobalAuthenticationConfigurationAdapter(ApplicationContext context) { |
||||||
|
this.context = context; |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public void init(AuthenticationManagerBuilder auth) { |
||||||
|
Map<String, Object> beansWithAnnotation = context.getBeansWithAnnotation(EnableAutoConfiguration.class); |
||||||
|
if(logger.isDebugEnabled()) { |
||||||
|
logger.debug("Eagerly initializing " + beansWithAnnotation); |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
@ -0,0 +1,22 @@ |
|||||||
|
<?xml version="1.0" encoding="UTF-8"?> |
||||||
|
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> |
||||||
|
<modelVersion>4.0.0</modelVersion> |
||||||
|
<parent> |
||||||
|
<groupId>org.springframework.boot</groupId> |
||||||
|
<artifactId>spring-boot-parent</artifactId> |
||||||
|
<version>1.2.2.BUILD-SNAPSHOT</version> |
||||||
|
<relativePath>../spring-boot-parent</relativePath> |
||||||
|
</parent> |
||||||
|
<artifactId>spring-boot-security-tests</artifactId> |
||||||
|
<packaging>pom</packaging> |
||||||
|
<name>Spring Boot Security Tests</name> |
||||||
|
<description>${project.name}</description> |
||||||
|
<url>http://projects.spring.io/spring-boot/</url> |
||||||
|
<organization> |
||||||
|
<name>Pivotal Software, Inc.</name> |
||||||
|
<url>http://www.spring.io</url> |
||||||
|
</organization> |
||||||
|
<modules> |
||||||
|
<module>spring-boot-security-tests-web-helloworld</module> |
||||||
|
</modules> |
||||||
|
</project> |
||||||
@ -0,0 +1,32 @@ |
|||||||
|
<?xml version="1.0" encoding="UTF-8"?> |
||||||
|
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> |
||||||
|
<modelVersion>4.0.0</modelVersion> |
||||||
|
<parent> |
||||||
|
<groupId>org.springframework.boot</groupId> |
||||||
|
<artifactId>spring-boot-security-tests</artifactId> |
||||||
|
<version>1.2.2.BUILD-SNAPSHOT</version> |
||||||
|
<relativePath>../</relativePath> |
||||||
|
</parent> |
||||||
|
<artifactId>spring-boot-security-tests-web-helloworld</artifactId> |
||||||
|
<name>Spring Boot Security Tests - Web Basic</name> |
||||||
|
<description>${project.name}</description> |
||||||
|
<url>http://projects.spring.io/spring-boot/</url> |
||||||
|
<organization> |
||||||
|
<name>Pivotal Software, Inc.</name> |
||||||
|
<url>http://www.spring.io</url> |
||||||
|
</organization> |
||||||
|
<dependencies> |
||||||
|
<dependency> |
||||||
|
<groupId>org.springframework.boot</groupId> |
||||||
|
<artifactId>spring-boot-starter</artifactId> |
||||||
|
</dependency> |
||||||
|
<dependency> |
||||||
|
<groupId>org.springframework.boot</groupId> |
||||||
|
<artifactId>spring-boot-starter-web</artifactId> |
||||||
|
</dependency> |
||||||
|
<dependency> |
||||||
|
<groupId>org.springframework.boot</groupId> |
||||||
|
<artifactId>spring-boot-starter-security</artifactId> |
||||||
|
</dependency> |
||||||
|
</dependencies> |
||||||
|
</project> |
||||||
@ -0,0 +1,39 @@ |
|||||||
|
/* |
||||||
|
* Copyright 2012-2015 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 sample; |
||||||
|
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired; |
||||||
|
import org.springframework.boot.SpringApplication; |
||||||
|
import org.springframework.boot.autoconfigure.SpringBootApplication; |
||||||
|
import org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder; |
||||||
|
|
||||||
|
@SpringBootApplication |
||||||
|
public class HelloWebSecurityApplication { |
||||||
|
|
||||||
|
@Autowired |
||||||
|
public void configureGlobal(AuthenticationManagerBuilder auth) |
||||||
|
throws Exception { |
||||||
|
// @formatter:off
|
||||||
|
auth |
||||||
|
.inMemoryAuthentication() |
||||||
|
.withUser("user").password("password").roles("USER"); |
||||||
|
// @formatter:on
|
||||||
|
} |
||||||
|
|
||||||
|
public static void main(String[] args) { |
||||||
|
SpringApplication.run(HelloWebSecurityApplication.class, args); |
||||||
|
} |
||||||
|
} |
||||||
@ -0,0 +1,72 @@ |
|||||||
|
/* |
||||||
|
* Copyright 2012-2015 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 sample; |
||||||
|
|
||||||
|
import javax.servlet.http.HttpServletResponse; |
||||||
|
|
||||||
|
import org.junit.Before; |
||||||
|
import org.junit.Test; |
||||||
|
import org.junit.runner.RunWith; |
||||||
|
import org.springframework.beans.factory.annotation.Autowired; |
||||||
|
import org.springframework.boot.test.SpringApplicationConfiguration; |
||||||
|
import org.springframework.boot.test.WebIntegrationTest; |
||||||
|
import org.springframework.mock.web.MockFilterChain; |
||||||
|
import org.springframework.mock.web.MockHttpServletRequest; |
||||||
|
import org.springframework.mock.web.MockHttpServletResponse; |
||||||
|
import org.springframework.security.crypto.codec.Base64; |
||||||
|
import org.springframework.security.web.FilterChainProxy; |
||||||
|
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; |
||||||
|
|
||||||
|
import static org.hamcrest.Matchers.*; |
||||||
|
import static org.junit.Assert.assertThat; |
||||||
|
|
||||||
|
@RunWith(SpringJUnit4ClassRunner.class) |
||||||
|
@SpringApplicationConfiguration(classes = HelloWebSecurityApplication.class) |
||||||
|
@WebIntegrationTest(randomPort = true) |
||||||
|
public class HelloWebSecurityApplicationTests { |
||||||
|
@Autowired |
||||||
|
FilterChainProxy springSecurityFilterChain; |
||||||
|
|
||||||
|
MockHttpServletRequest request; |
||||||
|
|
||||||
|
MockHttpServletResponse response; |
||||||
|
|
||||||
|
MockFilterChain chain; |
||||||
|
|
||||||
|
@Before |
||||||
|
public void setup() { |
||||||
|
request = new MockHttpServletRequest(); |
||||||
|
response = new MockHttpServletResponse(); |
||||||
|
chain = new MockFilterChain(); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void requiresAuthentication() throws Exception { |
||||||
|
springSecurityFilterChain.doFilter(request, response, chain); |
||||||
|
|
||||||
|
assertThat(response.getStatus(), equalTo(HttpServletResponse.SC_UNAUTHORIZED)); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
@Test |
||||||
|
public void userAuthenticates() throws Exception { |
||||||
|
request.addHeader("Authorization", "Basic " + new String(Base64.encode("user:password".getBytes("UTF-8")))); |
||||||
|
|
||||||
|
springSecurityFilterChain.doFilter(request, response, chain); |
||||||
|
|
||||||
|
assertThat(response.getStatus(), equalTo(HttpServletResponse.SC_OK)); |
||||||
|
} |
||||||
|
} |
||||||
Loading…
Reference in new issue