Project

General

Profile

1
package eu.dnetlib.openaire.usermanagement;
2

    
3
import eu.dnetlib.openaire.user.utils.VerificationActions;
4
import org.apache.log4j.Logger;
5
import org.springframework.beans.factory.annotation.Autowired;
6
import org.springframework.web.context.support.SpringBeanAutowiringSupport;
7

    
8
import javax.servlet.RequestDispatcher;
9
import javax.servlet.ServletConfig;
10
import javax.servlet.ServletException;
11
import javax.servlet.http.HttpServlet;
12
import javax.servlet.http.HttpServletRequest;
13
import javax.servlet.http.HttpServletResponse;
14
import javax.servlet.http.HttpSession;
15
import java.io.IOException;
16
import java.io.PrintWriter;
17

    
18
/**
19
 * Created by kiatrop on 28/9/2017.
20
 */
21
public class VerificationCodeServlet extends HttpServlet {
22

    
23
    public void init(ServletConfig config) throws ServletException {
24
        super.init(config);
25
        SpringBeanAutowiringSupport.processInjectionBasedOnServletContext(this,
26
                config.getServletContext());
27
    }
28

    
29
    @Autowired
30
    private VerificationActions verificationActions;
31

    
32
    private Logger logger = Logger.getLogger(VerificationCodeServlet.class);
33

    
34
    @Override
35
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws IOException {
36
        response.setContentType("text/html");
37
        PrintWriter printWriter = response.getWriter();
38

    
39
        String formUsername = request.getParameter("username");
40
        String formVerificationCode = request.getParameter("verification_code");
41

    
42
        if (verificationActions.verificationEntryExists(formUsername, formVerificationCode)) {
43
            //TODO check expiration date if "now" is more than 24h from the date in DB return error message
44
            //else go to next step resetPassword.jsp
45
//            request.setAttribute("username", formUsername);
46
//            RequestDispatcher rd = getServletContext().getRequestDispatcher("/resetPassword.jsp");
47
//            try {
48
//                rd.forward(request, response);
49
//            } catch (ServletException e) {
50
//               logger.info("Dispatcher error" + e);
51
//            }
52

    
53
            HttpSession session = request.getSession();
54
            session.setAttribute("username", formUsername);
55

    
56
            response.sendRedirect("./resetPassword.jsp");
57
            printWriter.close();
58

    
59
        } else {
60
            // response.sendRedirect("./error.jsp"); or write a message in the session
61
        }
62

    
63
    }
64
}
(4-4/4)