Subversion Repositories SmartDukaan

Rev

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

Rev Author Line No. Line
3232 varun.gupt 1
'''
2
Created on 31-Aug-2011
3
 
4
@author: Varun Gupta
5
'''
6
import tornado.httpserver
7
import tornado.ioloop
8
import tornado.web
9
import json, os, ConfigParser, sys
10
from PyLucene.Retriever import Retriever
3313 varun.gupt 11
from Utils import getItemsWithTopScore, isPriceSame, getProductClusters, getFilteredClustersWithTopScores, \
12
    getDisplayInfo
3232 varun.gupt 13
 
3235 rajveer 14
cmd_folder = os.path.dirname(os.path.abspath(os.environ["HOME"] + "/code/trunk/PyProj/src/shop2020/"))
3232 varun.gupt 15
if cmd_folder not in sys.path:
16
    sys.path.insert(0, cmd_folder)
17
 
18
from shop2020.clients.CatalogClient import CatalogClient
3350 varun.gupt 19
from shop2020.thriftpy.model.v1.catalog.ttypes import status
3232 varun.gupt 20
 
21
class BaseHandler(tornado.web.RequestHandler):
22
    def get_current_user(self):
23
        return self.get_secure_cookie('userauth')
24
 
25
class LoginHandler(BaseHandler):
26
    def get(self):
27
        self.loader = tornado.template.Loader('HTMLTemplates')
28
        self.write(self.loader.load('LoginForm.html').generate())
29
 
30
    def post(self):
31
        config = ConfigParser.SafeConfigParser()
32
        config.read('app.cfg')
33
 
34
        username = self.get_argument('username')
35
        password = self.get_argument('password')
36
 
37
        if username == config.get('auth', 'username') and password == config.get('auth', 'password'):
38
            print 'Password Matched'
39
            self.set_secure_cookie("userauth", username + '_' + password)
40
            self.redirect('/')
41
        else:
42
            self.redirect('/login')
43
 
44
class MainHandler(BaseHandler):
45
 
46
    @tornado.web.authenticated
47
    def get(self):
48
        self.loader = tornado.template.Loader('HTMLTemplates')
49
        catalog_client = CatalogClient().get_client()
3350 varun.gupt 50
        items = catalog_client.getAllItemsByStatus(status.ACTIVE)
51
        items.extend(catalog_client.getAllItemsByStatus(status.PAUSED))
52
        items.extend(catalog_client.getAllItemsByStatus(status.PAUSED_BY_RISK))
3232 varun.gupt 53
 
54
        retriever = Retriever()
55
        products = {}
56
 
57
        for item in items:
58
            if item.category in (10002, 10003, 10004, 10005, 10010):  products[item.catalogItemId] = item
59
 
60
        comparative_prices = []
3313 varun.gupt 61
 
3232 varun.gupt 62
        for item in sorted(products.itervalues(), key = lambda item: item.brand):
63
            try:
64
                model_name = item.modelName.strip() if len(item.modelName.strip()) > 0 else None
65
                model_number = item.modelNumber.strip() if len(item.modelNumber.strip()) > 0 else None
66
 
67
                search_results = retriever.retrieve(model_number = model_number, model_name = model_name, brand = item.brand)
68
 
3313 varun.gupt 69
                clusters = getProductClusters(search_results)
70
                filtered_clusters = getFilteredClustersWithTopScores(clusters)
3232 varun.gupt 71
 
3313 varun.gupt 72
                display_info = getDisplayInfo(filtered_clusters)
73
 
3232 varun.gupt 74
                product_name = "%s " % item.brand
75
                product_name += "%s " % model_name if model_name is not None else ''
76
                product_name += model_number if model_number is not None else ''
77
 
3313 varun.gupt 78
                display_info['product_name'] = product_name
79
                display_info['saholic'] = {'price': item.sellingPrice}
80
                comparative_prices.append(display_info)
3232 varun.gupt 81
            except Exception as e:
3313 varun.gupt 82
                print e
3232 varun.gupt 83
 
84
        self.write(self.loader.load('PriceChart.html').generate(data = comparative_prices))
85
 
86
 
87
settings  = {
88
        'static_path': os.path.join(os.path.dirname(__file__), 'static'),
89
        'login_url': '/login', 
90
        'cookie_secret' :"61oETzKXQAGaYdkL5gEmGeJJFuYh7EQnp2XdTP1o/Vo="
91
}
92
 
93
application = tornado.web.Application([
94
                (r"/", MainHandler),
95
                (r"/login", LoginHandler),
96
                (r"/(jquery-1.6.2.min\.js)", tornado.web.StaticFileHandler, dict(path=settings['static_path']))
97
            ], **settings)
98
 
99
if __name__ == '__main__':
100
    http_server = tornado.httpserver.HTTPServer(application)
101
    http_server.listen(8889)
102
    tornado.ioloop.IOLoop.instance().start()