trpc.h 2.8 KB
Newer Older
H
hzcheng 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
/*
 * Copyright (c) 2019 TAOS Data, Inc. <jhtao@taosdata.com>
 *
 * This program is free software: you can use, redistribute, and/or modify
 * it under the terms of the GNU Affero General Public License, version 3
 * or later ("AGPL"), as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with this program. If not, see <http://www.gnu.org/licenses/>.
 */
#ifndef TDENGINE_TRPC_H
#define TDENGINE_TRPC_H

#ifdef __cplusplus
extern "C" {
#endif

S
slguan 已提交
22 23 24
#include <stdbool.h>
#include <stdint.h>

H
hzcheng 已提交
25 26 27 28 29 30 31
#define TAOS_CONN_UDPS     0
#define TAOS_CONN_UDPC     1
#define TAOS_CONN_TCPS     2
#define TAOS_CONN_TCPC     3
#define TAOS_CONN_HTTPS    4
#define TAOS_CONN_HTTPC    5

32 33 34 35
#define TAOS_SOCKET_TYPE_NAME_TCP  "tcp"
#define TAOS_SOCKET_TYPE_NAME_UDP  "udp"

#define TAOS_CONN_SOCKET_TYPE_S()  ((strcasecmp(tsSocketType, TAOS_SOCKET_TYPE_NAME_UDP) == 0)? TAOS_CONN_UDPS:TAOS_CONN_TCPS)
S
slguan 已提交
36
#define TAOS_CONN_SOCKET_TYPE_C()  ((strcasecmp(tsSocketType, TAOS_SOCKET_TYPE_NAME_UDP) == 0)? TAOS_CONN_UDPC:TAOS_CONN_TCPC)
37

陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
38
extern int tsRpcHeadSize;
H
hzcheng 已提交
39 40 41

typedef struct {
  char *localIp;                        // local IP used
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
42
  uint16_t localPort;                   // local port
H
hzcheng 已提交
43 44
  char *label;                          // for debug purpose
  int   numOfThreads;                   // number of threads to handle connections
S
dnode  
slguan 已提交
45
  void *(*fp)(int8_t type, void *pCont, int32_t contLen, void *handle, int32_t index);  // function to process the incoming msg
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
46
  int   sessions;                       // number of sessions allowed
H
hzcheng 已提交
47 48
  int   connType;                       // TAOS_CONN_UDP, TAOS_CONN_TCPC, TAOS_CONN_TCPS
  int   idleTime;                       // milliseconds, 0 means idle timer is disabled
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
49 50 51 52 53 54
  char *meterId;   // meter ID
  char  spi;       // security parameter index
  char  encrypt;   // encrypt algorithm
  char *secret;    // key for authentication
  char *ckey;      // ciphering key
  int   (*afp) (char *meterId, char *spi, char *encrypt, uint8_t *secret, uint8_t *ckey); // call back to retrieve auth info
H
hzcheng 已提交
55 56 57
} SRpcInit;

typedef struct {
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
58 59
  int16_t   index; 
  int16_t   numOfIps;
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
60
  uint16_t  port;
61 62
  uint32_t  ip[TSDB_MAX_MPEERS];
  char      ipStr[TSDB_MAX_MPEERS][TSDB_IPv4ADDR_LEN];
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
63 64 65 66
} SRpcIpSet;

void *rpcOpen(SRpcInit *pRpc);
void  rpcClose(void *);
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
67 68
void *rpcMallocCont(int contLen);
void  rpcFreeCont(void *pCont);
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
69 70 71
void  rpcSendRequest(void *thandle, SRpcIpSet ipSet, char msgType, void *pCont, int contLen, void *ahandle);
void  rpcSendResponse(void *pConn, void *pCont, int contLen);
void  rpcSendSimpleRsp(void *pConn, int32_t code);
H
hzcheng 已提交
72 73 74 75 76 77 78


#ifdef __cplusplus
}
#endif

#endif  // TDENGINE_TRPC_H