Subversion Repositories SmartDukaan

Rev

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

Rev Author Line No. Line
317 ashish 1
/**
2
 * 
3
 */
4
package in.shop2020.serving.controllers;
5
 
650 rajveer 6
 
2306 vikas 7
import in.shop2020.datalogger.EventType;
8
import in.shop2020.model.v1.catalog.Item;
9
import in.shop2020.model.v1.user.UserContextService.Client;
3225 vikas 10
import in.shop2020.serving.utils.EhcacheWrapper;
3126 rajveer 11
import in.shop2020.thrift.clients.CatalogClient;
12
import in.shop2020.thrift.clients.UserClient;
2511 vikas 13
import in.shop2020.utils.DataLogger;
375 ashish 14
 
317 ashish 15
import java.io.IOException;
3225 vikas 16
import java.util.HashMap;
375 ashish 17
import java.util.Map;
507 rajveer 18
import java.util.StringTokenizer;
317 ashish 19
 
3225 vikas 20
import net.sf.ehcache.CacheManager;
21
 
832 rajveer 22
import org.apache.log4j.Logger;
507 rajveer 23
import org.apache.struts2.convention.annotation.Action;
24
import org.apache.struts2.convention.annotation.Actions;
974 vikas 25
import org.apache.struts2.convention.annotation.Result;
2306 vikas 26
import org.apache.struts2.convention.annotation.Results;
27
import org.json.JSONException;
28
import org.json.JSONObject;
317 ashish 29
 
30
/**
31
 * 
650 rajveer 32
 * @author rajveer
317 ashish 33
 *
34
 */
650 rajveer 35
 
2306 vikas 36
@Results({
37
    @Result(name = "show", location = "entity-show.vm"),
38
    @Result(name = "redirect", location = "${redirectUrl}", type = "redirect")
39
})
650 rajveer 40
public class EntityController extends BaseController {
41
 
42
	private static final long serialVersionUID = 1L;
1957 vikas 43
	private static Logger log = Logger.getLogger(Class.class);
3225 vikas 44
 
45
	private static final String PRODUCT_PROERTIES_SNIPPET_KEY = "PRODUCT_PROPERTIES";
46
	private static final String PRODUCT_SUMMARY_SNIPPET_KEY = "PRODUCT_SUMMARY";
47
	private static final String PRODUCT_SLIDEGUIDE_KEY = "SLIDEGUIDE";
48
 
317 ashish 49
	private String id;
2306 vikas 50
	private String redirectUrl;
620 rajveer 51
	private long productId;
2867 rajveer 52
	private boolean isMobile = false;
53
 
3225 vikas 54
	private Map<String, String> snippets;
55
 
375 ashish 56
	public EntityController(){
57
		super();
58
	}
507 rajveer 59
 
974 vikas 60
	// GET /*/1000001
507 rajveer 61
	@Actions({
974 vikas 62
		@Action("/mobile-phones"),
1005 vikas 63
		@Action("/mobile-accessories"),
2460 rajveer 64
		@Action("/tablets"),
1005 vikas 65
		@Action("/entity")
507 rajveer 66
	})
2306 vikas 67
    public String show() throws SecurityException, IOException, JSONException {
317 ashish 68
    	log.info("id=" + id);
637 rajveer 69
 
2306 vikas 70
    	String entityUrl = "";
71
    	String metaKeywords = "";
72
    	String metaDescription = "";
73
    	String pageTitle = "";
2434 rajveer 74
    	String productName = "";
2652 rajveer 75
    	String displayAccessories = "FALSE";
2306 vikas 76
    	try {
3225 vikas 77
    	    setSnippets();
78
            htmlSnippets.put("PRODUCT_PROPERTIES", snippets.get(PRODUCT_PROERTIES_SNIPPET_KEY));
79
    	    JSONObject productPropertiesInJson = new JSONObject(htmlSnippets.get("PRODUCT_PROPERTIES"));
2306 vikas 80
    	    entityUrl = productPropertiesInJson.getString("entityUrl");
81
    	    metaDescription = productPropertiesInJson.getString("metaDescription");
82
    	    metaKeywords = productPropertiesInJson.getString("metaKeywords");
83
    	    pageTitle = productPropertiesInJson.getString("title");
2434 rajveer 84
    	    productName = productPropertiesInJson.getString("name");
2652 rajveer 85
    	    displayAccessories = productPropertiesInJson.getString("displayAccessories");
2306 vikas 86
    	}
87
    	catch (JSONException e) {
2949 chandransh 88
            log.error("Unable to parse product properties JSON", e);
2306 vikas 89
            try {
3126 rajveer 90
                CatalogClient catalogClientService = new CatalogClient();
2306 vikas 91
                in.shop2020.model.v1.catalog.InventoryService.Client client = catalogClientService.getClient();
92
 
93
                Item item = client.getItemsByCatalogId(productId).get(0);
2307 vikas 94
                redirectUrl = "/" + item.getBrand().toLowerCase().replace(" ", "-");
2306 vikas 95
            } catch (Exception e1) {
2949 chandransh 96
                log.error("Unable to get items by catalog id", e1);
2306 vikas 97
                redirectUrl = "/";
98
            }
99
            log.info(redirectUrl);
100
            return "redirect";
101
       }
102
    	String currentUrl = request.getRequestURL().toString();
1197 varun.gupt 103
 
2306 vikas 104
    	if (!currentUrl.contains(entityUrl)) {
105
    	    redirectUrl = entityUrl;
106
    	    return "redirect";
107
    	}
108
 
2434 rajveer 109
    	//Extracting base url
1689 rajveer 110
    	String rootUrl = currentUrl.split("/")[2];
2194 varun.gupt 111
 
3225 vikas 112
    	htmlSnippets.put("PRODUCT_SUMMARY", snippets.get(PRODUCT_SUMMARY_SNIPPET_KEY));
1258 varun.gupt 113
    	htmlSnippets.put("PRODUCT_ID", productId + "");
114
    	htmlSnippets.put("PRODUCT_NAME", productName);
1689 rajveer 115
    	htmlSnippets.put("PRODUCT_URL", currentUrl);
2194 varun.gupt 116
    	htmlSnippets.put("ROOT_URL", "http://" + rootUrl);
3225 vikas 117
		htmlSnippets.put("SLIDE_GUIDE", snippets.get(PRODUCT_SLIDEGUIDE_KEY));
1269 varun.gupt 118
		htmlSnippets.put("PAGE_TITLE", pageTitle.trim());
2306 vikas 119
		htmlSnippets.put("PAGE_METADESC", metaDescription);
120
		htmlSnippets.put("PAGE_METAKEYWORDS", metaKeywords);
2652 rajveer 121
		if(displayAccessories.equals("TRUE")){
2867 rajveer 122
			setMobile(true);
2652 rajveer 123
		}
124
 
650 rajveer 125
		try {
3126 rajveer 126
			UserClient userServiceClient = new UserClient();
555 chandransh 127
			Client client = userServiceClient.getClient();
773 rajveer 128
			long itemId = Long.parseLong(id);
129
			long userId = userinfo.getUserId();
1511 rajveer 130
			if(userId != -1){
131
				client.updateBrowseHistory(userId, itemId);
132
			}
650 rajveer 133
 
449 rajveer 134
		} catch (Exception e) {
2949 chandransh 135
			log.warn("Unable to update the browsing history because of: ", e);
449 rajveer 136
		}
137
 
3185 vikas 138
		DataLogger.logData(EventType.PRODUCT_VIEW, getSessionId(), userinfo.getUserId(), userinfo.getEmail(),
3074 vikas 139
                productName, Long.toString(productId));
2149 vikas 140
		return "show";
317 ashish 141
    }
3225 vikas 142
 
317 ashish 143
    /**
144
     * 
145
     * @param id
146
     */
147
    public void setId(String id) {
507 rajveer 148
    	StringTokenizer tokenizer = new StringTokenizer(id,"-");
149
    	while(tokenizer.hasMoreTokens()){
150
    		this.id = tokenizer.nextToken();
151
    	}
974 vikas 152
    	this.productId = Long.parseLong(this.id);
317 ashish 153
    }
154
 
387 rajveer 155
	public Map<String,String> getHtmlSnippets(){
388 rajveer 156
		System.out.println(" getHtmlSnippets  is called");
387 rajveer 157
		return htmlSnippets;
375 ashish 158
	}
388 rajveer 159
 
449 rajveer 160
	public String getSlideGuideSnippet(){
388 rajveer 161
		return htmlSnippets.get("SLIDE_GUIDE");
162
	}
163
 
2306 vikas 164
	public String getRedirectUrl(){
165
        return redirectUrl;
166
    }
167
 
449 rajveer 168
	public String getProductSummarySnippet(){
169
		return htmlSnippets.get("PRODUCT_SUMMARY");
170
	}
171
 
974 vikas 172
	public String getPageTitleSnippet(){
173
		return htmlSnippets.get("PAGE_TITLE");
174
	}
175
 
176
	public String getPageMetaDescSnippet(){
177
		return htmlSnippets.get("PAGE_METADESC");
178
	}
179
 
180
	public String getPageMetaKeywordsSnippet(){
181
		return htmlSnippets.get("PAGE_METAKEYWORDS");
182
	}
183
 
1197 varun.gupt 184
	public String getProductName()	{
185
		return htmlSnippets.get("PRODUCT_NAME");
186
	}
1258 varun.gupt 187
 
188
	public String getProductId()	{
189
		return htmlSnippets.get("PRODUCT_ID");
190
	}
191
 
192
	public String getProductUrl()	{
193
		return htmlSnippets.get("PRODUCT_URL");
194
	}
1364 varun.gupt 195
 
196
	public String getRootUrl()	{
197
		return htmlSnippets.get("ROOT_URL");
198
	}
2867 rajveer 199
 
200
	/**
201
	 * @param isMobile the isMobile to set
202
	 */
203
	public void setMobile(boolean isMobile) {
204
		this.isMobile = isMobile;
2652 rajveer 205
	}
2867 rajveer 206
 
207
	/**
208
	 * @return the isMobile
209
	 */
210
	public boolean isMobile() {
211
		return isMobile;
212
	}
3225 vikas 213
 
214
    private void setSnippets() {
215
        EhcacheWrapper<Long, Map<String, String>> productSnippetsCache = new EhcacheWrapper<Long, Map<String, String>>(
216
                EhcacheWrapper.PRODUCT_PAGE_SNIPPET_CACHE_NAME, CacheManager.create());
217
        snippets = productSnippetsCache.get(productId);
218
        if (snippets == null) {
219
            log.info("Getting product snippet for :" + productId);
220
            snippets = new HashMap<String, String>();
221
            snippets.put(PRODUCT_PROERTIES_SNIPPET_KEY, pageLoader.getProductPropertiesHtml(productId).trim());
222
            snippets.put(PRODUCT_SUMMARY_SNIPPET_KEY, pageLoader.getProductSummaryHtml(productId));
223
            snippets.put(PRODUCT_SLIDEGUIDE_KEY, pageLoader.getSlideGuideHtml(productId));
224
            productSnippetsCache.put(productId, snippets);
225
            return;
226
        }
227
        log.info("Loaded from cache product snippet for :" + productId);
228
    }
229
 
1197 varun.gupt 230
}