blob: c73fecf42afc7356bafc4a10b002b1655b074c52 [file] [log] [blame]
Kevin Clarkab4460d2009-03-20 02:28:41 +00001/**
2 * Licensed to the Apache Software Foundation (ASF) under one
3 * or more contributor license agreements. See the NOTICE file
4 * distributed with this work for additional information
5 * regarding copyright ownership. The ASF licenses this file
6 * to you under the Apache License, Version 2.0 (the
7 * "License"); you may not use this file except in compliance
8 * with the License. You may obtain a copy of the License at
9 *
10 * http://www.apache.org/licenses/LICENSE-2.0
11 *
12 * Unless required by applicable law or agreed to in writing,
13 * software distributed under the License is distributed on an
14 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15 * KIND, either express or implied. See the License for the
16 * specific language governing permissions and limitations
17 * under the License.
Todd Lipcon53ae9f32009-12-07 00:42:38 +000018 *
19 * Contains some contributions under the Thrift Software License.
20 * Please see doc/old-thrift-license.txt in the Thrift distribution for
21 * details.
Kevin Clarkab4460d2009-03-20 02:28:41 +000022 */
23
David Reiss7f42bcf2008-01-11 20:59:12 +000024using System;
David Reiss7f42bcf2008-01-11 20:59:12 +000025using Thrift.Transport;
26using Thrift.Protocol;
27
28namespace Thrift.Server
29{
Randy Abernethy0e86f1f2014-07-13 09:50:19 -070030 /// <summary>
31 /// Simple single-threaded server for testing
32 /// </summary>
33 public class TSimpleServer : TServer
34 {
35 private bool stop = false;
David Reiss63191332009-01-06 19:49:22 +000036
Randy Abernethy0e86f1f2014-07-13 09:50:19 -070037 public TSimpleServer(TProcessor processor,
38 TServerTransport serverTransport)
39 : base(processor, serverTransport, new TTransportFactory(), new TTransportFactory(), new TBinaryProtocol.Factory(), new TBinaryProtocol.Factory(), DefaultLogDelegate)
40 {
41 }
David Reiss63191332009-01-06 19:49:22 +000042
Randy Abernethy0e86f1f2014-07-13 09:50:19 -070043 public TSimpleServer(TProcessor processor,
44 TServerTransport serverTransport,
45 LogDelegate logDel)
46 : base(processor, serverTransport, new TTransportFactory(), new TTransportFactory(), new TBinaryProtocol.Factory(), new TBinaryProtocol.Factory(), logDel)
47 {
48 }
David Reiss7f42bcf2008-01-11 20:59:12 +000049
Randy Abernethy0e86f1f2014-07-13 09:50:19 -070050 public TSimpleServer(TProcessor processor,
51 TServerTransport serverTransport,
52 TTransportFactory transportFactory)
53 : base(processor,
54 serverTransport,
55 transportFactory,
56 transportFactory,
57 new TBinaryProtocol.Factory(),
58 new TBinaryProtocol.Factory(),
59 DefaultLogDelegate)
60 {
61 }
David Reiss7f42bcf2008-01-11 20:59:12 +000062
Randy Abernethy0e86f1f2014-07-13 09:50:19 -070063 public TSimpleServer(TProcessor processor,
Jonathan Heard2bfd7df2015-10-28 17:34:27 +000064 TServerTransport serverTransport,
65 TTransportFactory transportFactory,
66 TProtocolFactory protocolFactory)
67 : base(processor,
68 serverTransport,
69 transportFactory,
70 transportFactory,
71 protocolFactory,
72 protocolFactory,
73 DefaultLogDelegate)
74 {
75 }
76
77 public TSimpleServer(TProcessorFactory processorFactory,
Randy Abernethy0e86f1f2014-07-13 09:50:19 -070078 TServerTransport serverTransport,
79 TTransportFactory transportFactory,
80 TProtocolFactory protocolFactory)
Jonathan Heard2bfd7df2015-10-28 17:34:27 +000081 : base(processorFactory,
Randy Abernethy0e86f1f2014-07-13 09:50:19 -070082 serverTransport,
83 transportFactory,
84 transportFactory,
85 protocolFactory,
86 protocolFactory,
87 DefaultLogDelegate)
88 {
89 }
David Reiss7f42bcf2008-01-11 20:59:12 +000090
Randy Abernethy0e86f1f2014-07-13 09:50:19 -070091 public override void Serve()
92 {
93 try
94 {
95 serverTransport.Listen();
96 }
97 catch (TTransportException ttx)
98 {
99 logDelegate(ttx.ToString());
100 return;
101 }
David Reiss7f42bcf2008-01-11 20:59:12 +0000102
Randy Abernethy0e86f1f2014-07-13 09:50:19 -0700103 //Fire the preServe server event when server is up but before any client connections
104 if (serverEventHandler != null)
105 serverEventHandler.preServe();
106
107 while (!stop)
108 {
Jonathan Heard2bfd7df2015-10-28 17:34:27 +0000109 TProcessor processor = null;
Randy Abernethy0e86f1f2014-07-13 09:50:19 -0700110 TTransport client = null;
111 TTransport inputTransport = null;
112 TTransport outputTransport = null;
113 TProtocol inputProtocol = null;
114 TProtocol outputProtocol = null;
115 Object connectionContext = null;
116 try
117 {
118 using (client = serverTransport.Accept())
Roger Meierb1ec4cc2012-04-11 21:21:41 +0000119 {
Jonathan Heard2bfd7df2015-10-28 17:34:27 +0000120 processor = processorFactory.GetProcessor(client);
Roger Meierb1ec4cc2012-04-11 21:21:41 +0000121 if (client != null)
122 {
Randy Abernethy0e86f1f2014-07-13 09:50:19 -0700123 using (inputTransport = inputTransportFactory.GetTransport(client))
Roger Meierb1ec4cc2012-04-11 21:21:41 +0000124 {
125 using (outputTransport = outputTransportFactory.GetTransport(client))
126 {
127 inputProtocol = inputProtocolFactory.GetProtocol(inputTransport);
128 outputProtocol = outputProtocolFactory.GetProtocol(outputTransport);
Randy Abernethy0e86f1f2014-07-13 09:50:19 -0700129
130 //Recover event handler (if any) and fire createContext server event when a client connects
131 if (serverEventHandler != null)
132 connectionContext = serverEventHandler.createContext(inputProtocol, outputProtocol);
133
134 //Process client requests until client disconnects
Jens Geyer7d882082015-01-27 22:08:44 +0100135 while (!stop)
Randy Abernethy0e86f1f2014-07-13 09:50:19 -0700136 {
Jens Geyerd5436f52014-10-03 19:50:38 +0200137 if (!inputTransport.Peek())
Jens Geyereb8e5ad2014-09-29 21:50:15 +0200138 break;
139
Randy Abernethy0e86f1f2014-07-13 09:50:19 -0700140 //Fire processContext server event
141 //N.B. This is the pattern implemented in C++ and the event fires provisionally.
142 //That is to say it may be many minutes between the event firing and the client request
143 //actually arriving or the client may hang up without ever makeing a request.
144 if (serverEventHandler != null)
145 serverEventHandler.processContext(connectionContext, inputTransport);
146 //Process client request (blocks until transport is readable)
147 if (!processor.Process(inputProtocol, outputProtocol))
148 break;
149 }
Roger Meierb1ec4cc2012-04-11 21:21:41 +0000150 }
151 }
152 }
153 }
154 }
Jens Geyer7d882082015-01-27 22:08:44 +0100155 catch (TTransportException ttx)
Roger Meierb1ec4cc2012-04-11 21:21:41 +0000156 {
Jens Geyer7d882082015-01-27 22:08:44 +0100157 if (!stop || ttx.Type != TTransportException.ExceptionType.Interrupted)
158 {
159 logDelegate(ttx.ToString());
160 }
Roger Meierb1ec4cc2012-04-11 21:21:41 +0000161 }
162 catch (Exception x)
163 {
Randy Abernethy0e86f1f2014-07-13 09:50:19 -0700164 //Unexpected
Roger Meierb1ec4cc2012-04-11 21:21:41 +0000165 logDelegate(x.ToString());
166 }
Randy Abernethy0e86f1f2014-07-13 09:50:19 -0700167
168 //Fire deleteContext server event after client disconnects
169 if (serverEventHandler != null)
170 serverEventHandler.deleteContext(connectionContext, inputProtocol, outputProtocol);
Roger Meierb1ec4cc2012-04-11 21:21:41 +0000171 }
Randy Abernethy0e86f1f2014-07-13 09:50:19 -0700172 }
David Reissdc815f52008-03-02 00:58:04 +0000173
Randy Abernethy0e86f1f2014-07-13 09:50:19 -0700174 public override void Stop()
175 {
176 stop = true;
177 serverTransport.Close();
178 }
179 }
David Reiss7f42bcf2008-01-11 20:59:12 +0000180}