Subversion Repositories SmartDukaan

Rev

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

Rev Author Line No. Line
3487 rajveer 1
package in.shop2020.web;
2
 
3
import in.shop2020.model.ComparisonStats;
4
import in.shop2020.server.ComparisonStatsRepository;
5
 
6
import java.text.SimpleDateFormat;
7
import java.util.Calendar;
8
import java.util.Date;
9
import java.util.HashMap;
10
import java.util.List;
11
import java.util.Map;
12
 
13
import javax.servlet.http.HttpServlet;
14
import javax.servlet.http.HttpServletRequest;
15
import javax.servlet.http.HttpServletResponse;
16
 
3504 rajveer 17
import org.json.JSONObject;
3487 rajveer 18
 
3504 rajveer 19
 
3487 rajveer 20
import com.google.appengine.api.datastore.DatastoreService;
21
import com.google.appengine.api.datastore.DatastoreServiceFactory;
22
import com.google.appengine.api.datastore.Entity;
23
import com.google.appengine.api.datastore.PreparedQuery;
24
import com.google.appengine.api.datastore.Query;
3518 rajveer 25
import com.google.appengine.api.datastore.Text;
3487 rajveer 26
 
27
public class DailyComparisonStatsGenerator extends HttpServlet {
28
    private static final long serialVersionUID = -8236918415987438049L;
29
 
30
    public void doPost(HttpServletRequest req, HttpServletResponse resp) {
31
        resp.setContentType("application/json");
32
 
33
        DatastoreService datastore = DatastoreServiceFactory
34
                .getDatastoreService();
35
 
36
        Calendar cal = Calendar.getInstance();
37
        Date toDate =  cal.getTime();
38
        cal.add(Calendar.MONTH, -1);
39
        Date fromDate = cal.getTime();
40
 
41
 
42
        Query q = new Query("DataLog");
43
        q.addFilter("eventType", Query.FilterOperator.EQUAL, "PRODUCT_COMPARE");
44
        q.addFilter("date", Query.FilterOperator.GREATER_THAN_OR_EQUAL, fromDate);
45
        q.addFilter("date", Query.FilterOperator.LESS_THAN_OR_EQUAL, toDate);
46
 
47
        PreparedQuery pq = datastore.prepare(q);
48
        Map<Long, Map<Long, Long>> comparisonStats = new HashMap<Long, Map<Long, Long>>();
49
 
50
 
51
        for (Entity result : pq.asIterable()) {
52
        	List<Long> itemIds;
53
        	try{
54
        		itemIds =  (List<Long>) result.getProperty("itemIds");
55
        	}catch (ClassCastException ce) {
56
				System.out.println("Unable to cast itemIds to List");
57
				continue;
58
			}
59
            if(itemIds != null && !itemIds.isEmpty()){
60
            	for(int i=0; i<itemIds.size(); i++){
61
            		for(int j=0; j<i; j++){
62
            			Long itemOne = itemIds.get(i);
63
            			Long itemTwo = itemIds.get(j);
64
            			Map<Long, Long> comparedItems;
65
            			comparedItems = comparisonStats.get(itemOne);
66
            			if(comparedItems==null){
67
            				comparedItems = new HashMap<Long, Long>();
68
            				comparisonStats.put(itemOne, comparedItems);
69
            			}
70
            			if(comparedItems.containsKey(itemTwo)){
71
            				comparedItems.put(itemTwo, comparedItems.get(itemTwo)+1);
72
            			}else{
73
            				comparedItems.put(itemTwo, 1L);
74
            			}
75
 
76
            			comparedItems = comparisonStats.get(itemTwo);
77
            			if(comparedItems==null){
78
            				comparedItems = new HashMap<Long, Long>();
79
            				comparisonStats.put(itemTwo, comparedItems);
80
            			}
81
            			if(comparedItems.containsKey(itemOne)){
82
            				comparedItems.put(itemOne, comparedItems.get(itemOne)+1);
83
            			}else{
84
            				comparedItems.put(itemOne, 1L);
85
            			}
86
            		}
87
            	}
88
            }
89
        }
90
 
91
        SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMdd");
3498 rajveer 92
        String id = sdf.format(toDate);  
3487 rajveer 93
 
94
 
3504 rajveer 95
        JSONObject comparisonStatsJSON = new JSONObject(comparisonStats);
3487 rajveer 96
 
97
        ComparisonStats compStats = new ComparisonStats();
98
        compStats.setId(id);
3518 rajveer 99
        compStats.setComparisonStatsJSON(new Text(comparisonStatsJSON.toString()));
3487 rajveer 100
 
101
        ComparisonStatsRepository repo = new ComparisonStatsRepository();
102
        repo.store(compStats);
103
    }
104
 
105
    public void doGet(HttpServletRequest req, HttpServletResponse resp) {
106
        doPost(req, resp);
107
    }
108
}