Subversion Repositories SmartDukaan

Rev

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