blob: 05fa76149e864ff67f8d44f85d91d3e6da9c1597 [file] [log] [blame]
Craig Tillerdb57c4f2015-02-24 10:34:47 -08001/*
2 *
3 * Copyright 2015, Google Inc.
4 * All rights reserved.
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions are
8 * met:
9 *
10 * * Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * * Redistributions in binary form must reproduce the above
13 * copyright notice, this list of conditions and the following disclaimer
14 * in the documentation and/or other materials provided with the
15 * distribution.
16 * * Neither the name of Google Inc. nor the names of its
17 * contributors may be used to endorse or promote products derived from
18 * this software without specific prior written permission.
19 *
20 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
23 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
24 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
25 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
26 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
30 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31 *
32 */
33
Yang Gao49996492015-03-12 16:40:19 -070034#ifndef GRPCXX_ASYNC_GENERIC_SERVICE_H
35#define GRPCXX_ASYNC_GENERIC_SERVICE_H
Craig Tillerdb57c4f2015-02-24 10:34:47 -080036
Yang Gao1c402332015-03-05 16:39:25 -080037#include <grpc++/byte_buffer.h>
Craig Tillerdb57c4f2015-02-24 10:34:47 -080038#include <grpc++/stream.h>
39
Yang Gao1c402332015-03-05 16:39:25 -080040struct grpc_server;
41
Craig Tillerdb57c4f2015-02-24 10:34:47 -080042namespace grpc {
43
Yang Gao49996492015-03-12 16:40:19 -070044typedef ServerAsyncReaderWriter<ByteBuffer, ByteBuffer> GenericServerAsyncReaderWriter;
Craig Tillerdb57c4f2015-02-24 10:34:47 -080045
Yang Gao179f8682015-03-12 14:36:58 -070046class GenericServerContext GRPC_FINAL : public ServerContext {
Craig Tillerdb57c4f2015-02-24 10:34:47 -080047 public:
48 const grpc::string& method() const { return method_; }
49 const grpc::string& host() const { return host_; }
50
51 private:
Yang Gao5f4539f2015-03-06 16:11:16 -080052 friend class Server;
53
Craig Tillerdb57c4f2015-02-24 10:34:47 -080054 grpc::string method_;
55 grpc::string host_;
56};
57
Yang Gao49996492015-03-12 16:40:19 -070058class AsyncGenericService GRPC_FINAL {
Craig Tillerdb57c4f2015-02-24 10:34:47 -080059 public:
Yang Gao1c402332015-03-05 16:39:25 -080060 // TODO(yangg) Once we can add multiple completion queues to the server
61 // in c core, add a CompletionQueue* argument to the ctor here.
Yang Gao49996492015-03-12 16:40:19 -070062 AsyncGenericService() : server_(nullptr) {}
Craig Tillerdb57c4f2015-02-24 10:34:47 -080063
Yang Gao005eb882015-03-11 22:17:13 -070064 void RequestCall(GenericServerContext* ctx,
Yang Gao49996492015-03-12 16:40:19 -070065 GenericServerAsyncReaderWriter* reader_writer,
Yang Gao1c402332015-03-05 16:39:25 -080066 CompletionQueue* cq, void* tag);
Yang Gao5f4539f2015-03-06 16:11:16 -080067
Craig Tillerdb57c4f2015-02-24 10:34:47 -080068 private:
Yang Gao1c402332015-03-05 16:39:25 -080069 friend class Server;
70 Server* server_;
Craig Tillerdb57c4f2015-02-24 10:34:47 -080071};
72
Yang Gao1c402332015-03-05 16:39:25 -080073} // namespace grpc
Craig Tillerdb57c4f2015-02-24 10:34:47 -080074
Yang Gao49996492015-03-12 16:40:19 -070075#endif // GRPCXX_ASYNC_GENERIC_SERVICE_H