P15GEN2\59518
2024-05-29 d4210c7c4b04abde20037ea8aa0f54ef8a2649aa
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
104
105
106
107
package foundation.route;
 
import java.io.PrintWriter;
 
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
 
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
 
import foundation.translator.Translator;
 
 
public abstract class RouteNavigator {
 
    protected static Logger logger;
    protected HttpServletRequest request;
    protected ClientAcceptType clientAcceptType;
    protected String uri;
    protected String path;
    protected Route route;
    protected Route redirectTo;
    protected boolean authorizeSensitive;
    protected boolean debugEnabled;
    
    static {
        logger = LogManager.getLogger();
    }
    
    public RouteNavigator(HttpServletRequest request, String uri, String path, Route route, boolean authorizeSensitive) {
        this.request = request;
        this.clientAcceptType = ClientAcceptType.getInstance(request);
        this.uri = uri;
        this.path = path;
        this.route = route;
        this.authorizeSensitive = authorizeSensitive;
        
        debugEnabled = !Translator.toBoolean(request.getParameter("silent"), false);
    }
    
    public abstract void sendTo(HttpServletResponse response, Object... args);
    
    public void onSendToError(Exception e) {
        // TODO Auto-generated method stub
    }
 
    public ClientAcceptType getClientAcceptType() {
        return clientAcceptType;
    }
 
    public void redirectToTimeOut(HttpServletResponse response, ClientAcceptType acceptType) {
        redirectTo = RouteTable.getTimeOutRoute();
        redirectTo(response, redirectTo, acceptType);
    }
 
    public void redirectToInvalidUserRight(HttpServletResponse response, ClientAcceptType acceptType) {
        redirectTo = RouteTable.getInvalidUserRightRoute();
        redirectTo(response, redirectTo, acceptType);
    }
    
    private void redirectTo(HttpServletResponse response, Route route, ClientAcceptType acceptType) {
        if (ClientAcceptType.Ajax == clientAcceptType) {
            response.setHeader("Access-Control-Allow-Origin", "*");
            response.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE, PUT");
            response.setHeader("Access-Control-Max-Age", "0");
            response.setHeader("Cache-Control","no-cache");
            response.setHeader("Access-Control-Allow-Credentials", "true");
            response.setHeader("XDomainRequestAllowed","1");
            response.setHeader("Access-Control-Allow-Headers", "Origin, No-Cache, X-Requested-With, If-Modified-Since, Pragma, Last-Modified, Cache-Control, Expires, Content-Type, X-E4M-With,userId,token");
            response.setHeader("access-control-expose-headers", "Authorization");
        }
        
        PrintWriter writer;
        try {
            writer = response.getWriter();
            ((WriterRoute)route).write(writer, acceptType);
        } 
        catch (Exception e) {
        }
    }
 
    public Route getRoute() {
        return route;
    }
 
    public boolean isAuthorizeSensitive() {
        return authorizeSensitive;
    }
 
    public String getUri() {
        return uri;
    }
 
    @Override
    public String toString() {
        return uri + " >> " + path + " : " + route.toString();
    }
 
    public boolean isDebugEnabled() {
        return debugEnabled;
    }
 
    public void setDebugEnabled(boolean debugEnabled) {
        this.debugEnabled = debugEnabled;
    }
    
}