forked from stan1y/proto
-
Notifications
You must be signed in to change notification settings - Fork 0
/
server.py
33 lines (27 loc) · 912 Bytes
/
server.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
'''
The Proto! Python Async RPC based on ProtocolBuffers and TCP sockets.
Licensed under LPGLv2+.
Created on Oct 24, 2009
@author: Stanislav Yudin
'''
import sys, logging
import sample_pb2, proto
log = logging.getLogger(__name__)
class sample_impl(proto.ProtoServer, sample_pb2.sample_rpc):
def __init__(self, addr):
proto.ProtoServer.__init__(self, addr)
log.debug('starting service %s' % type(self).__name__)
def the_method(self, rpc_controller, request, done):
log.debug('%s called with %s' % (__name__, request))
rsp = sample_pb2.sample_response()
rsp.answer = 'answer!'
return rsp
logging.basicConfig(level=logging.DEBUG)
log = logging.getLogger(__name__)
if __name__ == '__main__':
port = 9999
if len(sys.argv) == 2:
port = int(sys.argv[1])
#running server with specific generated files and
#module containing service implementation(s)
sample_impl.run_server(port, sample_pb2)