Subversion Repositories SmartDukaan

Rev

Rev 3126 | Rev 3266 | 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;
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
 
3126 rajveer 46
	CatalogClient catalogClientService = null;
545 rajveer 47
 
48
 
49
 
50
	public LatestArrivalsController() {
51
		super();
52
		try {
3126 rajveer 53
			catalogClientService = new CatalogClient();
545 rajveer 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);
3118 vikas 71
        setSnippets();
545 rajveer 72
    	return new DefaultHttpHeaders("index");
73
    }
74
 
75
    // GET /show
76
    public HttpHeaders show() {
3112 vikas 77
        EhcacheWrapper<String, Object> showcasePageSnippetsCache = new EhcacheWrapper<String, Object>(
78
                EhcacheWrapper.SHOWCASE_PAGE_SNIPPET_CACHE_NAME, CacheManager.create());
79
        this.snippets = (List<String>)showcasePageSnippetsCache.get(SHOWCASE_LATEST_ARRIVALS_CACHE_KEY + beginIndex);
80
        this.totalItems = (Long)showcasePageSnippetsCache.get(SHOWCASE_LATEST_ARRIVALS_COUNT_CACHE_KEY);
81
        if(this.snippets != null && !this.snippets.isEmpty() && this.totalItems > 0) {
82
            log.info("Using Cache.");
83
            return new DefaultHttpHeaders("show");
84
        }
85
        log.info("Getting latest arrivals from snippets.");
545 rajveer 86
    	in.shop2020.model.v1.catalog.InventoryService.Client client = catalogClientService.getClient();
87
    	try {
590 chandransh 88
			this.setTotalItems(client.getLatestArrivalsCount());
3112 vikas 89
			showcasePageSnippetsCache.put(SHOWCASE_LATEST_ARRIVALS_COUNT_CACHE_KEY, this.totalItems);
2975 chandransh 90
			this.items = client.getLatestArrivalsCatalogIds(beginIndex, windowSize, null, new ArrayList<Long>());
3112 vikas 91
			setSnippets();
92
            showcasePageSnippetsCache.put(SHOWCASE_LATEST_ARRIVALS_CACHE_KEY + beginIndex, this.snippets);
545 rajveer 93
		} catch (InventoryServiceException e) {
2949 chandransh 94
			log.error("Unable to get latest arrivals from inventory service.", e);
545 rajveer 95
		} catch (TException e) {
2949 chandransh 96
			log.error("Unable to get latest arrivals from inventory service.", e);
545 rajveer 97
		}
98
    	return new DefaultHttpHeaders("show");
99
    }
100
 
3112 vikas 101
    public void setSnippets(){
102
    	snippets = new ArrayList<String>();
741 rajveer 103
    	if(items != null){
104
    		for(long item: items){
968 chandransh 105
    			try{
106
    				snippets.add(FileUtils.read( Utils.EXPORT_ENTITIES_PATH + item + File.separator +"CategorySnippet.html"));
107
    			}catch(IOException ioex){
2949 chandransh 108
    				log.error("Unable to read snippet for " + item, ioex);
968 chandransh 109
    			}
741 rajveer 110
			}
111
    	}
545 rajveer 112
    }
113
 
3112 vikas 114
    public List<String> getSnippets() {
115
        return snippets;
116
    }
117
 
545 rajveer 118
	public void setId(String id) {
119
		this.id = id;
2943 chandransh 120
		this.beginIndex = windowSize * (Long.parseLong(id)-1);
545 rajveer 121
	}
122
 
123
	public String getId() {
124
		return id;
125
	}
126
 
127
	public long getBeginIndex(){
128
		if(totalItems>0)
129
			return beginIndex+1;
130
		return beginIndex;
131
	}
132
 
133
	public void setTotalItems(long totalItems) {
134
		this.totalItems = totalItems;
135
	}
136
 
137
	public long getTotalItems() {
138
		return totalItems;
139
	}
140
 
141
	public long getTotalPages() {
2950 chandransh 142
	    return 1 + (totalItems-1)/windowSize;
545 rajveer 143
	}
144
 
145
	public long getCurrentPage() {
146
		return Long.parseLong(getId());
147
	}
148
}