Subversion Repositories SmartDukaan

Rev

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

Rev Author Line No. Line
458 rajveer 1
/**
2
 * 
3
 */
4
package in.shop2020.serving.controllers;
5
 
3830 chandransh 6
import java.util.HashMap;
7
import java.util.Map;
507 rajveer 8
import java.util.StringTokenizer;
9
 
5072 amar.kumar 10
import in.shop2020.datalogger.EventType;
4865 rajveer 11
import in.shop2020.logistics.LogisticsInfo;
507 rajveer 12
import in.shop2020.logistics.LogisticsService.Client;
4630 mandeep.dh 13
import in.shop2020.logistics.DeliveryType;
786 rajveer 14
import in.shop2020.logistics.LogisticsServiceException;
3126 rajveer 15
import in.shop2020.thrift.clients.LogisticsClient;
5072 amar.kumar 16
import in.shop2020.utils.DataLogger;
507 rajveer 17
 
832 rajveer 18
import org.apache.log4j.Logger;
458 rajveer 19
import org.apache.struts2.rest.DefaultHttpHeaders;
20
import org.apache.struts2.rest.HttpHeaders;
786 rajveer 21
import org.apache.thrift.TException;
458 rajveer 22
 
3830 chandransh 23
import com.google.gson.Gson;
24
 
458 rajveer 25
/**
26
 * @author rajveer
27
 *
28
 */
29
public class EstimateController extends BaseController {
30
 
1044 chandransh 31
	private static final long serialVersionUID = 8023801600023970837L;
32
 
832 rajveer 33
	private static Logger log = Logger.getLogger(Class.class);	
458 rajveer 34
	private String id;
507 rajveer 35
	private long itemId;
36
	private String pincode;
843 chandransh 37
	private long days = -1;
3830 chandransh 38
	private boolean isCODAvailable;
39
	private Map<String, String> response = new HashMap<String, String>();
40
 
458 rajveer 41
	public EstimateController() {
42
		super();
43
	}
44
 
45
    // GET /logout
786 rajveer 46
    public HttpHeaders show(){
3126 rajveer 47
    	LogisticsClient logisticsServiceClient = null;
507 rajveer 48
    	try {
3126 rajveer 49
			logisticsServiceClient = new LogisticsClient();
507 rajveer 50
			Client logisticsClient = logisticsServiceClient.getClient();
4865 rajveer 51
			LogisticsInfo logistincInfo = logisticsClient.getLogisticsEstimation(itemId, pincode, DeliveryType.PREPAID);
52
			days = logistincInfo.getDeliveryTime();
53
			isCODAvailable = logistincInfo.isCodAllowed();
3830 chandransh 54
    	} catch (LogisticsServiceException e)	{
843 chandransh 55
    		days = -1;
3830 chandransh 56
    		isCODAvailable = false;
57
    		log.error("Unable to get estimate/COD availability for " + itemId, e);
58
 
59
		} catch(TException e)	{
786 rajveer 60
 
3830 chandransh 61
		} catch (Exception e)	{
786 rajveer 62
 
63
		}
3830 chandransh 64
		response.put("delivery_estimate", Long.toString(days));
65
		response.put("is_cod_available_for_location", Boolean.toString(isCODAvailable));
66
 
5072 amar.kumar 67
		try{
68
			String requestOrigin = request.getHeader("referer").contains("cart")?"Cart":"Product";
69
			DataLogger.logData(EventType.DELIVERY_ESTIMATE, getSessionId(), userinfo.getUserId(), userinfo.getEmail(),
70
					pincode, (new Long(days)).toString(), (new Long(itemId)).toString(), (new Boolean(isCODAvailable)).toString(),
71
					requestOrigin);
72
		}catch(Exception e){
5191 amar.kumar 73
			log.warn(e.getMessage()+"pincode : "+ pincode + " Actual referer : " + request.getHeader("referer") + e.getStackTrace());
5072 amar.kumar 74
		}
458 rajveer 75
    	return new DefaultHttpHeaders("index");
76
    }
3830 chandransh 77
 
458 rajveer 78
    /**
79
     * 
80
     * @param id
81
     */
82
    public void setId(String id) {
83
        this.id = id;
2148 chandransh 84
        StringTokenizer tokenizer = new StringTokenizer(this.id, "_");
507 rajveer 85
        this.pincode = tokenizer.nextToken();
86
        this.itemId = Long.parseLong(tokenizer.nextToken());
458 rajveer 87
    }
88
 
3830 chandransh 89
    public String getResponseJSONString() {
90
    	Gson gson = new Gson();
91
    	return gson.toJson(response);
458 rajveer 92
    }
3830 chandransh 93
}