Subversion Repositories SmartDukaan

Rev

Rev 3126 | Rev 3830 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
637 rajveer 1
/**
2
 * 
3
 */
4
package in.shop2020.serving.controllers;
5
 
2263 vikas 6
import in.shop2020.datalogger.EventType;
637 rajveer 7
import in.shop2020.model.v1.user.User;
815 rajveer 8
import in.shop2020.serving.utils.DesEncrypter;
1175 varun.gupt 9
import in.shop2020.serving.utils.UserMessage;
3126 rajveer 10
import in.shop2020.thrift.clients.UserClient;
2511 vikas 11
import in.shop2020.utils.DataLogger;
637 rajveer 12
 
13
import java.io.IOException;
14
import java.util.Date;
1623 rajveer 15
import java.util.List;
637 rajveer 16
 
832 rajveer 17
import org.apache.log4j.Logger;
637 rajveer 18
import org.apache.struts2.convention.annotation.Result;
925 rajveer 19
import org.apache.struts2.convention.annotation.Results;
637 rajveer 20
 
21
/**
22
 * 
23
 * @author rajveer
781 vikas 24
 * 
637 rajveer 25
 */
925 rajveer 26
@Results({
27
	@Result(name="success", type="redirectAction", params = {"actionName" , "home"}),
28
	@Result(name = "redirect", location = "${redirectUrl}", type = "redirect")
29
})
637 rajveer 30
 
781 vikas 31
public class LoginController extends BaseController {
650 rajveer 32
 
781 vikas 33
	/**
34
	 * 
35
	 */
36
	private static final long serialVersionUID = 5390035354379263121L;
650 rajveer 37
 
832 rajveer 38
	private static Logger log = Logger.getLogger(Class.class);
815 rajveer 39
	private DesEncrypter desEncrypter = new DesEncrypter("saholic");
40
 
2933 vikas 41
	private String redirectUrl = "/";
781 vikas 42
 
43
	public LoginController() {
637 rajveer 44
		super();
45
	}
46
 
781 vikas 47
	public String index() throws SecurityException, IOException {
925 rajveer 48
		if(userinfo.isLoggedIn()){
49
    		return "success";
50
    	}
650 rajveer 51
		return "index";
781 vikas 52
	}
637 rajveer 53
 
781 vikas 54
	public String create() throws SecurityException, Exception {
55
		if (loginUser()) {
2959 chandransh 56
			log.info("Will redirect the user to:" + redirectUrl);
2637 vikas 57
            return "redirect";
781 vikas 58
		} else {
1175 varun.gupt 59
			addActionError(UserMessage.USER_AUTHENTICATION_FAILURE);
3185 vikas 60
            DataLogger.logData(EventType.LOGIN_FAILED, getSessionId(), userinfo.getUserId(), this.request.getParameter("email"));
830 vikas 61
			return "login";
781 vikas 62
		}
63
	}
64
 
65
	private boolean loginUser() {
66
		try {
67
			String email, password;
68
 
69
			email = this.request.getParameter("email");
70
			password = this.request.getParameter("password");
71
 
72
			if (email == null || password == null) {
73
				return false;
74
			}
815 rajveer 75
 
1776 varun.gupt 76
			String encryptedPassword = desEncrypter.encrypt(password);
815 rajveer 77
 
3126 rajveer 78
			UserClient userContextServiceClient = new UserClient();
1747 varun.gupt 79
			in.shop2020.model.v1.user.UserContextService.Client userClient = userContextServiceClient.getClient();
815 rajveer 80
			User user = userClient.authenticateUser(email, encryptedPassword);
793 rajveer 81
			userClient.setUserAsLoggedIn(user.getUserId(),(new Date()).getTime());
82
			String pincode = userClient.getDefaultPincode(user.getUserId());
2637 vikas 83
 
1175 varun.gupt 84
			// TODO: setTotalItems shouldn't be a method on userinfo. This allows
85
			// for potentially updating the item count wrongly. The method setCartId
637 rajveer 86
			// should update the item count as well. Also, there can be a method
1175 varun.gupt 87
			// called refreshItemCount() that automatically updates the number of
637 rajveer 88
			// items currently in the cart.
1625 rajveer 89
			if(userinfo.getUserId() != -1){
1623 rajveer 90
				userClient.mergeCart(userinfo.getCartId(), user.getActiveCartId());
1625 rajveer 91
 
2982 rajveer 92
				List<Long> items = userClient.getBrowseHistoryItems(userinfo.getUserId());
93
				if(items != null){
94
					for(Long itemId: items){
95
						userClient.updateBrowseHistory(user.getUserId(), itemId);
1623 rajveer 96
					}
97
				}
2982 rajveer 98
 
99
				items = userClient.getMyResearchItems(userinfo.getUserId());
100
				if(items != null){
101
					for(Long itemId: items){
102
						userClient.updateMyResearch(user.getUserId(), itemId);
1625 rajveer 103
					}
104
				}
1623 rajveer 105
			}
106
 
107
 
1625 rajveer 108
			userinfo.setUserId(user.getUserId());
109
			userinfo.setNameOfUser(user.getName());
110
			userinfo.setEmail(email);
111
			userinfo.setLoggedIn(true);
112
			userinfo.setPincode(pincode);
637 rajveer 113
			userinfo.setCartId(user.getActiveCartId());
1776 varun.gupt 114
			int totalItems = userClient.getCart(user.getActiveCartId()).getLinesSize();
762 rajveer 115
			userinfo.setTotalItems(totalItems);
2959 chandransh 116
			log.info(userinfo);
2996 vikas 117
			String src = user.getSource();
118
			if (src == null) {
119
			    src = "";
120
			}
3185 vikas 121
			DataLogger.logData(EventType.LOGIN_SUCCESS, getSessionId(), userinfo.getUserId(),
2996 vikas 122
                    email, src);
2637 vikas 123
    		return true;
781 vikas 124
		} catch (Exception e) {
2959 chandransh 125
			log.error(UserMessage.USER_AUTHENTICATION_FAILURE, e);
781 vikas 126
			return false;
127
		}
128
	}
637 rajveer 129
 
924 vikas 130
	public String getRedirectUrl() {
131
		return redirectUrl;
781 vikas 132
	}
133
 
924 vikas 134
	public void setRedirectUrl(String redirectUrl) {
135
		this.redirectUrl = redirectUrl;
136
	}
637 rajveer 137
}