mnodeSdb.h 2.6 KB
Newer Older
H
hzcheng 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
/*
 * 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/>.
 */

S
slguan 已提交
16 17 18 19 20 21
#ifndef TDENGINE_MNODE_SDB_H
#define TDENGINE_MNODE_SDB_H

#ifdef __cplusplus
extern "C" {
#endif
H
hzcheng 已提交
22

23 24
struct SMnodeMsg;

S
slguan 已提交
25
typedef enum {
S
Shengliang Guan 已提交
26 27 28 29 30 31 32 33 34
  SDB_TABLE_CLUSTER = 0,
  SDB_TABLE_DNODE   = 1,
  SDB_TABLE_MNODE   = 2,
  SDB_TABLE_ACCOUNT = 3,
  SDB_TABLE_USER    = 4,
  SDB_TABLE_DB      = 5,
  SDB_TABLE_VGROUP  = 6,
  SDB_TABLE_STABLE  = 7,
  SDB_TABLE_CTABLE  = 8,
S
Shengliang Guan 已提交
35
  SDB_TABLE_MAX     = 9
S
slguan 已提交
36 37
} ESdbTable;

S
slguan 已提交
38
typedef enum {
S
slguan 已提交
39
  SDB_KEY_STRING, 
S
slguan 已提交
40
  SDB_KEY_INT,
41 42
  SDB_KEY_AUTO,
  SDB_KEY_VAR_STRING,
S
slguan 已提交
43
} ESdbKey;
S
slguan 已提交
44

S
slguan 已提交
45
typedef enum {
S
slguan 已提交
46 47
  SDB_OPER_GLOBAL,
  SDB_OPER_LOCAL
S
slguan 已提交
48
} ESdbOper;
S
slguan 已提交
49

S
slguan 已提交
50
typedef struct {
S
slguan 已提交
51 52 53 54
  ESdbOper type;
  void *   table;
  void *   pObj;
  void *   rowData;
55 56
  int32_t  rowSize;
  int32_t  retCode; // for callback in sdb queue
57
  int32_t  processedCount; // for sync fwd callback
58
  int32_t  (*cb)(struct SMnodeMsg *pMsg, int32_t code);
59
  struct SMnodeMsg *pMsg;
S
slguan 已提交
60
} SSdbOper;
S
slguan 已提交
61 62 63 64 65

typedef struct {
  char   *tableName;
  int32_t hashSessions;
  int32_t maxRowSize;
S
slguan 已提交
66
  int32_t refCountPos;
S
slguan 已提交
67 68 69 70 71 72 73 74
  ESdbTable tableId;
  ESdbKey   keyType;
  int32_t (*insertFp)(SSdbOper *pOper);
  int32_t (*deleteFp)(SSdbOper *pOper);
  int32_t (*updateFp)(SSdbOper *pOper);
  int32_t (*encodeFp)(SSdbOper *pOper);
  int32_t (*decodeFp)(SSdbOper *pDesc);  
  int32_t (*destroyFp)(SSdbOper *pDesc);
S
slguan 已提交
75
  int32_t (*restoredFp)();
S
slguan 已提交
76
} SSdbTableDesc;
S
slguan 已提交
77

S
slguan 已提交
78 79
int32_t sdbInit();
void    sdbCleanUp();
S
slguan 已提交
80 81
void *  sdbOpenTable(SSdbTableDesc *desc);
void    sdbCloseTable(void *handle);
S
slguan 已提交
82
bool    sdbIsMaster();
S
slguan 已提交
83
bool    sdbIsServing();
S
slguan 已提交
84
void    sdbUpdateMnodeRoles();
S
slguan 已提交
85

S
slguan 已提交
86 87 88
int32_t sdbInsertRow(SSdbOper *pOper);
int32_t sdbDeleteRow(SSdbOper *pOper);
int32_t sdbUpdateRow(SSdbOper *pOper);
S
slguan 已提交
89

S
slguan 已提交
90
void    *sdbGetRow(void *handle, void *key);
S
Shengliang Guan 已提交
91 92
void    *sdbFetchRow(void *handle, void *pIter, void **ppRow);
void     sdbFreeIter(void *pIter);
S
slguan 已提交
93 94
void     sdbIncRef(void *thandle, void *pRow);
void     sdbDecRef(void *thandle, void *pRow);
S
slguan 已提交
95
int64_t  sdbGetNumOfRows(void *handle);
S
slguan 已提交
96
int32_t  sdbGetId(void *handle);
S
slguan 已提交
97
uint64_t sdbGetVersion();
98
bool     sdbCheckRowDeleted(void *thandle, void *pRow);
S
slguan 已提交
99 100 101

#ifdef __cplusplus
}
H
hzcheng 已提交
102
#endif
S
slguan 已提交
103 104

#endif