forked from actframework/actframework
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathHandleMissingAuthentication.java
More file actions
103 lines (91 loc) · 2.91 KB
/
HandleMissingAuthentication.java
File metadata and controls
103 lines (91 loc) · 2.91 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
package act.controller.annotation;
/*-
* #%L
* ACT Framework
* %%
* Copyright (C) 2014 - 2017 ActFramework
* %%
* 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.
* #L%
*/
import act.Act;
import act.util.MissingAuthenticationHandler;
import act.util.RedirectToLoginUrl;
import act.util.ReturnUnauthorized;
import org.osgl.util.S;
import java.lang.annotation.*;
/**
* Specify how to handle the case when interact user not authenticated
*/
@Retention(RetentionPolicy.RUNTIME)
@Inherited
@Target(ElementType.TYPE)
public @interface HandleMissingAuthentication {
enum Option {
/**
* redirect to login URL
*/
REDIRECT() {
@Override
protected MissingAuthenticationHandler createHandler(String custom) {
return S.blank(custom) ? Act.getInstance(RedirectToLoginUrl.class) : new RedirectToLoginUrl(custom);
}
},
/**
* send 401 response
*/
REJECT() {
@Override
protected MissingAuthenticationHandler createHandler(String custom) {
return Act.getInstance(ReturnUnauthorized.class);
}
},
/**
* Customized solution
*/
CUSTOM() {
@Override
protected MissingAuthenticationHandler createHandler(String custom) {
return Act.getInstance(custom);
}
};
private volatile MissingAuthenticationHandler realHandler;
public MissingAuthenticationHandler handler(String custom) {
if (null == realHandler) {
synchronized (this) {
if (null == realHandler) {
realHandler = createHandler(custom);
}
}
}
return realHandler;
}
protected abstract MissingAuthenticationHandler createHandler(String custom);
}
/**
* Specify the option to handle missing authentication case
* @return the way to deal with missing authentication
*/
Option value();
/**
* If the {@link #value()} is {@link Option#CUSTOM}, this
* field specifies the customer implementation.
*
* If the {@link #value()} is {@link Option#REDIRECT} and this
* field is provided, then it specifies the login URL
*
*
* @return the custom implementation or login URL
*/
String custom() default "";
}