trpc.h 2.7 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
#include <stdbool.h>
#include <stdint.h>
S
slguan 已提交
24
#include "taosdef.h"
S
slguan 已提交
25

26 27
#define TAOS_CONN_SERVER   0
#define TAOS_CONN_CLIENT   1
28

陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
29
extern int tsRpcHeadSize;
H
hzcheng 已提交
30 31

typedef struct {
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
32 33
  int16_t   index; 
  int16_t   numOfIps;
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
34
  uint16_t  port;
35
  uint32_t  ip[TSDB_MAX_MPEERS];
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
36 37
} SRpcIpSet;

陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
38
typedef struct {
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
39 40 41
  uint32_t  clientIp;
  uint16_t  clientPort;
  uint32_t  serverIp;
S
slguan 已提交
42
  char      user[TSDB_USER_LEN];
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
43 44
} SRpcConnInfo;

陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
45 46 47 48 49 50 51 52 53
typedef struct {
  char *localIp;      // local IP used
  uint16_t localPort; // local port
  char *label;        // for debug purpose
  int   numOfThreads; // number of threads to handle connections
  int   sessions;     // number of sessions allowed
  int   connType;     // TAOS_CONN_UDP, TAOS_CONN_TCPC, TAOS_CONN_TCPS
  int   idleTime;     // milliseconds, 0 means idle timer is disabled

54
  // the following is for client app ecurity only
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
55
  char *user;         // user name
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
56 57 58 59 60
  char  spi;          // security parameter index
  char  encrypt;      // encrypt algorithm
  char *secret;       // key for authentication
  char *ckey;         // ciphering key

61 62
  // call back to process incoming msg, code shall be ignored by server app
  void (*cfp)(char type, void *pCont, int contLen, void *handle, int32_t code);  
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
63

64
  // call back to process notify the ipSet changes, for client app only
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
65
  void (*ufp)(void *ahandle, SRpcIpSet *pIpSet);
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
66

67
  // call back to retrieve the client auth info, for server app only 
68
  int  (*afp)(char *meterId, char *spi, char *encrypt, char *secret, char *ckey); 
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
69 70
} SRpcInit;

陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
71 72
void *rpcOpen(SRpcInit *pRpc);
void  rpcClose(void *);
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
73 74
void *rpcMallocCont(int contLen);
void  rpcFreeCont(void *pCont);
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
75
void  rpcSendRequest(void *thandle, SRpcIpSet *pIpSet, char msgType, void *pCont, int contLen, void *ahandle);
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
76
void  rpcSendResponse(void *pConn, int32_t code, void *pCont, int contLen);
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
77
void  rpcSendRedirectRsp(void *pConn, SRpcIpSet *pIpSet); 
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
78
void  rpcGetConnInfo(void *thandle, SRpcConnInfo *pInfo);
H
hzcheng 已提交
79 80 81 82 83 84

#ifdef __cplusplus
}
#endif

#endif  // TDENGINE_TRPC_H