| #!/usr/bin/env python |
| |
| import sys |
| sys.path.append('../gen-py') |
| |
| from tutorial import Calculator |
| from tutorial.ttypes import * |
| |
| from shared.ttypes import SharedStruct |
| |
| from thrift.transport import TSocket |
| from thrift.transport import TTransport |
| from thrift.protocol import TBinaryProtocol |
| from thrift.server import TServer |
| |
| class CalculatorHandler: |
| def __init__(self): |
| self.log = {} |
| |
| def ping(self): |
| print 'ping()' |
| |
| def add(self, n1, n2): |
| print 'add(%d,%d)' % (n1, n2) |
| return n1+n2 |
| |
| def calculate(self, logid, work): |
| print 'calculate(%d, %s)' % (logid, work.__str__()) |
| |
| if work.op == Operation.ADD: |
| val = work.num1 + work.num2 |
| elif work.op == Operation.SUBTRACT: |
| val = work.num1 - work.num2 |
| elif work.op == Operation.MULTIPLY: |
| val = work.num1 * work.num2 |
| elif work.op == Operation.DIVIDE: |
| if work.num2 == 0: |
| x = InvalidOperation() |
| x.what = work.op |
| x.why = 'Cannot divide by 0' |
| raise x |
| val = work.num1 / work.num2 |
| else: |
| x = InvalidOperation() |
| x.what = work.op |
| x.why = 'Invalid operation' |
| raise x |
| |
| log = SharedStruct() |
| log.key = logid |
| log.value = '%d' % (val) |
| self.log[logid] = log |
| |
| return val |
| |
| def getStruct(self, key): |
| print 'getStruct(%d)' % (key) |
| return self.log[key] |
| |
| def zip(self): |
| print 'zip()' |
| |
| handler = CalculatorHandler() |
| processor = Calculator.Processor(handler) |
| transport = TSocket.TServerSocket(9090) |
| tfactory = TTransport.TBufferedTransportFactory() |
| pfactory = TBinaryProtocol.TBinaryProtocolFactory() |
| |
| server = TServer.TSimpleServer(processor, transport, tfactory, pfactory) |
| |
| # You could do one of these for a multithreaded server |
| #server = TServer.TThreadedServer(processor, transport, tfactory, pfactory) |
| #server = TServer.TThreadPoolServer(processor, transport, tfactory, pfactory) |
| |
| print 'Starting the server...' |
| server.serve() |
| print 'done.' |