Subversion Repositories SmartDukaan

Rev

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

Rev Author Line No. Line
545 rajveer 1
package in.shop2020.serving.controllers;
2
 
3017 vikas 3
import in.shop2020.model.v1.catalog.InventoryServiceException;
3242 vikas 4
import in.shop2020.serving.cache.EhcacheWrapper;
3017 vikas 5
import in.shop2020.serving.utils.FileUtils;
6
import in.shop2020.serving.utils.Utils;
3126 rajveer 7
import in.shop2020.thrift.clients.CatalogClient;
3017 vikas 8
 
741 rajveer 9
import java.io.File;
968 chandransh 10
import java.io.IOException;
741 rajveer 11
import java.util.ArrayList;
3266 chandransh 12
import java.util.Arrays;
545 rajveer 13
import java.util.List;
14
 
3112 vikas 15
import net.sf.ehcache.CacheManager;
16
 
832 rajveer 17
import org.apache.log4j.Logger;
545 rajveer 18
import org.apache.struts2.rest.DefaultHttpHeaders;
19
import org.apache.struts2.rest.HttpHeaders;
20
import org.apache.thrift.TException;
21
 
22
/**
23
 * get latest arrivals items from the catalog service
24
 * @author rajveer
25
 *	
26
 */
2975 chandransh 27
@SuppressWarnings("serial")
545 rajveer 28
public class LatestArrivalsController extends BaseController {
29
 
832 rajveer 30
	private static Logger log = Logger.getLogger(Class.class);
545 rajveer 31
 
2943 chandransh 32
	private static final int windowSize = 20;
545 rajveer 33
 
3112 vikas 34
	private static final String SHOWCASE_LATEST_ARRIVALS_CACHE_KEY = "SHOWCASE_LATEST_ARRIVALS";
35
    private static final String SHOWCASE_LATEST_ARRIVALS_COUNT_CACHE_KEY = "SHOWCASE_LATEST_ARRIVALS_COUNT";
36
 
545 rajveer 37
	private long beginIndex = 0;
38
 
3112 vikas 39
	private Long totalItems = 0l;
545 rajveer 40
 
41
	private String id;
42
 
43
	List<Long> items = null;
44
 
3112 vikas 45
	private List<String> snippets = null;
46
 
3126 rajveer 47
	CatalogClient catalogClientService = null;
545 rajveer 48
 
49
 
50
 
51
	public LatestArrivalsController() {
52
		super();
53
		try {
3126 rajveer 54
			catalogClientService = new CatalogClient();
545 rajveer 55
		} catch (Exception e) {
2949 chandransh 56
			log.error("Unable to get catalog service client.", e);
545 rajveer 57
		}
58
	}
59
 
60
    // GET /index
61
    public HttpHeaders index() throws Exception {
637 rajveer 62
    	long categoryId = Long.parseLong(request.getParameter("categoryid"));
1923 rajveer 63
    	String brandName = request.getParameter("brand");
3017 vikas 64
    	List<Long> latestArrivalCategories = new ArrayList<Long>();
1923 rajveer 65
    	//Right now if we have brand name, we can just send back for all categories
3017 vikas 66
    	if(brandName==null){
67
    	    latestArrivalCategories.add(categoryId);
1923 rajveer 68
    	}
545 rajveer 69
    	in.shop2020.model.v1.catalog.InventoryService.Client client = catalogClientService.getClient();
3017 vikas 70
 
3112 vikas 71
        this.items = client.getLatestArrivalsCatalogIds(beginIndex, windowSize, brandName, latestArrivalCategories);
3118 vikas 72
        setSnippets();
545 rajveer 73
    	return new DefaultHttpHeaders("index");
74
    }
75
 
76
    // GET /show
77
    public HttpHeaders show() {
3112 vikas 78
        EhcacheWrapper<String, Object> showcasePageSnippetsCache = new EhcacheWrapper<String, Object>(
79
                EhcacheWrapper.SHOWCASE_PAGE_SNIPPET_CACHE_NAME, CacheManager.create());
80
        this.snippets = (List<String>)showcasePageSnippetsCache.get(SHOWCASE_LATEST_ARRIVALS_CACHE_KEY + beginIndex);
81
        this.totalItems = (Long)showcasePageSnippetsCache.get(SHOWCASE_LATEST_ARRIVALS_COUNT_CACHE_KEY);
82
        if(this.snippets != null && !this.snippets.isEmpty() && this.totalItems > 0) {
83
            log.info("Using Cache.");
84
            return new DefaultHttpHeaders("show");
85
        }
86
        log.info("Getting latest arrivals from snippets.");
545 rajveer 87
    	in.shop2020.model.v1.catalog.InventoryService.Client client = catalogClientService.getClient();
88
    	try {
590 chandransh 89
			this.setTotalItems(client.getLatestArrivalsCount());
3112 vikas 90
			showcasePageSnippetsCache.put(SHOWCASE_LATEST_ARRIVALS_COUNT_CACHE_KEY, this.totalItems);
3266 chandransh 91
			this.items = client.getLatestArrivalsCatalogIds(beginIndex, windowSize, null, Arrays.asList(new Long[]{10002L, 10003L, 10010L}));
3112 vikas 92
			setSnippets();
93
            showcasePageSnippetsCache.put(SHOWCASE_LATEST_ARRIVALS_CACHE_KEY + beginIndex, this.snippets);
545 rajveer 94
		} catch (InventoryServiceException e) {
2949 chandransh 95
			log.error("Unable to get latest arrivals from inventory service.", e);
545 rajveer 96
		} catch (TException e) {
2949 chandransh 97
			log.error("Unable to get latest arrivals from inventory service.", e);
545 rajveer 98
		}
99
    	return new DefaultHttpHeaders("show");
100
    }
101
 
3112 vikas 102
    public void setSnippets(){
103
    	snippets = new ArrayList<String>();
741 rajveer 104
    	if(items != null){
105
    		for(long item: items){
968 chandransh 106
    			try{
107
    				snippets.add(FileUtils.read( Utils.EXPORT_ENTITIES_PATH + item + File.separator +"CategorySnippet.html"));
108
    			}catch(IOException ioex){
2949 chandransh 109
    				log.error("Unable to read snippet for " + item, ioex);
968 chandransh 110
    			}
741 rajveer 111
			}
112
    	}
545 rajveer 113
    }
114
 
3112 vikas 115
    public List<String> getSnippets() {
116
        return snippets;
117
    }
118
 
545 rajveer 119
	public void setId(String id) {
120
		this.id = id;
2943 chandransh 121
		this.beginIndex = windowSize * (Long.parseLong(id)-1);
545 rajveer 122
	}
123
 
124
	public String getId() {
125
		return id;
126
	}
127
 
128
	public long getBeginIndex(){
129
		if(totalItems>0)
130
			return beginIndex+1;
131
		return beginIndex;
132
	}
133
 
134
	public void setTotalItems(long totalItems) {
135
		this.totalItems = totalItems;
136
	}
137
 
138
	public long getTotalItems() {
139
		return totalItems;
140
	}
141
 
142
	public long getTotalPages() {
2950 chandransh 143
	    return 1 + (totalItems-1)/windowSize;
545 rajveer 144
	}
145
 
146
	public long getCurrentPage() {
147
		return Long.parseLong(getId());
148
	}
149
}