Merge branch 'master' of github.com:eugenp/tutorials into master
This commit is contained in:
		
						commit
						bd9ff48eb3
					
				| @ -4,10 +4,7 @@ import org.junit.Test; | |||||||
| 
 | 
 | ||||||
| import java.io.File; | import java.io.File; | ||||||
| import java.io.IOException; | import java.io.IOException; | ||||||
| import java.nio.file.Files; | import java.nio.file.*; | ||||||
| import java.nio.file.LinkOption; |  | ||||||
| import java.nio.file.Path; |  | ||||||
| import java.nio.file.Paths; |  | ||||||
| import java.util.concurrent.ThreadLocalRandom; | import java.util.concurrent.ThreadLocalRandom; | ||||||
| 
 | 
 | ||||||
| import static org.junit.Assert.assertFalse; | import static org.junit.Assert.assertFalse; | ||||||
| @ -47,8 +44,18 @@ public class ExistenceUnitTest { | |||||||
|     public void givenSymbolicLink_whenTargetDoesNotExists_thenFollowOrNotBasedOnTheOptions() throws IOException { |     public void givenSymbolicLink_whenTargetDoesNotExists_thenFollowOrNotBasedOnTheOptions() throws IOException { | ||||||
|         Path target = Files.createTempFile("baeldung", "target"); |         Path target = Files.createTempFile("baeldung", "target"); | ||||||
|         Path symbol = Paths.get("test-link-" + ThreadLocalRandom.current().nextInt()); |         Path symbol = Paths.get("test-link-" + ThreadLocalRandom.current().nextInt()); | ||||||
|  |         Path symbolicLink = null; | ||||||
|  | 
 | ||||||
|  |         try { | ||||||
|  |             symbolicLink = Files.createSymbolicLink(symbol, target); | ||||||
|  |         } catch (FileSystemException ex) { | ||||||
|  |             System.out.println("Your OS security policy prevents the current user from creating symbolic links.\n" + | ||||||
|  |                     "Most probably you're running Windows with UAC.\n" + | ||||||
|  |                     "If this is the case, please see - https://docs.microsoft.com/en-us/windows/security/threat-protection/security-policy-settings/create-symbolic-links\n" + | ||||||
|  |                     "You must change your security settings to run this test under Windows."); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
| 
 | 
 | ||||||
|         Path symbolicLink = Files.createSymbolicLink(symbol, target); |  | ||||||
|         assertTrue(Files.exists(symbolicLink)); |         assertTrue(Files.exists(symbolicLink)); | ||||||
|         assertTrue(Files.isSymbolicLink(symbolicLink)); |         assertTrue(Files.isSymbolicLink(symbolicLink)); | ||||||
|         assertFalse(Files.isSymbolicLink(target)); |         assertFalse(Files.isSymbolicLink(target)); | ||||||
|  | |||||||
| @ -1,12 +1,12 @@ | |||||||
| <?xml version="1.0" encoding="UTF-8"?> | <?xml version="1.0" encoding="UTF-8"?> | ||||||
| <hazelcast xsi:schemaLocation="http://www.hazelcast.com/schema/config hazelcast-config-3.7.xsd" | <hazelcast xmlns="http://www.hazelcast.com/schema/config" | ||||||
|            xmlns="http://www.hazelcast.com/schema/config" |            xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" | ||||||
|            xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> |            xsi:schemaLocation="http://www.hazelcast.com/schema/config | ||||||
|  |                                http://www.hazelcast.com/schema/config/hazelcast-config-4.0.xsd"> | ||||||
|     <network> |     <network> | ||||||
|         <port auto-increment="true" port-count="20">5701</port> |         <port auto-increment="true" port-count="20">5701</port> | ||||||
|         <join> |         <join> | ||||||
|             <multicast enabled="false"> |             <multicast enabled="false"/> | ||||||
| 	        </multicast> |  | ||||||
|             <tcp-ip enabled="true"> |             <tcp-ip enabled="true"> | ||||||
|                 <member>machine1</member> |                 <member>machine1</member> | ||||||
|                 <member>localhost</member> |                 <member>localhost</member> | ||||||
|  | |||||||
| @ -32,6 +32,10 @@ | |||||||
|             <groupId>org.thymeleaf.extras</groupId> |             <groupId>org.thymeleaf.extras</groupId> | ||||||
|             <artifactId>thymeleaf-extras-springsecurity5</artifactId> |             <artifactId>thymeleaf-extras-springsecurity5</artifactId> | ||||||
|         </dependency> |         </dependency> | ||||||
|  |         <dependency> | ||||||
|  |             <groupId>org.springframework.boot</groupId> | ||||||
|  |             <artifactId>spring-boot-starter-jersey</artifactId> | ||||||
|  |         </dependency> | ||||||
| 
 | 
 | ||||||
|         <!-- oauth2 --> |         <!-- oauth2 --> | ||||||
|         <dependency> |         <dependency> | ||||||
|  | |||||||
| @ -0,0 +1,13 @@ | |||||||
|  | package com.baeldung.jersey; | ||||||
|  | 
 | ||||||
|  | import org.springframework.boot.SpringApplication; | ||||||
|  | import org.springframework.boot.autoconfigure.SpringBootApplication; | ||||||
|  | import org.springframework.context.annotation.PropertySource; | ||||||
|  | 
 | ||||||
|  | @SpringBootApplication | ||||||
|  | @PropertySource("classpath:jersey-application.properties") | ||||||
|  | public class JerseyApplication { | ||||||
|  |     public static void main(String[] args) { | ||||||
|  |         SpringApplication.run(JerseyApplication.class, args); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,30 @@ | |||||||
|  | package com.baeldung.jersey; | ||||||
|  | 
 | ||||||
|  | import org.springframework.security.oauth2.client.authentication.OAuth2AuthenticationToken; | ||||||
|  | import org.springframework.security.oauth2.core.OAuth2AuthenticatedPrincipal; | ||||||
|  | 
 | ||||||
|  | import javax.ws.rs.GET; | ||||||
|  | import javax.ws.rs.Path; | ||||||
|  | import javax.ws.rs.Produces; | ||||||
|  | import javax.ws.rs.core.Context; | ||||||
|  | import javax.ws.rs.core.MediaType; | ||||||
|  | import javax.ws.rs.core.SecurityContext; | ||||||
|  | 
 | ||||||
|  | @Path("/") | ||||||
|  | public class JerseyResource { | ||||||
|  |     @GET | ||||||
|  |     @Path("login") | ||||||
|  |     @Produces(MediaType.TEXT_HTML) | ||||||
|  |     public String login() { | ||||||
|  |         return "Log in with <a href=\"/oauth2/authorization/github\">GitHub</a>"; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @GET | ||||||
|  |     @Produces(MediaType.TEXT_PLAIN) | ||||||
|  |     public String home(@Context SecurityContext securityContext) { | ||||||
|  |         OAuth2AuthenticationToken authenticationToken = (OAuth2AuthenticationToken) securityContext.getUserPrincipal(); | ||||||
|  |         OAuth2AuthenticatedPrincipal authenticatedPrincipal = authenticationToken.getPrincipal(); | ||||||
|  |         String userName = authenticatedPrincipal.getAttribute("login"); | ||||||
|  |         return "Hello " + userName; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,11 @@ | |||||||
|  | package com.baeldung.jersey; | ||||||
|  | 
 | ||||||
|  | import org.glassfish.jersey.server.ResourceConfig; | ||||||
|  | import org.springframework.stereotype.Component; | ||||||
|  | 
 | ||||||
|  | @Component | ||||||
|  | public class RestConfig extends ResourceConfig { | ||||||
|  |     public RestConfig() { | ||||||
|  |         register(JerseyResource.class); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,21 @@ | |||||||
|  | package com.baeldung.jersey; | ||||||
|  | 
 | ||||||
|  | import org.springframework.context.annotation.Configuration; | ||||||
|  | import org.springframework.security.config.annotation.web.builders.HttpSecurity; | ||||||
|  | import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter; | ||||||
|  | 
 | ||||||
|  | @Configuration | ||||||
|  | public class SecurityConfig extends WebSecurityConfigurerAdapter { | ||||||
|  |     @Override | ||||||
|  |     protected void configure(HttpSecurity http) throws Exception { | ||||||
|  |         http | ||||||
|  |           .authorizeRequests() | ||||||
|  |           .antMatchers("/login") | ||||||
|  |           .permitAll() | ||||||
|  |           .anyRequest() | ||||||
|  |           .authenticated() | ||||||
|  |           .and() | ||||||
|  |           .oauth2Login() | ||||||
|  |           .loginPage("/login"); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,3 @@ | |||||||
|  | server.port=8083 | ||||||
|  | spring.security.oauth2.client.registration.github.client-id=<your-client-id> | ||||||
|  | spring.security.oauth2.client.registration.github.client-secret=<your-client-secret> | ||||||
| @ -0,0 +1,72 @@ | |||||||
|  | package com.baeldung.jersey; | ||||||
|  | 
 | ||||||
|  | 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.context.SpringBootTest; | ||||||
|  | import org.springframework.boot.test.web.client.TestRestTemplate; | ||||||
|  | import org.springframework.boot.web.server.LocalServerPort; | ||||||
|  | import org.springframework.http.HttpStatus; | ||||||
|  | import org.springframework.http.ResponseEntity; | ||||||
|  | import org.springframework.test.context.TestPropertySource; | ||||||
|  | import org.springframework.test.context.junit4.SpringRunner; | ||||||
|  | 
 | ||||||
|  | import java.net.URI; | ||||||
|  | 
 | ||||||
|  | import static org.assertj.core.api.Assertions.assertThat; | ||||||
|  | import static org.springframework.boot.test.context.SpringBootTest.WebEnvironment.RANDOM_PORT; | ||||||
|  | import static org.springframework.http.MediaType.TEXT_HTML; | ||||||
|  | 
 | ||||||
|  | @RunWith(SpringRunner.class) | ||||||
|  | @SpringBootTest(webEnvironment = RANDOM_PORT) | ||||||
|  | @TestPropertySource(properties = "spring.security.oauth2.client.registration.github.client-id:test-id") | ||||||
|  | public class JerseyResourceUnitTest { | ||||||
|  |     @Autowired | ||||||
|  |     private TestRestTemplate restTemplate; | ||||||
|  | 
 | ||||||
|  |     @LocalServerPort | ||||||
|  |     private int port; | ||||||
|  | 
 | ||||||
|  |     private String basePath; | ||||||
|  | 
 | ||||||
|  |     @Before | ||||||
|  |     public void setup() { | ||||||
|  |         basePath = "http://localhost:" + port + "/"; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Test | ||||||
|  |     public void whenUserIsUnauthenticated_thenTheyAreRedirectedToLoginPage() { | ||||||
|  |         ResponseEntity<Object> response = restTemplate.getForEntity(basePath, Object.class); | ||||||
|  |         assertThat(response.getStatusCode()).isEqualTo(HttpStatus.FOUND); | ||||||
|  |         assertThat(response.getBody()).isNull(); | ||||||
|  | 
 | ||||||
|  |         URI redirectLocation = response.getHeaders().getLocation(); | ||||||
|  |         assertThat(redirectLocation).isNotNull(); | ||||||
|  |         assertThat(redirectLocation.toString()).isEqualTo(basePath + "login"); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Test | ||||||
|  |     public void whenUserAttemptsToLogin_thenAuthorizationPathIsReturned() { | ||||||
|  |         ResponseEntity<String> response = restTemplate.getForEntity(basePath + "login", String.class); | ||||||
|  |         assertThat(response.getHeaders().getContentType()).isEqualTo(TEXT_HTML); | ||||||
|  |         assertThat(response.getBody()).isEqualTo("Log in with <a href=\"/oauth2/authorization/github\">GitHub</a>"); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Test | ||||||
|  |     public void whenUserAccessesAuthorizationEndpoint_thenTheyAresRedirectedToProvider() { | ||||||
|  |         ResponseEntity<String> response = restTemplate.getForEntity(basePath + "oauth2/authorization/github", String.class); | ||||||
|  |         assertThat(response.getStatusCode()).isEqualTo(HttpStatus.FOUND); | ||||||
|  |         assertThat(response.getBody()).isNull(); | ||||||
|  | 
 | ||||||
|  |         URI redirectLocation = response.getHeaders().getLocation(); | ||||||
|  |         assertThat(redirectLocation).isNotNull(); | ||||||
|  |         assertThat(redirectLocation.getHost()).isEqualTo("github.com"); | ||||||
|  |         assertThat(redirectLocation.getPath()).isEqualTo("/login/oauth/authorize"); | ||||||
|  | 
 | ||||||
|  |         String redirectionQuery = redirectLocation.getQuery(); | ||||||
|  |         assertThat(redirectionQuery.contains("response_type=code")); | ||||||
|  |         assertThat(redirectionQuery.contains("client_id=test-id")); | ||||||
|  |         assertThat(redirectionQuery.contains("scope=read:user")); | ||||||
|  |     } | ||||||
|  | } | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user