cmdnodes.h 10.7 KB
Newer Older
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/>.
 */

16 17
#ifndef _TD_CMD_NODES_H_
#define _TD_CMD_NODES_H_
18 19 20 21 22

#ifdef __cplusplus
extern "C" {
#endif

23
#include "query.h"
X
Xiaoyu Wang 已提交
24
#include "querynodes.h"
25

X
Xiaoyu Wang 已提交
26
#define DESCRIBE_RESULT_COLS      4
27
#define DESCRIBE_RESULT_FIELD_LEN (TSDB_COL_NAME_LEN - 1 + VARSTR_HEADER_SIZE)
X
Xiaoyu Wang 已提交
28 29
#define DESCRIBE_RESULT_TYPE_LEN  (20 + VARSTR_HEADER_SIZE)
#define DESCRIBE_RESULT_NOTE_LEN  (8 + VARSTR_HEADER_SIZE)
30

31
#define SHOW_CREATE_DB_RESULT_COLS       2
D
dapan1121 已提交
32 33 34
#define SHOW_CREATE_DB_RESULT_FIELD1_LEN (TSDB_DB_NAME_LEN + VARSTR_HEADER_SIZE)
#define SHOW_CREATE_DB_RESULT_FIELD2_LEN (TSDB_MAX_BINARY_LEN + VARSTR_HEADER_SIZE)

35
#define SHOW_CREATE_TB_RESULT_COLS       2
D
dapan1121 已提交
36 37 38
#define SHOW_CREATE_TB_RESULT_FIELD1_LEN (TSDB_TABLE_NAME_LEN + VARSTR_HEADER_SIZE)
#define SHOW_CREATE_TB_RESULT_FIELD2_LEN (TSDB_MAX_BINARY_LEN + VARSTR_HEADER_SIZE)

X
Xiaoyu Wang 已提交
39
#define SHOW_LOCAL_VARIABLES_RESULT_COLS       2
D
dapan1121 已提交
40 41 42
#define SHOW_LOCAL_VARIABLES_RESULT_FIELD1_LEN (TSDB_CONFIG_OPTION_LEN + VARSTR_HEADER_SIZE)
#define SHOW_LOCAL_VARIABLES_RESULT_FIELD2_LEN (TSDB_CONFIG_VALUE_LEN + VARSTR_HEADER_SIZE)

X
Xiaoyu Wang 已提交
43 44 45 46 47 48 49 50
#define PRIVILEGE_TYPE_MASK(n) (1 << n)

#define PRIVILEGE_TYPE_ALL   PRIVILEGE_TYPE_MASK(0)
#define PRIVILEGE_TYPE_READ  PRIVILEGE_TYPE_MASK(1)
#define PRIVILEGE_TYPE_WRITE PRIVILEGE_TYPE_MASK(2)

#define PRIVILEGE_TYPE_TEST_MASK(val, mask) (((val) & (mask)) != 0)

51
typedef struct SDatabaseOptions {
X
Xiaoyu Wang 已提交
52 53 54 55 56
  ENodeType   type;
  int32_t     buffer;
  int8_t      cachelast;
  int8_t      compressionLevel;
  int32_t     daysPerFile;
X
Xiaoyu Wang 已提交
57
  SValueNode* pDaysPerFile;
X
Xiaoyu Wang 已提交
58 59 60 61
  int32_t     fsyncPeriod;
  int32_t     maxRowsPerBlock;
  int32_t     minRowsPerBlock;
  SNodeList*  pKeep;
X
Xiaoyu Wang 已提交
62
  int64_t     keep[3];
X
Xiaoyu Wang 已提交
63 64 65 66 67 68 69 70 71 72
  int32_t     pages;
  int32_t     pagesize;
  char        precisionStr[3];
  int8_t      precision;
  int8_t      replica;
  int8_t      strict;
  int8_t      walLevel;
  int32_t     numOfVgroups;
  int8_t      singleStable;
  SNodeList*  pRetentions;
X
Xiaoyu Wang 已提交
73
  int8_t      schemaless;
74
} SDatabaseOptions;
75

76
typedef struct SCreateDatabaseStmt {
X
Xiaoyu Wang 已提交
77 78 79
  ENodeType         type;
  char              dbName[TSDB_DB_NAME_LEN];
  bool              ignoreExists;
X
Xiaoyu Wang 已提交
80
  SDatabaseOptions* pOptions;
81
} SCreateDatabaseStmt;
82

83 84
typedef struct SUseDatabaseStmt {
  ENodeType type;
X
Xiaoyu Wang 已提交
85
  char      dbName[TSDB_DB_NAME_LEN];
86 87
} SUseDatabaseStmt;

88 89
typedef struct SDropDatabaseStmt {
  ENodeType type;
X
Xiaoyu Wang 已提交
90 91
  char      dbName[TSDB_DB_NAME_LEN];
  bool      ignoreNotExists;
92 93
} SDropDatabaseStmt;

94
typedef struct SAlterDatabaseStmt {
X
Xiaoyu Wang 已提交
95 96
  ENodeType         type;
  char              dbName[TSDB_DB_NAME_LEN];
97 98 99
  SDatabaseOptions* pOptions;
} SAlterDatabaseStmt;

X
Xiaoyu Wang 已提交
100 101 102 103 104
typedef struct SFlushDatabaseStmt {
  ENodeType type;
  char      dbName[TSDB_DB_NAME_LEN];
} SFlushDatabaseStmt;

X
Xiaoyu Wang 已提交
105
typedef struct STableOptions {
X
Xiaoyu Wang 已提交
106
  ENodeType  type;
wmmhello's avatar
wmmhello 已提交
107
  bool       commentNull;
108
  char       comment[TSDB_TB_COMMENT_LEN];
X
Xiaoyu Wang 已提交
109 110 111 112 113 114
  SNodeList* pMaxDelay;
  int64_t    maxDelay1;
  int64_t    maxDelay2;
  SNodeList* pWatermark;
  int64_t    watermark1;
  int64_t    watermark2;
X
Xiaoyu Wang 已提交
115 116
  SNodeList* pRollupFuncs;
  int32_t    ttl;
117
  SNodeList* pSma;
X
Xiaoyu Wang 已提交
118 119 120 121
} STableOptions;

typedef struct SColumnDefNode {
  ENodeType type;
X
Xiaoyu Wang 已提交
122
  char      colName[TSDB_COL_NAME_LEN];
X
Xiaoyu Wang 已提交
123
  SDataType dataType;
124
  char      comments[TSDB_TB_COMMENT_LEN];
X
Xiaoyu Wang 已提交
125
  bool      sma;
X
Xiaoyu Wang 已提交
126 127 128
} SColumnDefNode;

typedef struct SCreateTableStmt {
X
Xiaoyu Wang 已提交
129 130 131 132 133 134
  ENodeType      type;
  char           dbName[TSDB_DB_NAME_LEN];
  char           tableName[TSDB_TABLE_NAME_LEN];
  bool           ignoreExists;
  SNodeList*     pCols;
  SNodeList*     pTags;
X
Xiaoyu Wang 已提交
135
  STableOptions* pOptions;
X
Xiaoyu Wang 已提交
136 137
} SCreateTableStmt;

138
typedef struct SCreateSubTableClause {
139 140 141 142 143 144 145 146
  ENodeType      type;
  char           dbName[TSDB_DB_NAME_LEN];
  char           tableName[TSDB_TABLE_NAME_LEN];
  char           useDbName[TSDB_DB_NAME_LEN];
  char           useTableName[TSDB_TABLE_NAME_LEN];
  bool           ignoreExists;
  SNodeList*     pSpecificTags;
  SNodeList*     pValsOfTags;
wmmhello's avatar
wmmhello 已提交
147
  STableOptions* pOptions;
148
} SCreateSubTableClause;
149 150

typedef struct SCreateMultiTableStmt {
X
Xiaoyu Wang 已提交
151
  ENodeType  type;
152 153
  SNodeList* pSubTables;
} SCreateMultiTableStmt;
X
Xiaoyu Wang 已提交
154

155 156
typedef struct SDropTableClause {
  ENodeType type;
X
Xiaoyu Wang 已提交
157 158 159
  char      dbName[TSDB_DB_NAME_LEN];
  char      tableName[TSDB_TABLE_NAME_LEN];
  bool      ignoreNotExists;
160 161 162
} SDropTableClause;

typedef struct SDropTableStmt {
X
Xiaoyu Wang 已提交
163
  ENodeType  type;
164 165 166
  SNodeList* pTables;
} SDropTableStmt;

167 168
typedef struct SDropSuperTableStmt {
  ENodeType type;
X
Xiaoyu Wang 已提交
169 170 171
  char      dbName[TSDB_DB_NAME_LEN];
  char      tableName[TSDB_TABLE_NAME_LEN];
  bool      ignoreNotExists;
172 173
} SDropSuperTableStmt;

174
typedef struct SAlterTableStmt {
X
Xiaoyu Wang 已提交
175 176 177 178 179 180
  ENodeType      type;
  char           dbName[TSDB_DB_NAME_LEN];
  char           tableName[TSDB_TABLE_NAME_LEN];
  int8_t         alterType;
  char           colName[TSDB_COL_NAME_LEN];
  char           newColName[TSDB_COL_NAME_LEN];
181
  STableOptions* pOptions;
X
Xiaoyu Wang 已提交
182 183
  SDataType      dataType;
  SValueNode*    pVal;
184 185
} SAlterTableStmt;

186 187
typedef struct SCreateUserStmt {
  ENodeType type;
X
Xiaoyu Wang 已提交
188 189
  char      useName[TSDB_USER_LEN];
  char      password[TSDB_USET_PASSWORD_LEN];
X
Xiaoyu Wang 已提交
190
  int8_t    sysinfo;
191 192 193 194
} SCreateUserStmt;

typedef struct SAlterUserStmt {
  ENodeType type;
X
Xiaoyu Wang 已提交
195 196
  char      useName[TSDB_USER_LEN];
  int8_t    alterType;
X
Xiaoyu Wang 已提交
197 198 199
  char      password[TSDB_USET_PASSWORD_LEN];
  int8_t    enable;
  int8_t    sysinfo;
200 201 202 203
} SAlterUserStmt;

typedef struct SDropUserStmt {
  ENodeType type;
X
Xiaoyu Wang 已提交
204
  char      useName[TSDB_USER_LEN];
205 206 207 208
} SDropUserStmt;

typedef struct SCreateDnodeStmt {
  ENodeType type;
X
Xiaoyu Wang 已提交
209 210
  char      fqdn[TSDB_FQDN_LEN];
  int32_t   port;
211 212 213 214
} SCreateDnodeStmt;

typedef struct SDropDnodeStmt {
  ENodeType type;
X
Xiaoyu Wang 已提交
215 216 217
  int32_t   dnodeId;
  char      fqdn[TSDB_FQDN_LEN];
  int32_t   port;
218 219
} SDropDnodeStmt;

220 221
typedef struct SAlterDnodeStmt {
  ENodeType type;
X
Xiaoyu Wang 已提交
222 223 224
  int32_t   dnodeId;
  char      config[TSDB_DNODE_CONFIG_LEN];
  char      value[TSDB_DNODE_VALUE_LEN];
225 226
} SAlterDnodeStmt;

227
typedef struct SShowStmt {
228 229 230 231
  ENodeType     type;
  SNode*        pDbName;  // SValueNode
  SNode*        pTbName;  // SValueNode
  EOperatorType tableCondType;
232 233
} SShowStmt;

234
typedef struct SShowCreateDatabaseStmt {
235
  ENodeType type;
X
Xiaoyu Wang 已提交
236
  char      dbName[TSDB_DB_NAME_LEN];
237 238 239 240
  void*     pCfg;  // SDbCfgInfo
} SShowCreateDatabaseStmt;

typedef struct SShowCreateTableStmt {
241 242 243 244
  ENodeType type;
  char      dbName[TSDB_DB_NAME_LEN];
  char      tableName[TSDB_TABLE_NAME_LEN];
  void*     pCfg;  // STableCfg
245
} SShowCreateTableStmt;
246

247 248 249 250 251 252
typedef struct SShowTableDistributedStmt {
  ENodeType type;
  char      dbName[TSDB_DB_NAME_LEN];
  char      tableName[TSDB_TABLE_NAME_LEN];
} SShowTableDistributedStmt;

253 254 255 256 257
typedef struct SShowDnodeVariablesStmt {
  ENodeType type;
  SNode*    pDnodeId;
} SShowDnodeVariablesStmt;

X
Xiaoyu Wang 已提交
258
typedef enum EIndexType { INDEX_TYPE_SMA = 1, INDEX_TYPE_FULLTEXT } EIndexType;
X
Xiaoyu Wang 已提交
259 260

typedef struct SIndexOptions {
X
Xiaoyu Wang 已提交
261
  ENodeType  type;
X
Xiaoyu Wang 已提交
262
  SNodeList* pFuncs;
X
Xiaoyu Wang 已提交
263 264 265
  SNode*     pInterval;
  SNode*     pOffset;
  SNode*     pSliding;
266
  SNode*     pStreamOptions;
X
Xiaoyu Wang 已提交
267 268 269
} SIndexOptions;

typedef struct SCreateIndexStmt {
X
Xiaoyu Wang 已提交
270 271 272 273 274 275
  ENodeType      type;
  EIndexType     indexType;
  bool           ignoreExists;
  char           indexName[TSDB_INDEX_NAME_LEN];
  char           tableName[TSDB_TABLE_NAME_LEN];
  SNodeList*     pCols;
X
Xiaoyu Wang 已提交
276 277 278
  SIndexOptions* pOptions;
} SCreateIndexStmt;

279 280
typedef struct SDropIndexStmt {
  ENodeType type;
X
Xiaoyu Wang 已提交
281 282
  bool      ignoreNotExists;
  char      indexName[TSDB_INDEX_NAME_LEN];
283 284
} SDropIndexStmt;

285
typedef struct SCreateComponentNodeStmt {
X
Xiaoyu Wang 已提交
286
  ENodeType type;
X
Xiaoyu Wang 已提交
287
  int32_t   dnodeId;
288
} SCreateComponentNodeStmt;
X
Xiaoyu Wang 已提交
289

290
typedef struct SDropComponentNodeStmt {
291
  ENodeType type;
X
Xiaoyu Wang 已提交
292
  int32_t   dnodeId;
293
} SDropComponentNodeStmt;
294 295

typedef struct SCreateTopicStmt {
296 297 298 299 300
  ENodeType type;
  char      topicName[TSDB_TABLE_NAME_LEN];
  char      subDbName[TSDB_DB_NAME_LEN];
  char      subSTbName[TSDB_TABLE_NAME_LEN];
  bool      ignoreExists;
X
Xiaoyu Wang 已提交
301
  bool      withMeta;
302
  SNode*    pQuery;
303 304 305 306
} SCreateTopicStmt;

typedef struct SDropTopicStmt {
  ENodeType type;
X
Xiaoyu Wang 已提交
307 308
  char      topicName[TSDB_TABLE_NAME_LEN];
  bool      ignoreNotExists;
309 310
} SDropTopicStmt;

X
Xiaoyu Wang 已提交
311 312 313 314 315 316 317
typedef struct SDropCGroupStmt {
  ENodeType type;
  char      topicName[TSDB_TABLE_NAME_LEN];
  char      cgroup[TSDB_CGROUP_LEN];
  bool      ignoreNotExists;
} SDropCGroupStmt;

318 319
typedef struct SAlterLocalStmt {
  ENodeType type;
X
Xiaoyu Wang 已提交
320 321
  char      config[TSDB_DNODE_CONFIG_LEN];
  char      value[TSDB_DNODE_VALUE_LEN];
322 323
} SAlterLocalStmt;

324
typedef struct SDescribeStmt {
X
Xiaoyu Wang 已提交
325 326 327
  ENodeType   type;
  char        dbName[TSDB_DB_NAME_LEN];
  char        tableName[TSDB_TABLE_NAME_LEN];
328 329 330
  STableMeta* pMeta;
} SDescribeStmt;

331 332
typedef struct SKillStmt {
  ENodeType type;
X
Xiaoyu Wang 已提交
333
  int32_t   targetId;
334 335
} SKillStmt;

X
Xiaoyu Wang 已提交
336 337 338 339 340
typedef struct SKillQueryStmt {
  ENodeType type;
  char      queryId[TSDB_QUERY_ID_LEN];
} SKillQueryStmt;

341 342
typedef struct SStreamOptions {
  ENodeType type;
X
Xiaoyu Wang 已提交
343
  int8_t    triggerType;
344
  SNode*    pDelay;
X
Xiaoyu Wang 已提交
345
  SNode*    pWatermark;
346
  bool      ignoreExpired;
347 348 349
} SStreamOptions;

typedef struct SCreateStreamStmt {
X
Xiaoyu Wang 已提交
350 351 352 353 354
  ENodeType       type;
  char            streamName[TSDB_TABLE_NAME_LEN];
  char            targetDbName[TSDB_DB_NAME_LEN];
  char            targetTabName[TSDB_TABLE_NAME_LEN];
  bool            ignoreExists;
355
  SStreamOptions* pOptions;
X
Xiaoyu Wang 已提交
356
  SNode*          pQuery;
357 358 359 360
} SCreateStreamStmt;

typedef struct SDropStreamStmt {
  ENodeType type;
X
Xiaoyu Wang 已提交
361 362
  char      streamName[TSDB_TABLE_NAME_LEN];
  bool      ignoreNotExists;
363 364
} SDropStreamStmt;

365 366
typedef struct SCreateFunctionStmt {
  ENodeType type;
X
Xiaoyu Wang 已提交
367 368 369 370
  bool      ignoreExists;
  char      funcName[TSDB_FUNC_NAME_LEN];
  bool      isAgg;
  char      libraryPath[PATH_MAX];
371
  SDataType outputDt;
X
Xiaoyu Wang 已提交
372
  int32_t   bufSize;
373 374
} SCreateFunctionStmt;

375 376 377 378 379 380 381 382 383 384 385 386 387 388 389
typedef struct SDropFunctionStmt {
  ENodeType type;
  char      funcName[TSDB_FUNC_NAME_LEN];
  bool      ignoreNotExists;
} SDropFunctionStmt;

typedef struct SGrantStmt {
  ENodeType type;
  char      userName[TSDB_USER_LEN];
  char      dbName[TSDB_DB_NAME_LEN];
  int64_t   privileges;
} SGrantStmt;

typedef SGrantStmt SRevokeStmt;

X
Xiaoyu Wang 已提交
390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413
typedef struct SBalanceVgroupStmt {
  ENodeType type;
} SBalanceVgroupStmt;

typedef struct SMergeVgroupStmt {
  ENodeType type;
  int32_t   vgId1;
  int32_t   vgId2;
} SMergeVgroupStmt;

typedef struct SRedistributeVgroupStmt {
  ENodeType  type;
  int32_t    vgId;
  int32_t    dnodeId1;
  int32_t    dnodeId2;
  int32_t    dnodeId3;
  SNodeList* pDnodes;
} SRedistributeVgroupStmt;

typedef struct SSplitVgroupStmt {
  ENodeType type;
  int32_t   vgId;
} SSplitVgroupStmt;

414 415 416 417
#ifdef __cplusplus
}
#endif

418
#endif /*_TD_CMD_NODES_H_*/