Subversion Repositories SmartDukaan

Rev

Rev 3539 | Go to most recent revision | 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
29
        try:
30
            config_client = ConfigClient()
31
            host_name = config_client.get_property('logistics_service_server_host')
32
            port = int(config_client.get_property('logistics_service_server_port'))
33
            dbname = config_client.get_property('logistics_service_dbname')
34
            db_hostname = config_client.get_property('logistics_service_db_hostname')
35
        except:
36
            #error while spawning the config server
37
            host_name = 'localhost'
38
            port = 9011
39
            dbname='logistics'
40
            db_hostname = 'localhost'
41
 
42
        handler = LogisticsServiceHandler(dbname, db_hostname)
43
        processor = LogisticsService.Processor(handler)
44
        transport = TSocket.TServerSocket(port=port)
45
        tfactory = TTransport.TFramedTransportFactory()
46
        pfactory = TBinaryProtocolFactory()
47
        server = TServer.TThreadedServer(processor, transport, tfactory, pfactory)
48
        print "Starting LogisticsService at, port "+ str(port)+" host "+host_name
49
        server.serve()
50
        print "Server functioning"
412 ashish 51
 
52
 
3915 chandransh 53
if __name__ == "__main__":
54
    parser = optparse.OptionParser()
55
    parser.add_option("-l", "--logfile", dest="logfile",
56
                      type="string",
57
                      help="Log all output to LOG_FILE",
58
                      )
59
    parser.add_option("-i", "--pidfile", dest="pidfile",
60
                      type="string",
61
                      help="Write the PID to pidfile")
62
    (options, args) = parser.parse_args()
63
    daemon = LogisticsServer(options.logfile, options.pidfile)
64
    if len(args) == 0:
65
        daemon.run()
66
    elif len(args) == 1:
67
        if 'start' == args[0]:
68
            daemon.start()
69
        elif 'stop' == args[0]:
70
            daemon.stop()
71
        elif 'restart' == args[0]:
72
            daemon.restart()
73
        else:
74
            print "Unknown command"
75
            sys.exit(2)
76
        sys.exit(0)
77
    else:
78
        print "usage: %s start|stop|restart" % sys.argv[0]
79
        sys.exit(2)