| margaretha | 56e8e55 | 2017-12-05 16:31:21 +0100 | [diff] [blame] | 1 | package de.ids_mannheim.korap.authentication.http; |
| 2 | |
| margaretha | 2afb97d | 2017-12-07 19:18:44 +0100 | [diff] [blame] | 3 | import java.util.EnumSet; |
| 4 | |
| margaretha | 56e8e55 | 2017-12-05 16:31:21 +0100 | [diff] [blame] | 5 | import javax.ws.rs.core.HttpHeaders; |
| 6 | import javax.ws.rs.core.Response; |
| margaretha | 2afb97d | 2017-12-07 19:18:44 +0100 | [diff] [blame] | 7 | import javax.ws.rs.core.Response.ResponseBuilder; |
| margaretha | 56e8e55 | 2017-12-05 16:31:21 +0100 | [diff] [blame] | 8 | |
| margaretha | 56e8e55 | 2017-12-05 16:31:21 +0100 | [diff] [blame] | 9 | import org.springframework.stereotype.Component; |
| 10 | |
| margaretha | 0e8f4e7 | 2018-04-05 14:11:52 +0200 | [diff] [blame^] | 11 | import de.ids_mannheim.korap.constant.AuthenticationScheme; |
| margaretha | 56e8e55 | 2017-12-05 16:31:21 +0100 | [diff] [blame] | 12 | |
| 13 | /** Implementation of HTTP authentication scheme (see RFC 7253 and 7617) |
| 14 | * for server creating responses with status 401 Unauthorized and |
| 15 | * WWW-Authenticate header to unauthenticated requests. |
| 16 | * |
| 17 | * @author margaretha |
| 18 | * |
| 19 | */ |
| 20 | @Component |
| 21 | public class HttpUnauthorizedHandler { |
| margaretha | 56e8e55 | 2017-12-05 16:31:21 +0100 | [diff] [blame] | 22 | |
| 23 | public Response createUnauthenticatedResponse (String notification) { |
| margaretha | 2afb97d | 2017-12-07 19:18:44 +0100 | [diff] [blame] | 24 | ResponseBuilder builder = Response.status(Response.Status.UNAUTHORIZED); |
| 25 | |
| 26 | for (AuthenticationScheme s : EnumSet |
| 27 | .allOf(AuthenticationScheme.class)) { |
| 28 | builder = builder.header(HttpHeaders.WWW_AUTHENTICATE, |
| 29 | s.displayName() + " realm=\"Kustvakt\""); |
| 30 | } |
| 31 | |
| 32 | return builder.entity(notification).build(); |
| margaretha | 56e8e55 | 2017-12-05 16:31:21 +0100 | [diff] [blame] | 33 | } |
| 34 | } |