Subversion Repositories SmartDukaan

Rev

Rev 3915 | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
412 ashish 1
'''
2
Created on 05-Aug-2010
3
 
4
@author: ashish
5
'''
3915 chandransh 6
import optparse
7
import sys
8
import os
9
 
10
if __name__ == '__main__' and __package__ is None:
11
    sys.path.insert(0, os.getcwd())
12
 
412 ashish 13
from thrift.transport import TSocket, TTransport
14
from thrift.protocol.TBinaryProtocol import TBinaryProtocolFactory
15
from thrift.server import TServer
3915 chandransh 16
 
17
from shop2020.utils.daemon import Daemon
18
from shop2020.config.client.ConfigClient import ConfigClient
412 ashish 19
from shop2020.logistics.service.impl.LogisticsServiceHandler import LogisticsServiceHandler
20
from shop2020.thriftpy.logistics import LogisticsService
21
 
3915 chandransh 22
class LogisticsServer(Daemon):
23
 
24
    def __init__(self, logfile='/var/log/services/logistics.log', pidfile='/tmp/logistics-server.pid'):
25
        Daemon.__init__(self, pidfile, stdout=logfile, stderr=logfile)
412 ashish 26
 
3915 chandransh 27
    def run(self):
28
        #get the config client
4651 rajveer 29
        config_client = ConfigClient()
30
        host_name = config_client.get_property('logistics_service_server_host')
31
        port = int(config_client.get_property('logistics_service_server_port'))
32
        dbname = config_client.get_property('logistics_service_dbname')
33
        db_hostname = config_client.get_property('logistics_service_db_hostname')
3915 chandransh 34
 
35
        handler = LogisticsServiceHandler(dbname, db_hostname)
36
        processor = LogisticsService.Processor(handler)
37
        transport = TSocket.TServerSocket(port=port)
38
        tfactory = TTransport.TFramedTransportFactory()
39
        pfactory = TBinaryProtocolFactory()
40
        server = TServer.TThreadedServer(processor, transport, tfactory, pfactory)
41
        print "Starting LogisticsService at, port "+ str(port)+" host "+host_name
42
        server.serve()
43
        print "Server functioning"
412 ashish 44
 
45
 
3915 chandransh 46
if __name__ == "__main__":
47
    parser = optparse.OptionParser()
48
    parser.add_option("-l", "--logfile", dest="logfile",
49
                      type="string",
50
                      help="Log all output to LOG_FILE",
51
                      )
52
    parser.add_option("-i", "--pidfile", dest="pidfile",
53
                      type="string",
54
                      help="Write the PID to pidfile")
55
    (options, args) = parser.parse_args()
56
    daemon = LogisticsServer(options.logfile, options.pidfile)
57
    if len(args) == 0:
58
        daemon.run()
59
    elif len(args) == 1:
60
        if 'start' == args[0]:
61
            daemon.start()
62
        elif 'stop' == args[0]:
63
            daemon.stop()
64
        elif 'restart' == args[0]:
65
            daemon.restart()
66
        else:
67
            print "Unknown command"
68
            sys.exit(2)
69
        sys.exit(0)
70
    else:
71
        print "usage: %s start|stop|restart" % sys.argv[0]
72
        sys.exit(2)