trpc.h 3.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
#include <stdbool.h>
#include <stdint.h>
S
slguan 已提交
24
#include "taosdef.h"
H
Hongze Cheng 已提交
25
#include "tmsg.h"
S
slguan 已提交
26

H
Hongze Cheng 已提交
27 28
#define TAOS_CONN_SERVER 0
#define TAOS_CONN_CLIENT 1
S
Shengliang Guan 已提交
29
#define IsReq(pMsg)      (pMsg->msgType & 1U)
30

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

S
Shengliang Guan 已提交
33
typedef struct {
H
Hongze Cheng 已提交
34 35 36
  uint32_t clientIp;
  uint16_t clientPort;
  char     user[TSDB_USER_LEN];
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
37 38
} SRpcConnInfo;

39
typedef struct SRpcHandleInfo {
S
Shengliang Guan 已提交
40
  // rpc info
dengyihao's avatar
dengyihao 已提交
41
  void *  handle;         // rpc handle returned to app
42 43 44 45
  int64_t refId;          // refid, used by server
  int32_t noResp;         // has response or not(default 0, 0: resp, 1: no resp);
  int32_t persistHandle;  // persist handle or not

S
Shengliang Guan 已提交
46
  // app info
47 48 49 50
  void *ahandle;  // app handle set by client
  void *wrapper;  // wrapper handle
  void *node;     // node mgmt handle

S
Shengliang Guan 已提交
51
  // resp info
dengyihao's avatar
dengyihao 已提交
52
  void *  rsp;
53
  int32_t rspLen;
S
Shengliang Guan 已提交
54
} SRpcHandleInfo;
dengyihao's avatar
dengyihao 已提交
55

S
Shengliang Guan 已提交
56 57
typedef struct SRpcMsg {
  tmsg_t         msgType;
dengyihao's avatar
dengyihao 已提交
58
  void *         pCont;
S
Shengliang Guan 已提交
59 60 61 62
  int32_t        contLen;
  int32_t        code;
  SRpcHandleInfo info;
  SRpcConnInfo   conn;
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
63 64
} SRpcMsg;

dengyihao's avatar
dengyihao 已提交
65 66
typedef void (*RpcCfp)(void *parent, SRpcMsg *, SEpSet *rf);
typedef bool (*RpcRfp)(int32_t code);
S
Shengliang Guan 已提交
67

68
typedef struct SRpcInit {
69
  char     localFqdn[TSDB_FQDN_LEN];
H
Hongze Cheng 已提交
70 71 72 73 74 75
  uint16_t localPort;     // local port
  char *   label;         // for debug purpose
  int      numOfThreads;  // number of threads to handle connections
  int      sessions;      // number of sessions allowed
  int8_t   connType;      // TAOS_CONN_UDP, TAOS_CONN_TCPC, TAOS_CONN_TCPS
  int      idleTime;      // milliseconds, 0 means idle timer is disabled
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
76

77
  // the following is for client app ecurity only
dengyihao's avatar
dengyihao 已提交
78
  char *user;  // user name
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
79

80
  // call back to process incoming msg, code shall be ignored by server app
S
Shengliang Guan 已提交
81
  RpcCfp cfp;
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
82

dengyihao's avatar
dengyihao 已提交
83 84
  // user defined retry func
  RpcRfp rfp;
S
Shengliang Guan 已提交
85 86

  void *parent;
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
87 88
} SRpcInit;

dengyihao's avatar
dengyihao 已提交
89
typedef struct {
dengyihao's avatar
dengyihao 已提交
90
  void *val;
D
dapan1121 已提交
91
  int32_t (*clone)(void *src, void **dst);
dengyihao's avatar
dengyihao 已提交
92
  void (*freeFunc)(const void *arg);
dengyihao's avatar
dengyihao 已提交
93 94 95
} SRpcCtxVal;

typedef struct {
dengyihao's avatar
dengyihao 已提交
96 97
  int32_t msgType;
  void *  val;
D
dapan1121 已提交
98
  int32_t (*clone)(void *src, void **dst);
dengyihao's avatar
dengyihao 已提交
99
  void (*freeFunc)(const void *arg);
dengyihao's avatar
dengyihao 已提交
100 101 102 103 104
} SRpcBrokenlinkVal;

typedef struct {
  SHashObj *        args;
  SRpcBrokenlinkVal brokenVal;
dengyihao's avatar
dengyihao 已提交
105 106
} SRpcCtx;

S
Shengliang Guan 已提交
107
int32_t rpcInit();
H
Hongze Cheng 已提交
108
void    rpcCleanup();
dengyihao's avatar
dengyihao 已提交
109
void *  rpcOpen(const SRpcInit *pRpc);
H
Hongze Cheng 已提交
110 111 112 113
void    rpcClose(void *);
void *  rpcMallocCont(int contLen);
void    rpcFreeCont(void *pCont);
void *  rpcReallocCont(void *ptr, int contLen);
dengyihao's avatar
dengyihao 已提交
114

S
shm  
Shengliang Guan 已提交
115 116 117 118
// Because taosd supports multi-process mode
// These functions should not be used on the server side
// Please use tmsg<xx> functions, which are defined in tmsgcb.h
void rpcSendRequest(void *thandle, const SEpSet *pEpSet, SRpcMsg *pMsg, int64_t *rid);
dengyihao's avatar
dengyihao 已提交
119
void rpcSendResponse(const SRpcMsg *pMsg);
S
shm  
Shengliang Guan 已提交
120 121 122 123
void rpcRegisterBrokenLinkArg(SRpcMsg *msg);
void rpcReleaseHandle(void *handle, int8_t type);  // just release client conn to rpc instance, no close sock

// These functions will not be called in the child process
dengyihao's avatar
dengyihao 已提交
124
void rpcSendRedirectRsp(void *pConn, const SEpSet *pEpSet);
S
shm  
Shengliang Guan 已提交
125
void rpcSendRequestWithCtx(void *thandle, const SEpSet *pEpSet, SRpcMsg *pMsg, int64_t *rid, SRpcCtx *ctx);
dengyihao's avatar
dengyihao 已提交
126 127
int  rpcGetConnInfo(void *thandle, SRpcConnInfo *pInfo);
void rpcSendRecv(void *shandle, SEpSet *pEpSet, SRpcMsg *pReq, SRpcMsg *pRsp);
dengyihao's avatar
dengyihao 已提交
128

H
hzcheng 已提交
129 130 131 132 133
#ifdef __cplusplus
}
#endif

#endif  // TDENGINE_TRPC_H