Subversion Repositories SmartDukaan

Rev

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