InfiniSQL  v0.1.2-alpha
Massive Scale Transaction Processing
 All Classes Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
ObGateway.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2013 Mark Travis <mtravis15432+src@gmail.com>
3  * All rights reserved. No warranty, explicit or implicit, provided.
4  *
5  * This file is part of InfiniSQL(tm).
6 
7  * InfiniSQL is free software: you can redistribute it and/or modify
8  * it under the terms of the GNU General Public License version 3
9  * as published by the Free Software Foundation.
10  *
11  * InfiniSQL is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with InfiniSQL. If not, see <http://www.gnu.org/licenses/>.
18  */
19 
30 #ifndef INFINISQLOBGATEWAY_H
31 #define INFINISQLOBGATEWAY_H
32 
33 #include "gch.h"
34 
40 class ObGateway
41 {
42 public:
43  ObGateway(Topology::partitionAddress *myIdentityArg);
44  virtual ~ObGateway();
45  void updateRemoteGateways();
46 
48  class Mboxes mboxes;
50 
51 private:
52  // remoteGateways[nodeid]=socket for corresponding ibgw's
53  std::vector<int> remoteGateways;
54  socklen_t optlen;
55  int so_sndbuf;
56  char *serstrsmall;
57  char *cstrsmall;
59 };
60 
68 void *obGateway(void *identity);
69 
70 #endif /* INFINISQLOBGATEWAY_H */