P15GEN2\59518
2025-10-10 9f6890646993d16260d4201d613c092132856127
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
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
package foundation.server;
 
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.PrintStream;
 
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
 
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import org.apache.logging.log4j.ThreadContext;
 
import foundation.handler.DataPool;
import foundation.handler.DataPoolType;
import foundation.log.LogConfig;
import foundation.route.ClientAcceptType;
import foundation.route.ControllerNavigator;
import foundation.route.Route;
import foundation.route.RouteNavigator;
import foundation.route.RouteTable;
import foundation.route.RouteType;
import foundation.route.ServerErrorNavigator;
import foundation.server.config.Configer;
import foundation.token.IOnlineUser;
import foundation.token.IUserManager;
import foundation.value.Translator;
 
public class Dispatcher implements Filter { 
 
    public static boolean AuthorizeActive;
    private static Dispatcher instance;
    private static Logger logger;
 
    static {
        logger = LogManager.getLogger(Dispatcher.class);
    }
 
    public Dispatcher() {
        instance = this;
    }
 
    public synchronized static Dispatcher getInstance() {
        if (instance == null) {
            instance = new Dispatcher();
        }
 
        return instance;
    }
 
    public void init(FilterConfig filterConfig) throws ServletException {
        AuthorizeActive = Translator.toBoolean(Configer.getString("AuthorizeActive"), true);
    }
 
    public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException {
        HttpServletRequest request = (HttpServletRequest) req;
        HttpServletResponse response = (HttpServletResponse) res;
        
        try {
            DataPool dataPool = null;
            request.setCharacterEncoding("utf-8");
            
            //1. route and get navigator
            RouteNavigator navigator = RouteTable.matchRoute(request);
            
//            //2. log
//            if (LogConfig.IsActive_Dispatcher_Trace) {
//                logger.debug("filter request URI:" + navigator); 
//            }
            
            //3. authorize
            if (navigator.isAuthorizeSensitive() && AuthorizeActive) {
                Route route = navigator.getRoute();
                
                //3.1 user token
                dataPool = new DataPool(request);
                
                if (DataPoolType.Options == dataPool.getType()) {
                    ControllerNavigator.replyOptions(request, response);
                    return;
                }
                
                String token = dataPool.getToken();
                IOnlineUser onlineUser = IUserManager.registerUser(token);
                dataPool.setUser(onlineUser);
                
                if (LogConfig.IsActive_Dispatcher_Trace) {
                    ThreadContext.put("DealerId", onlineUser.getId());
                    logger.debug("filter request URI:" + navigator); 
                }
                
                //3.2 go to login
                if (onlineUser.isAnymous()) {
                    if (route == null) {
                        logger.info("redirct to time out for request: {}", navigator);
                        navigator.redirectToTimeOut(response, ClientAcceptType.Html);
                        return;
                    }
                    
                    RouteType routeType = route.getRouteType();
                    
                    if (RouteType.Controller == routeType) {
                        logger.info("redirct to time out for request: {}", navigator);
                        navigator.redirectToTimeOut(response, ClientAcceptType.Ajax);
                        return;
                    }
                    
                    navigator.redirectToTimeOut(response, ClientAcceptType.Html);
                    logger.debug("filter request body:" + dataPool.getBody());
                    
                    return;
                } 
                
            }
            
            //4. send to
            ThreadContext.put("DealerId", "anymous");
            navigator.sendTo(response, dataPool);
        }
        catch (Exception e) {
            String error = printStackToString(e);
            logger.error("dispatch error:" + e.getMessage());
            logger.error(error);
            
            RouteNavigator navigator = new ServerErrorNavigator(request);
            navigator.sendTo(response, null, e);
        }
    }
    
    public void destroy() {
 
    }
 
    private String printStackToString(Exception e) {
        ByteArrayOutputStream outStream = new ByteArrayOutputStream();
        PrintStream printStream = new PrintStream(outStream);
        e.printStackTrace(printStream);
 
        return outStream.toString();
    }
 
}