Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Sign in / Register
Toggle navigation
S
spring-boot
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
DEMO
spring-boot
Commits
a226005f
Commit
a226005f
authored
Jun 08, 2015
by
Dave Syer
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch '1.2.x'
parents
3dcd8e23
1c0bcc13
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
45 additions
and
0 deletions
+45
-0
AuthenticationManagerConfiguration.java
...onfigure/security/AuthenticationManagerConfiguration.java
+14
-0
SecurityAutoConfigurationTests.java
...utoconfigure/security/SecurityAutoConfigurationTests.java
+31
-0
No files found.
spring-boot-autoconfigure/src/main/java/org/springframework/boot/autoconfigure/security/AuthenticationManagerConfiguration.java
View file @
a226005f
...
@@ -16,6 +16,7 @@
...
@@ -16,6 +16,7 @@
package
org
.
springframework
.
boot
.
autoconfigure
.
security
;
package
org
.
springframework
.
boot
.
autoconfigure
.
security
;
import
java.lang.reflect.Field
;
import
java.util.LinkedHashSet
;
import
java.util.LinkedHashSet
;
import
java.util.List
;
import
java.util.List
;
import
java.util.Set
;
import
java.util.Set
;
...
@@ -46,6 +47,7 @@ import org.springframework.security.config.annotation.authentication.configurati
...
@@ -46,6 +47,7 @@ import org.springframework.security.config.annotation.authentication.configurati
import
org.springframework.security.config.annotation.authentication.configurers.GlobalAuthenticationConfigurerAdapter
;
import
org.springframework.security.config.annotation.authentication.configurers.GlobalAuthenticationConfigurerAdapter
;
import
org.springframework.security.config.annotation.authentication.configurers.provisioning.InMemoryUserDetailsManagerConfigurer
;
import
org.springframework.security.config.annotation.authentication.configurers.provisioning.InMemoryUserDetailsManagerConfigurer
;
import
org.springframework.stereotype.Component
;
import
org.springframework.stereotype.Component
;
import
org.springframework.util.ReflectionUtils
;
/**
/**
* Configuration for a Spring Security in-memory {@link AuthenticationManager}. Can be
* Configuration for a Spring Security in-memory {@link AuthenticationManager}. Can be
...
@@ -171,9 +173,21 @@ public class AuthenticationManagerConfiguration {
...
@@ -171,9 +173,21 @@ public class AuthenticationManagerConfiguration {
Set
<
String
>
roles
=
new
LinkedHashSet
<
String
>(
user
.
getRole
());
Set
<
String
>
roles
=
new
LinkedHashSet
<
String
>(
user
.
getRole
());
withUser
(
user
.
getName
()).
password
(
user
.
getPassword
()).
roles
(
withUser
(
user
.
getName
()).
password
(
user
.
getPassword
()).
roles
(
roles
.
toArray
(
new
String
[
roles
.
size
()]));
roles
.
toArray
(
new
String
[
roles
.
size
()]));
setField
(
auth
,
"defaultUserDetailsService"
,
getUserDetailsService
());
super
.
configure
(
auth
);
super
.
configure
(
auth
);
}
}
private
void
setField
(
Object
target
,
String
name
,
Object
value
)
{
try
{
Field
field
=
ReflectionUtils
.
findField
(
target
.
getClass
(),
name
);
ReflectionUtils
.
makeAccessible
(
field
);
ReflectionUtils
.
setField
(
field
,
target
,
value
);
}
catch
(
Exception
e
)
{
logger
.
info
(
"Could not set "
+
name
);
}
}
}
}
/**
/**
...
...
spring-boot-autoconfigure/src/test/java/org/springframework/boot/autoconfigure/security/SecurityAutoConfigurationTests.java
View file @
a226005f
...
@@ -49,6 +49,7 @@ import org.springframework.security.config.annotation.web.configuration.WebSecur
...
@@ -49,6 +49,7 @@ import org.springframework.security.config.annotation.web.configuration.WebSecur
import
org.springframework.security.core.Authentication
;
import
org.springframework.security.core.Authentication
;
import
org.springframework.security.core.AuthenticationException
;
import
org.springframework.security.core.AuthenticationException
;
import
org.springframework.security.core.authority.AuthorityUtils
;
import
org.springframework.security.core.authority.AuthorityUtils
;
import
org.springframework.security.core.userdetails.UserDetailsService
;
import
org.springframework.security.web.FilterChainProxy
;
import
org.springframework.security.web.FilterChainProxy
;
import
org.springframework.security.web.SecurityFilterChain
;
import
org.springframework.security.web.SecurityFilterChain
;
import
org.springframework.web.context.support.AnnotationConfigWebApplicationContext
;
import
org.springframework.web.context.support.AnnotationConfigWebApplicationContext
;
...
@@ -190,6 +191,19 @@ public class SecurityAutoConfigurationTests {
...
@@ -190,6 +191,19 @@ public class SecurityAutoConfigurationTests {
this
.
context
.
getBean
(
AuthenticationManager
.
class
));
this
.
context
.
getBean
(
AuthenticationManager
.
class
));
}
}
@Test
public
void
testDefaultAuthenticationManagerMakesUserDetailsAvailable
()
throws
Exception
{
this
.
context
=
new
AnnotationConfigWebApplicationContext
();
this
.
context
.
setServletContext
(
new
MockServletContext
());
this
.
context
.
register
(
UserDetailsSecurityCustomizer
.
class
,
SecurityAutoConfiguration
.
class
,
ServerPropertiesAutoConfiguration
.
class
,
PropertyPlaceholderAutoConfiguration
.
class
);
this
.
context
.
refresh
();
assertNotNull
(
this
.
context
.
getBean
(
UserDetailsSecurityCustomizer
.
class
)
.
getUserDetails
().
loadUserByUsername
(
"user"
));
}
@Test
@Test
public
void
testOverrideAuthenticationManagerAndInjectIntoSecurityFilter
()
public
void
testOverrideAuthenticationManagerAndInjectIntoSecurityFilter
()
throws
Exception
{
throws
Exception
{
...
@@ -380,4 +394,21 @@ public class SecurityAutoConfigurationTests {
...
@@ -380,4 +394,21 @@ public class SecurityAutoConfigurationTests {
}
}
@Configuration
protected
static
class
UserDetailsSecurityCustomizer
extends
WebSecurityConfigurerAdapter
{
private
UserDetailsService
userDetails
;
@Override
protected
void
configure
(
HttpSecurity
http
)
throws
Exception
{
this
.
userDetails
=
http
.
getSharedObject
(
UserDetailsService
.
class
);
}
public
UserDetailsService
getUserDetails
()
{
return
this
.
userDetails
;
}
}
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment