Merge pull request #22650 from taosdata/szhou/ip-whitelist
enhance: ip whitelist syntax
This commit is contained in:
commit
4a5bcb5c80
|
@ -88,6 +88,7 @@ extern int64_t tsMndLogRetention;
|
||||||
extern int8_t tsGrant;
|
extern int8_t tsGrant;
|
||||||
extern int32_t tsMndGrantMode;
|
extern int32_t tsMndGrantMode;
|
||||||
extern bool tsMndSkipGrant;
|
extern bool tsMndSkipGrant;
|
||||||
|
extern bool tsEnableWhiteList;
|
||||||
|
|
||||||
// dnode
|
// dnode
|
||||||
extern int64_t tsDndStart;
|
extern int64_t tsDndStart;
|
||||||
|
|
|
@ -184,6 +184,8 @@ typedef enum _mgmt_table {
|
||||||
#define TSDB_ALTER_USER_REMOVE_WRITE_TABLE 0x10
|
#define TSDB_ALTER_USER_REMOVE_WRITE_TABLE 0x10
|
||||||
#define TSDB_ALTER_USER_ADD_ALL_TABLE 0x11
|
#define TSDB_ALTER_USER_ADD_ALL_TABLE 0x11
|
||||||
#define TSDB_ALTER_USER_REMOVE_ALL_TABLE 0x12
|
#define TSDB_ALTER_USER_REMOVE_ALL_TABLE 0x12
|
||||||
|
#define TSDB_ALTER_USER_ADD_WHITE_LIST 0x13
|
||||||
|
#define TSDB_ALTER_USER_DROP_WHITE_LIST 0x14
|
||||||
|
|
||||||
#define TSDB_ALTER_USER_PRIVILEGES 0x2
|
#define TSDB_ALTER_USER_PRIVILEGES 0x2
|
||||||
|
|
||||||
|
@ -421,7 +423,6 @@ typedef enum ENodeType {
|
||||||
QUERY_NODE_PHYSICAL_PLAN_DYN_QUERY_CTRL
|
QUERY_NODE_PHYSICAL_PLAN_DYN_QUERY_CTRL
|
||||||
} ENodeType;
|
} ENodeType;
|
||||||
|
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
int32_t vgId;
|
int32_t vgId;
|
||||||
char* dbFName;
|
char* dbFName;
|
||||||
|
@ -874,29 +875,39 @@ typedef struct {
|
||||||
int32_t tSerializeSDropUserReq(void* buf, int32_t bufLen, SDropUserReq* pReq);
|
int32_t tSerializeSDropUserReq(void* buf, int32_t bufLen, SDropUserReq* pReq);
|
||||||
int32_t tDeserializeSDropUserReq(void* buf, int32_t bufLen, SDropUserReq* pReq);
|
int32_t tDeserializeSDropUserReq(void* buf, int32_t bufLen, SDropUserReq* pReq);
|
||||||
|
|
||||||
|
typedef struct SIpV4Range {
|
||||||
|
uint32_t ip;
|
||||||
|
uint32_t mask;
|
||||||
|
} SIpV4Range;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
int8_t createType;
|
int8_t createType;
|
||||||
int8_t superUser; // denote if it is a super user or not
|
int8_t superUser; // denote if it is a super user or not
|
||||||
int8_t sysInfo;
|
int8_t sysInfo;
|
||||||
int8_t enable;
|
int8_t enable;
|
||||||
char user[TSDB_USER_LEN];
|
char user[TSDB_USER_LEN];
|
||||||
char pass[TSDB_USET_PASSWORD_LEN];
|
char pass[TSDB_USET_PASSWORD_LEN];
|
||||||
|
int32_t numIpRanges;
|
||||||
|
SIpV4Range* pIpRanges;
|
||||||
} SCreateUserReq;
|
} SCreateUserReq;
|
||||||
|
|
||||||
int32_t tSerializeSCreateUserReq(void* buf, int32_t bufLen, SCreateUserReq* pReq);
|
int32_t tSerializeSCreateUserReq(void* buf, int32_t bufLen, SCreateUserReq* pReq);
|
||||||
int32_t tDeserializeSCreateUserReq(void* buf, int32_t bufLen, SCreateUserReq* pReq);
|
int32_t tDeserializeSCreateUserReq(void* buf, int32_t bufLen, SCreateUserReq* pReq);
|
||||||
|
void tFreeSCreateUserReq(SCreateUserReq* pReq);
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
int8_t alterType;
|
int8_t alterType;
|
||||||
int8_t superUser;
|
int8_t superUser;
|
||||||
int8_t sysInfo;
|
int8_t sysInfo;
|
||||||
int8_t enable;
|
int8_t enable;
|
||||||
char user[TSDB_USER_LEN];
|
char user[TSDB_USER_LEN];
|
||||||
char pass[TSDB_USET_PASSWORD_LEN];
|
char pass[TSDB_USET_PASSWORD_LEN];
|
||||||
char objname[TSDB_DB_FNAME_LEN]; // db or topic
|
char objname[TSDB_DB_FNAME_LEN]; // db or topic
|
||||||
char tabName[TSDB_TABLE_NAME_LEN];
|
char tabName[TSDB_TABLE_NAME_LEN];
|
||||||
char* tagCond;
|
char* tagCond;
|
||||||
int32_t tagCondLen;
|
int32_t tagCondLen;
|
||||||
|
int32_t numIpRanges;
|
||||||
|
SIpV4Range* pIpRanges;
|
||||||
} SAlterUserReq;
|
} SAlterUserReq;
|
||||||
|
|
||||||
int32_t tSerializeSAlterUserReq(void* buf, int32_t bufLen, SAlterUserReq* pReq);
|
int32_t tSerializeSAlterUserReq(void* buf, int32_t bufLen, SAlterUserReq* pReq);
|
||||||
|
@ -973,14 +984,12 @@ typedef struct {
|
||||||
int64_t offset;
|
int64_t offset;
|
||||||
} SInterval;
|
} SInterval;
|
||||||
|
|
||||||
|
|
||||||
typedef struct STbVerInfo {
|
typedef struct STbVerInfo {
|
||||||
char tbFName[TSDB_TABLE_FNAME_LEN];
|
char tbFName[TSDB_TABLE_FNAME_LEN];
|
||||||
int32_t sversion;
|
int32_t sversion;
|
||||||
int32_t tversion;
|
int32_t tversion;
|
||||||
} STbVerInfo;
|
} STbVerInfo;
|
||||||
|
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
int32_t code;
|
int32_t code;
|
||||||
int64_t affectedRows;
|
int64_t affectedRows;
|
||||||
|
@ -1203,13 +1212,13 @@ typedef struct {
|
||||||
int16_t sstTrigger;
|
int16_t sstTrigger;
|
||||||
} SDbCfgRsp;
|
} SDbCfgRsp;
|
||||||
|
|
||||||
typedef SDbCfgRsp SDbCfgInfo;
|
typedef SDbCfgRsp SDbCfgInfo;
|
||||||
|
|
||||||
int32_t tSerializeSDbCfgRspImpl(SEncoder *encoder, const SDbCfgRsp *pRsp);
|
int32_t tSerializeSDbCfgRspImpl(SEncoder* encoder, const SDbCfgRsp* pRsp);
|
||||||
int32_t tSerializeSDbCfgRsp(void* buf, int32_t bufLen, const SDbCfgRsp* pRsp);
|
int32_t tSerializeSDbCfgRsp(void* buf, int32_t bufLen, const SDbCfgRsp* pRsp);
|
||||||
int32_t tDeserializeSDbCfgRsp(void* buf, int32_t bufLen, SDbCfgRsp* pRsp);
|
int32_t tDeserializeSDbCfgRsp(void* buf, int32_t bufLen, SDbCfgRsp* pRsp);
|
||||||
int32_t tDeserializeSDbCfgRspImpl(SDecoder* decoder, SDbCfgRsp *pRsp);
|
int32_t tDeserializeSDbCfgRspImpl(SDecoder* decoder, SDbCfgRsp* pRsp);
|
||||||
void tFreeSDbCfgRsp(SDbCfgRsp *pRsp);
|
void tFreeSDbCfgRsp(SDbCfgRsp* pRsp);
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
int32_t rowNum;
|
int32_t rowNum;
|
||||||
|
@ -1266,8 +1275,8 @@ int32_t tDeserializeSDnodeListRsp(void* buf, int32_t bufLen, SDnodeListRsp* pRsp
|
||||||
void tFreeSDnodeListRsp(SDnodeListRsp* pRsp);
|
void tFreeSDnodeListRsp(SDnodeListRsp* pRsp);
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
SUseDbRsp *useDbRsp;
|
SUseDbRsp* useDbRsp;
|
||||||
SDbCfgRsp *cfgRsp;
|
SDbCfgRsp* cfgRsp;
|
||||||
} SDbHbRsp;
|
} SDbHbRsp;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
|
@ -1368,6 +1377,7 @@ typedef struct {
|
||||||
char locale[TD_LOCALE_LEN]; // tsLocale
|
char locale[TD_LOCALE_LEN]; // tsLocale
|
||||||
char charset[TD_LOCALE_LEN]; // tsCharset
|
char charset[TD_LOCALE_LEN]; // tsCharset
|
||||||
int8_t ttlChangeOnWrite;
|
int8_t ttlChangeOnWrite;
|
||||||
|
int8_t enableWhiteList;
|
||||||
} SClusterCfg;
|
} SClusterCfg;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
|
@ -1402,7 +1412,7 @@ typedef struct {
|
||||||
int64_t numOfBatchInsertReqs;
|
int64_t numOfBatchInsertReqs;
|
||||||
int64_t numOfBatchInsertSuccessReqs;
|
int64_t numOfBatchInsertSuccessReqs;
|
||||||
int32_t numOfCachedTables;
|
int32_t numOfCachedTables;
|
||||||
int32_t learnerProgress; // use one reservered
|
int32_t learnerProgress; // use one reservered
|
||||||
} SVnodeLoad;
|
} SVnodeLoad;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
|
@ -2062,17 +2072,16 @@ typedef struct {
|
||||||
int32_t tversion;
|
int32_t tversion;
|
||||||
} SResReadyRsp;
|
} SResReadyRsp;
|
||||||
|
|
||||||
|
|
||||||
typedef struct SOperatorParam {
|
typedef struct SOperatorParam {
|
||||||
int32_t opType;
|
int32_t opType;
|
||||||
int32_t downstreamIdx;
|
int32_t downstreamIdx;
|
||||||
void* value;
|
void* value;
|
||||||
SArray* pChildren; //SArray<SOperatorParam*>
|
SArray* pChildren; // SArray<SOperatorParam*>
|
||||||
} SOperatorParam;
|
} SOperatorParam;
|
||||||
|
|
||||||
typedef struct STableScanOperatorParam {
|
typedef struct STableScanOperatorParam {
|
||||||
bool tableSeq;
|
bool tableSeq;
|
||||||
SArray* pUidList;
|
SArray* pUidList;
|
||||||
} STableScanOperatorParam;
|
} STableScanOperatorParam;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
|
@ -2161,7 +2170,6 @@ typedef struct {
|
||||||
int32_t tSerializeSTaskDropReq(void* buf, int32_t bufLen, STaskDropReq* pReq);
|
int32_t tSerializeSTaskDropReq(void* buf, int32_t bufLen, STaskDropReq* pReq);
|
||||||
int32_t tDeserializeSTaskDropReq(void* buf, int32_t bufLen, STaskDropReq* pReq);
|
int32_t tDeserializeSTaskDropReq(void* buf, int32_t bufLen, STaskDropReq* pReq);
|
||||||
|
|
||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
TASK_NOTIFY_FINISHED = 1,
|
TASK_NOTIFY_FINISHED = 1,
|
||||||
} ETaskNotifyType;
|
} ETaskNotifyType;
|
||||||
|
@ -2285,10 +2293,10 @@ typedef struct {
|
||||||
char clientId[256];
|
char clientId[256];
|
||||||
SArray* topicNames; // SArray<char**>
|
SArray* topicNames; // SArray<char**>
|
||||||
|
|
||||||
int8_t withTbName;
|
int8_t withTbName;
|
||||||
int8_t autoCommit;
|
int8_t autoCommit;
|
||||||
int32_t autoCommitInterval;
|
int32_t autoCommitInterval;
|
||||||
int8_t resetOffsetCfg;
|
int8_t resetOffsetCfg;
|
||||||
} SCMSubscribeReq;
|
} SCMSubscribeReq;
|
||||||
|
|
||||||
static FORCE_INLINE int32_t tSerializeSCMSubscribeReq(void** buf, const SCMSubscribeReq* pReq) {
|
static FORCE_INLINE int32_t tSerializeSCMSubscribeReq(void** buf, const SCMSubscribeReq* pReq) {
|
||||||
|
@ -2665,7 +2673,7 @@ typedef struct {
|
||||||
int32_t newTTL;
|
int32_t newTTL;
|
||||||
int32_t newCommentLen;
|
int32_t newCommentLen;
|
||||||
char* newComment;
|
char* newComment;
|
||||||
int64_t ctimeMs; // fill by vnode
|
int64_t ctimeMs; // fill by vnode
|
||||||
} SVAlterTbReq;
|
} SVAlterTbReq;
|
||||||
|
|
||||||
int32_t tEncodeSVAlterTbReq(SEncoder* pEncoder, const SVAlterTbReq* pReq);
|
int32_t tEncodeSVAlterTbReq(SEncoder* pEncoder, const SVAlterTbReq* pReq);
|
||||||
|
@ -3069,7 +3077,7 @@ typedef struct {
|
||||||
int64_t suid;
|
int64_t suid;
|
||||||
} SMqRebVgReq;
|
} SMqRebVgReq;
|
||||||
|
|
||||||
static FORCE_INLINE int tEncodeSMqRebVgReq(SEncoder *pCoder, const SMqRebVgReq* pReq) {
|
static FORCE_INLINE int tEncodeSMqRebVgReq(SEncoder* pCoder, const SMqRebVgReq* pReq) {
|
||||||
if (tStartEncode(pCoder) < 0) return -1;
|
if (tStartEncode(pCoder) < 0) return -1;
|
||||||
if (tEncodeI64(pCoder, pReq->leftForVer) < 0) return -1;
|
if (tEncodeI64(pCoder, pReq->leftForVer) < 0) return -1;
|
||||||
if (tEncodeI32(pCoder, pReq->vgId) < 0) return -1;
|
if (tEncodeI32(pCoder, pReq->vgId) < 0) return -1;
|
||||||
|
@ -3089,7 +3097,7 @@ static FORCE_INLINE int tEncodeSMqRebVgReq(SEncoder *pCoder, const SMqRebVgReq*
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static FORCE_INLINE int tDecodeSMqRebVgReq(SDecoder *pCoder, SMqRebVgReq* pReq) {
|
static FORCE_INLINE int tDecodeSMqRebVgReq(SDecoder* pCoder, SMqRebVgReq* pReq) {
|
||||||
if (tStartDecode(pCoder) < 0) return -1;
|
if (tStartDecode(pCoder) < 0) return -1;
|
||||||
|
|
||||||
if (tDecodeI64(pCoder, &pReq->leftForVer) < 0) return -1;
|
if (tDecodeI64(pCoder, &pReq->leftForVer) < 0) return -1;
|
||||||
|
@ -3105,7 +3113,7 @@ static FORCE_INLINE int tDecodeSMqRebVgReq(SDecoder *pCoder, SMqRebVgReq* pReq)
|
||||||
if (tDecodeCStr(pCoder, &pReq->qmsg) < 0) return -1;
|
if (tDecodeCStr(pCoder, &pReq->qmsg) < 0) return -1;
|
||||||
} else if (pReq->subType == TOPIC_SUB_TYPE__TABLE) {
|
} else if (pReq->subType == TOPIC_SUB_TYPE__TABLE) {
|
||||||
if (tDecodeI64(pCoder, &pReq->suid) < 0) return -1;
|
if (tDecodeI64(pCoder, &pReq->suid) < 0) return -1;
|
||||||
if (!tDecodeIsEnd(pCoder)){
|
if (!tDecodeIsEnd(pCoder)) {
|
||||||
if (tDecodeCStr(pCoder, &pReq->qmsg) < 0) return -1;
|
if (tDecodeCStr(pCoder, &pReq->qmsg) < 0) return -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3629,12 +3637,12 @@ typedef struct {
|
||||||
int32_t vgId;
|
int32_t vgId;
|
||||||
STqOffsetVal offset;
|
STqOffsetVal offset;
|
||||||
int64_t rows;
|
int64_t rows;
|
||||||
}OffsetRows;
|
} OffsetRows;
|
||||||
|
|
||||||
typedef struct{
|
typedef struct {
|
||||||
char topicName[TSDB_TOPIC_FNAME_LEN];
|
char topicName[TSDB_TOPIC_FNAME_LEN];
|
||||||
SArray* offsetRows;
|
SArray* offsetRows;
|
||||||
}TopicOffsetRows;
|
} TopicOffsetRows;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
int64_t consumerId;
|
int64_t consumerId;
|
||||||
|
@ -3647,9 +3655,9 @@ typedef struct {
|
||||||
} SMqHbRsp;
|
} SMqHbRsp;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
SMsgHead head;
|
SMsgHead head;
|
||||||
int64_t consumerId;
|
int64_t consumerId;
|
||||||
char subKey[TSDB_SUBSCRIBE_KEY_LEN];
|
char subKey[TSDB_SUBSCRIBE_KEY_LEN];
|
||||||
} SMqSeekReq;
|
} SMqSeekReq;
|
||||||
|
|
||||||
#define TD_AUTO_CREATE_TABLE 0x1
|
#define TD_AUTO_CREATE_TABLE 0x1
|
||||||
|
@ -3703,7 +3711,7 @@ typedef struct SDeleteRes {
|
||||||
int64_t affectedRows;
|
int64_t affectedRows;
|
||||||
char tableFName[TSDB_TABLE_NAME_LEN];
|
char tableFName[TSDB_TABLE_NAME_LEN];
|
||||||
char tsColName[TSDB_COL_NAME_LEN];
|
char tsColName[TSDB_COL_NAME_LEN];
|
||||||
int64_t ctimeMs; // fill by vnode
|
int64_t ctimeMs; // fill by vnode
|
||||||
} SDeleteRes;
|
} SDeleteRes;
|
||||||
|
|
||||||
int32_t tEncodeDeleteRes(SEncoder* pCoder, const SDeleteRes* pRes);
|
int32_t tEncodeDeleteRes(SEncoder* pCoder, const SDeleteRes* pRes);
|
||||||
|
@ -3781,8 +3789,8 @@ int32_t tSerializeSMqHbReq(void* buf, int32_t bufLen, SMqHbReq* pReq);
|
||||||
int32_t tDeserializeSMqHbReq(void* buf, int32_t bufLen, SMqHbReq* pReq);
|
int32_t tDeserializeSMqHbReq(void* buf, int32_t bufLen, SMqHbReq* pReq);
|
||||||
int32_t tDeatroySMqHbReq(SMqHbReq* pReq);
|
int32_t tDeatroySMqHbReq(SMqHbReq* pReq);
|
||||||
|
|
||||||
int32_t tSerializeSMqSeekReq(void *buf, int32_t bufLen, SMqSeekReq *pReq);
|
int32_t tSerializeSMqSeekReq(void* buf, int32_t bufLen, SMqSeekReq* pReq);
|
||||||
int32_t tDeserializeSMqSeekReq(void *buf, int32_t bufLen, SMqSeekReq *pReq);
|
int32_t tDeserializeSMqSeekReq(void* buf, int32_t bufLen, SMqSeekReq* pReq);
|
||||||
|
|
||||||
#define SUBMIT_REQ_AUTO_CREATE_TABLE 0x1
|
#define SUBMIT_REQ_AUTO_CREATE_TABLE 0x1
|
||||||
#define SUBMIT_REQ_COLUMN_DATA_FORMAT 0x2
|
#define SUBMIT_REQ_COLUMN_DATA_FORMAT 0x2
|
||||||
|
@ -3797,7 +3805,7 @@ typedef struct {
|
||||||
SArray* aRowP;
|
SArray* aRowP;
|
||||||
SArray* aCol;
|
SArray* aCol;
|
||||||
};
|
};
|
||||||
int64_t ctimeMs;
|
int64_t ctimeMs;
|
||||||
} SSubmitTbData;
|
} SSubmitTbData;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
|
|
|
@ -16,6 +16,7 @@
|
||||||
#ifndef _TD_COMMON_TOKEN_H_
|
#ifndef _TD_COMMON_TOKEN_H_
|
||||||
#define _TD_COMMON_TOKEN_H_
|
#define _TD_COMMON_TOKEN_H_
|
||||||
|
|
||||||
|
|
||||||
#define TK_OR 1
|
#define TK_OR 1
|
||||||
#define TK_AND 2
|
#define TK_AND 2
|
||||||
#define TK_UNION 3
|
#define TK_UNION 3
|
||||||
|
@ -48,313 +49,313 @@
|
||||||
#define TK_USERS 30
|
#define TK_USERS 30
|
||||||
#define TK_CONNS 31
|
#define TK_CONNS 31
|
||||||
#define TK_STATE 32
|
#define TK_STATE 32
|
||||||
#define TK_USER 33
|
#define TK_NK_COMMA 33
|
||||||
#define TK_ENABLE 34
|
#define TK_HOST 34
|
||||||
#define TK_NK_INTEGER 35
|
#define TK_USER 35
|
||||||
#define TK_SYSINFO 36
|
#define TK_ENABLE 36
|
||||||
#define TK_DROP 37
|
#define TK_NK_INTEGER 37
|
||||||
#define TK_GRANT 38
|
#define TK_SYSINFO 38
|
||||||
#define TK_ON 39
|
#define TK_ADD 39
|
||||||
#define TK_TO 40
|
#define TK_DROP 40
|
||||||
#define TK_REVOKE 41
|
#define TK_GRANT 41
|
||||||
#define TK_FROM 42
|
#define TK_ON 42
|
||||||
#define TK_SUBSCRIBE 43
|
#define TK_TO 43
|
||||||
#define TK_NK_COMMA 44
|
#define TK_REVOKE 44
|
||||||
#define TK_READ 45
|
#define TK_FROM 45
|
||||||
#define TK_WRITE 46
|
#define TK_SUBSCRIBE 46
|
||||||
#define TK_NK_DOT 47
|
#define TK_READ 47
|
||||||
#define TK_WITH 48
|
#define TK_WRITE 48
|
||||||
#define TK_DNODE 49
|
#define TK_NK_DOT 49
|
||||||
#define TK_PORT 50
|
#define TK_WITH 50
|
||||||
#define TK_DNODES 51
|
#define TK_DNODE 51
|
||||||
#define TK_RESTORE 52
|
#define TK_PORT 52
|
||||||
#define TK_NK_IPTOKEN 53
|
#define TK_DNODES 53
|
||||||
#define TK_FORCE 54
|
#define TK_RESTORE 54
|
||||||
#define TK_UNSAFE 55
|
#define TK_NK_IPTOKEN 55
|
||||||
#define TK_LOCAL 56
|
#define TK_FORCE 56
|
||||||
#define TK_QNODE 57
|
#define TK_UNSAFE 57
|
||||||
#define TK_BNODE 58
|
#define TK_LOCAL 58
|
||||||
#define TK_SNODE 59
|
#define TK_QNODE 59
|
||||||
#define TK_MNODE 60
|
#define TK_BNODE 60
|
||||||
#define TK_VNODE 61
|
#define TK_SNODE 61
|
||||||
#define TK_DATABASE 62
|
#define TK_MNODE 62
|
||||||
#define TK_USE 63
|
#define TK_VNODE 63
|
||||||
#define TK_FLUSH 64
|
#define TK_DATABASE 64
|
||||||
#define TK_TRIM 65
|
#define TK_USE 65
|
||||||
#define TK_COMPACT 66
|
#define TK_FLUSH 66
|
||||||
#define TK_IF 67
|
#define TK_TRIM 67
|
||||||
#define TK_NOT 68
|
#define TK_COMPACT 68
|
||||||
#define TK_EXISTS 69
|
#define TK_IF 69
|
||||||
#define TK_BUFFER 70
|
#define TK_NOT 70
|
||||||
#define TK_CACHEMODEL 71
|
#define TK_EXISTS 71
|
||||||
#define TK_CACHESIZE 72
|
#define TK_BUFFER 72
|
||||||
#define TK_COMP 73
|
#define TK_CACHEMODEL 73
|
||||||
#define TK_DURATION 74
|
#define TK_CACHESIZE 74
|
||||||
#define TK_NK_VARIABLE 75
|
#define TK_COMP 75
|
||||||
#define TK_MAXROWS 76
|
#define TK_DURATION 76
|
||||||
#define TK_MINROWS 77
|
#define TK_NK_VARIABLE 77
|
||||||
#define TK_KEEP 78
|
#define TK_MAXROWS 78
|
||||||
#define TK_PAGES 79
|
#define TK_MINROWS 79
|
||||||
#define TK_PAGESIZE 80
|
#define TK_KEEP 80
|
||||||
#define TK_TSDB_PAGESIZE 81
|
#define TK_PAGES 81
|
||||||
#define TK_PRECISION 82
|
#define TK_PAGESIZE 82
|
||||||
#define TK_REPLICA 83
|
#define TK_TSDB_PAGESIZE 83
|
||||||
#define TK_VGROUPS 84
|
#define TK_PRECISION 84
|
||||||
#define TK_SINGLE_STABLE 85
|
#define TK_REPLICA 85
|
||||||
#define TK_RETENTIONS 86
|
#define TK_VGROUPS 86
|
||||||
#define TK_SCHEMALESS 87
|
#define TK_SINGLE_STABLE 87
|
||||||
#define TK_WAL_LEVEL 88
|
#define TK_RETENTIONS 88
|
||||||
#define TK_WAL_FSYNC_PERIOD 89
|
#define TK_SCHEMALESS 89
|
||||||
#define TK_WAL_RETENTION_PERIOD 90
|
#define TK_WAL_LEVEL 90
|
||||||
#define TK_WAL_RETENTION_SIZE 91
|
#define TK_WAL_FSYNC_PERIOD 91
|
||||||
#define TK_WAL_ROLL_PERIOD 92
|
#define TK_WAL_RETENTION_PERIOD 92
|
||||||
#define TK_WAL_SEGMENT_SIZE 93
|
#define TK_WAL_RETENTION_SIZE 93
|
||||||
#define TK_STT_TRIGGER 94
|
#define TK_WAL_ROLL_PERIOD 94
|
||||||
#define TK_TABLE_PREFIX 95
|
#define TK_WAL_SEGMENT_SIZE 95
|
||||||
#define TK_TABLE_SUFFIX 96
|
#define TK_STT_TRIGGER 96
|
||||||
#define TK_NK_COLON 97
|
#define TK_TABLE_PREFIX 97
|
||||||
#define TK_BWLIMIT 98
|
#define TK_TABLE_SUFFIX 98
|
||||||
#define TK_START 99
|
#define TK_NK_COLON 99
|
||||||
#define TK_TIMESTAMP 100
|
#define TK_BWLIMIT 100
|
||||||
#define TK_END 101
|
#define TK_START 101
|
||||||
#define TK_TABLE 102
|
#define TK_TIMESTAMP 102
|
||||||
#define TK_NK_LP 103
|
#define TK_END 103
|
||||||
#define TK_NK_RP 104
|
#define TK_TABLE 104
|
||||||
#define TK_STABLE 105
|
#define TK_NK_LP 105
|
||||||
#define TK_ADD 106
|
#define TK_NK_RP 106
|
||||||
#define TK_COLUMN 107
|
#define TK_STABLE 107
|
||||||
#define TK_MODIFY 108
|
#define TK_COLUMN 108
|
||||||
#define TK_RENAME 109
|
#define TK_MODIFY 109
|
||||||
#define TK_TAG 110
|
#define TK_RENAME 110
|
||||||
#define TK_SET 111
|
#define TK_TAG 111
|
||||||
#define TK_NK_EQ 112
|
#define TK_SET 112
|
||||||
#define TK_USING 113
|
#define TK_NK_EQ 113
|
||||||
#define TK_TAGS 114
|
#define TK_USING 114
|
||||||
#define TK_BOOL 115
|
#define TK_TAGS 115
|
||||||
#define TK_TINYINT 116
|
#define TK_BOOL 116
|
||||||
#define TK_SMALLINT 117
|
#define TK_TINYINT 117
|
||||||
#define TK_INT 118
|
#define TK_SMALLINT 118
|
||||||
#define TK_INTEGER 119
|
#define TK_INT 119
|
||||||
#define TK_BIGINT 120
|
#define TK_INTEGER 120
|
||||||
#define TK_FLOAT 121
|
#define TK_BIGINT 121
|
||||||
#define TK_DOUBLE 122
|
#define TK_FLOAT 122
|
||||||
#define TK_BINARY 123
|
#define TK_DOUBLE 123
|
||||||
#define TK_NCHAR 124
|
#define TK_BINARY 124
|
||||||
#define TK_UNSIGNED 125
|
#define TK_NCHAR 125
|
||||||
#define TK_JSON 126
|
#define TK_UNSIGNED 126
|
||||||
#define TK_VARCHAR 127
|
#define TK_JSON 127
|
||||||
#define TK_MEDIUMBLOB 128
|
#define TK_VARCHAR 128
|
||||||
#define TK_BLOB 129
|
#define TK_MEDIUMBLOB 129
|
||||||
#define TK_VARBINARY 130
|
#define TK_BLOB 130
|
||||||
#define TK_GEOMETRY 131
|
#define TK_VARBINARY 131
|
||||||
#define TK_DECIMAL 132
|
#define TK_GEOMETRY 132
|
||||||
#define TK_COMMENT 133
|
#define TK_DECIMAL 133
|
||||||
#define TK_MAX_DELAY 134
|
#define TK_COMMENT 134
|
||||||
#define TK_WATERMARK 135
|
#define TK_MAX_DELAY 135
|
||||||
#define TK_ROLLUP 136
|
#define TK_WATERMARK 136
|
||||||
#define TK_TTL 137
|
#define TK_ROLLUP 137
|
||||||
#define TK_SMA 138
|
#define TK_TTL 138
|
||||||
#define TK_DELETE_MARK 139
|
#define TK_SMA 139
|
||||||
#define TK_FIRST 140
|
#define TK_DELETE_MARK 140
|
||||||
#define TK_LAST 141
|
#define TK_FIRST 141
|
||||||
#define TK_SHOW 142
|
#define TK_LAST 142
|
||||||
#define TK_PRIVILEGES 143
|
#define TK_SHOW 143
|
||||||
#define TK_DATABASES 144
|
#define TK_PRIVILEGES 144
|
||||||
#define TK_TABLES 145
|
#define TK_DATABASES 145
|
||||||
#define TK_STABLES 146
|
#define TK_TABLES 146
|
||||||
#define TK_MNODES 147
|
#define TK_STABLES 147
|
||||||
#define TK_QNODES 148
|
#define TK_MNODES 148
|
||||||
#define TK_FUNCTIONS 149
|
#define TK_QNODES 149
|
||||||
#define TK_INDEXES 150
|
#define TK_FUNCTIONS 150
|
||||||
#define TK_ACCOUNTS 151
|
#define TK_INDEXES 151
|
||||||
#define TK_APPS 152
|
#define TK_ACCOUNTS 152
|
||||||
#define TK_CONNECTIONS 153
|
#define TK_APPS 153
|
||||||
#define TK_LICENCES 154
|
#define TK_CONNECTIONS 154
|
||||||
#define TK_GRANTS 155
|
#define TK_LICENCES 155
|
||||||
#define TK_QUERIES 156
|
#define TK_GRANTS 156
|
||||||
#define TK_SCORES 157
|
#define TK_QUERIES 157
|
||||||
#define TK_TOPICS 158
|
#define TK_SCORES 158
|
||||||
#define TK_VARIABLES 159
|
#define TK_TOPICS 159
|
||||||
#define TK_CLUSTER 160
|
#define TK_VARIABLES 160
|
||||||
#define TK_BNODES 161
|
#define TK_CLUSTER 161
|
||||||
#define TK_SNODES 162
|
#define TK_BNODES 162
|
||||||
#define TK_TRANSACTIONS 163
|
#define TK_SNODES 163
|
||||||
#define TK_DISTRIBUTED 164
|
#define TK_TRANSACTIONS 164
|
||||||
#define TK_CONSUMERS 165
|
#define TK_DISTRIBUTED 165
|
||||||
#define TK_SUBSCRIPTIONS 166
|
#define TK_CONSUMERS 166
|
||||||
#define TK_VNODES 167
|
#define TK_SUBSCRIPTIONS 167
|
||||||
#define TK_ALIVE 168
|
#define TK_VNODES 168
|
||||||
#define TK_LIKE 169
|
#define TK_ALIVE 169
|
||||||
#define TK_TBNAME 170
|
#define TK_LIKE 170
|
||||||
#define TK_QTAGS 171
|
#define TK_TBNAME 171
|
||||||
#define TK_AS 172
|
#define TK_QTAGS 172
|
||||||
#define TK_INDEX 173
|
#define TK_AS 173
|
||||||
#define TK_FUNCTION 174
|
#define TK_INDEX 174
|
||||||
#define TK_INTERVAL 175
|
#define TK_FUNCTION 175
|
||||||
#define TK_COUNT 176
|
#define TK_INTERVAL 176
|
||||||
#define TK_LAST_ROW 177
|
#define TK_COUNT 177
|
||||||
#define TK_META 178
|
#define TK_LAST_ROW 178
|
||||||
#define TK_ONLY 179
|
#define TK_META 179
|
||||||
#define TK_TOPIC 180
|
#define TK_ONLY 180
|
||||||
#define TK_CONSUMER 181
|
#define TK_TOPIC 181
|
||||||
#define TK_GROUP 182
|
#define TK_CONSUMER 182
|
||||||
#define TK_DESC 183
|
#define TK_GROUP 183
|
||||||
#define TK_DESCRIBE 184
|
#define TK_DESC 184
|
||||||
#define TK_RESET 185
|
#define TK_DESCRIBE 185
|
||||||
#define TK_QUERY 186
|
#define TK_RESET 186
|
||||||
#define TK_CACHE 187
|
#define TK_QUERY 187
|
||||||
#define TK_EXPLAIN 188
|
#define TK_CACHE 188
|
||||||
#define TK_ANALYZE 189
|
#define TK_EXPLAIN 189
|
||||||
#define TK_VERBOSE 190
|
#define TK_ANALYZE 190
|
||||||
#define TK_NK_BOOL 191
|
#define TK_VERBOSE 191
|
||||||
#define TK_RATIO 192
|
#define TK_NK_BOOL 192
|
||||||
#define TK_NK_FLOAT 193
|
#define TK_RATIO 193
|
||||||
#define TK_OUTPUTTYPE 194
|
#define TK_NK_FLOAT 194
|
||||||
#define TK_AGGREGATE 195
|
#define TK_OUTPUTTYPE 195
|
||||||
#define TK_BUFSIZE 196
|
#define TK_AGGREGATE 196
|
||||||
#define TK_LANGUAGE 197
|
#define TK_BUFSIZE 197
|
||||||
#define TK_REPLACE 198
|
#define TK_LANGUAGE 198
|
||||||
#define TK_STREAM 199
|
#define TK_REPLACE 199
|
||||||
#define TK_INTO 200
|
#define TK_STREAM 200
|
||||||
#define TK_PAUSE 201
|
#define TK_INTO 201
|
||||||
#define TK_RESUME 202
|
#define TK_PAUSE 202
|
||||||
#define TK_TRIGGER 203
|
#define TK_RESUME 203
|
||||||
#define TK_AT_ONCE 204
|
#define TK_TRIGGER 204
|
||||||
#define TK_WINDOW_CLOSE 205
|
#define TK_AT_ONCE 205
|
||||||
#define TK_IGNORE 206
|
#define TK_WINDOW_CLOSE 206
|
||||||
#define TK_EXPIRED 207
|
#define TK_IGNORE 207
|
||||||
#define TK_FILL_HISTORY 208
|
#define TK_EXPIRED 208
|
||||||
#define TK_UPDATE 209
|
#define TK_FILL_HISTORY 209
|
||||||
#define TK_SUBTABLE 210
|
#define TK_UPDATE 210
|
||||||
#define TK_UNTREATED 211
|
#define TK_SUBTABLE 211
|
||||||
#define TK_KILL 212
|
#define TK_UNTREATED 212
|
||||||
#define TK_CONNECTION 213
|
#define TK_KILL 213
|
||||||
#define TK_TRANSACTION 214
|
#define TK_CONNECTION 214
|
||||||
#define TK_BALANCE 215
|
#define TK_TRANSACTION 215
|
||||||
#define TK_VGROUP 216
|
#define TK_BALANCE 216
|
||||||
#define TK_LEADER 217
|
#define TK_VGROUP 217
|
||||||
#define TK_MERGE 218
|
#define TK_LEADER 218
|
||||||
#define TK_REDISTRIBUTE 219
|
#define TK_MERGE 219
|
||||||
#define TK_SPLIT 220
|
#define TK_REDISTRIBUTE 220
|
||||||
#define TK_DELETE 221
|
#define TK_SPLIT 221
|
||||||
#define TK_INSERT 222
|
#define TK_DELETE 222
|
||||||
#define TK_NULL 223
|
#define TK_INSERT 223
|
||||||
#define TK_NK_QUESTION 224
|
#define TK_NULL 224
|
||||||
#define TK_NK_ARROW 225
|
#define TK_NK_QUESTION 225
|
||||||
#define TK_ROWTS 226
|
#define TK_NK_ARROW 226
|
||||||
#define TK_QSTART 227
|
#define TK_ROWTS 227
|
||||||
#define TK_QEND 228
|
#define TK_QSTART 228
|
||||||
#define TK_QDURATION 229
|
#define TK_QEND 229
|
||||||
#define TK_WSTART 230
|
#define TK_QDURATION 230
|
||||||
#define TK_WEND 231
|
#define TK_WSTART 231
|
||||||
#define TK_WDURATION 232
|
#define TK_WEND 232
|
||||||
#define TK_IROWTS 233
|
#define TK_WDURATION 233
|
||||||
#define TK_ISFILLED 234
|
#define TK_IROWTS 234
|
||||||
#define TK_CAST 235
|
#define TK_ISFILLED 235
|
||||||
#define TK_NOW 236
|
#define TK_CAST 236
|
||||||
#define TK_TODAY 237
|
#define TK_NOW 237
|
||||||
#define TK_TIMEZONE 238
|
#define TK_TODAY 238
|
||||||
#define TK_CLIENT_VERSION 239
|
#define TK_TIMEZONE 239
|
||||||
#define TK_SERVER_VERSION 240
|
#define TK_CLIENT_VERSION 240
|
||||||
#define TK_SERVER_STATUS 241
|
#define TK_SERVER_VERSION 241
|
||||||
#define TK_CURRENT_USER 242
|
#define TK_SERVER_STATUS 242
|
||||||
#define TK_CASE 243
|
#define TK_CURRENT_USER 243
|
||||||
#define TK_WHEN 244
|
#define TK_CASE 244
|
||||||
#define TK_THEN 245
|
#define TK_WHEN 245
|
||||||
#define TK_ELSE 246
|
#define TK_THEN 246
|
||||||
#define TK_BETWEEN 247
|
#define TK_ELSE 247
|
||||||
#define TK_IS 248
|
#define TK_BETWEEN 248
|
||||||
#define TK_NK_LT 249
|
#define TK_IS 249
|
||||||
#define TK_NK_GT 250
|
#define TK_NK_LT 250
|
||||||
#define TK_NK_LE 251
|
#define TK_NK_GT 251
|
||||||
#define TK_NK_GE 252
|
#define TK_NK_LE 252
|
||||||
#define TK_NK_NE 253
|
#define TK_NK_GE 253
|
||||||
#define TK_MATCH 254
|
#define TK_NK_NE 254
|
||||||
#define TK_NMATCH 255
|
#define TK_MATCH 255
|
||||||
#define TK_CONTAINS 256
|
#define TK_NMATCH 256
|
||||||
#define TK_IN 257
|
#define TK_CONTAINS 257
|
||||||
#define TK_JOIN 258
|
#define TK_IN 258
|
||||||
#define TK_INNER 259
|
#define TK_JOIN 259
|
||||||
#define TK_SELECT 260
|
#define TK_INNER 260
|
||||||
#define TK_NK_HINT 261
|
#define TK_SELECT 261
|
||||||
#define TK_DISTINCT 262
|
#define TK_NK_HINT 262
|
||||||
#define TK_WHERE 263
|
#define TK_DISTINCT 263
|
||||||
#define TK_PARTITION 264
|
#define TK_WHERE 264
|
||||||
#define TK_BY 265
|
#define TK_PARTITION 265
|
||||||
#define TK_SESSION 266
|
#define TK_BY 266
|
||||||
#define TK_STATE_WINDOW 267
|
#define TK_SESSION 267
|
||||||
#define TK_EVENT_WINDOW 268
|
#define TK_STATE_WINDOW 268
|
||||||
#define TK_SLIDING 269
|
#define TK_EVENT_WINDOW 269
|
||||||
#define TK_FILL 270
|
#define TK_SLIDING 270
|
||||||
#define TK_VALUE 271
|
#define TK_FILL 271
|
||||||
#define TK_VALUE_F 272
|
#define TK_VALUE 272
|
||||||
#define TK_NONE 273
|
#define TK_VALUE_F 273
|
||||||
#define TK_PREV 274
|
#define TK_NONE 274
|
||||||
#define TK_NULL_F 275
|
#define TK_PREV 275
|
||||||
#define TK_LINEAR 276
|
#define TK_NULL_F 276
|
||||||
#define TK_NEXT 277
|
#define TK_LINEAR 277
|
||||||
#define TK_HAVING 278
|
#define TK_NEXT 278
|
||||||
#define TK_RANGE 279
|
#define TK_HAVING 279
|
||||||
#define TK_EVERY 280
|
#define TK_RANGE 280
|
||||||
#define TK_ORDER 281
|
#define TK_EVERY 281
|
||||||
#define TK_SLIMIT 282
|
#define TK_ORDER 282
|
||||||
#define TK_SOFFSET 283
|
#define TK_SLIMIT 283
|
||||||
#define TK_LIMIT 284
|
#define TK_SOFFSET 284
|
||||||
#define TK_OFFSET 285
|
#define TK_LIMIT 285
|
||||||
#define TK_ASC 286
|
#define TK_OFFSET 286
|
||||||
#define TK_NULLS 287
|
#define TK_ASC 287
|
||||||
#define TK_ABORT 288
|
#define TK_NULLS 288
|
||||||
#define TK_AFTER 289
|
#define TK_ABORT 289
|
||||||
#define TK_ATTACH 290
|
#define TK_AFTER 290
|
||||||
#define TK_BEFORE 291
|
#define TK_ATTACH 291
|
||||||
#define TK_BEGIN 292
|
#define TK_BEFORE 292
|
||||||
#define TK_BITAND 293
|
#define TK_BEGIN 293
|
||||||
#define TK_BITNOT 294
|
#define TK_BITAND 294
|
||||||
#define TK_BITOR 295
|
#define TK_BITNOT 295
|
||||||
#define TK_BLOCKS 296
|
#define TK_BITOR 296
|
||||||
#define TK_CHANGE 297
|
#define TK_BLOCKS 297
|
||||||
#define TK_COMMA 298
|
#define TK_CHANGE 298
|
||||||
#define TK_CONCAT 299
|
#define TK_COMMA 299
|
||||||
#define TK_CONFLICT 300
|
#define TK_CONCAT 300
|
||||||
#define TK_COPY 301
|
#define TK_CONFLICT 301
|
||||||
#define TK_DEFERRED 302
|
#define TK_COPY 302
|
||||||
#define TK_DELIMITERS 303
|
#define TK_DEFERRED 303
|
||||||
#define TK_DETACH 304
|
#define TK_DELIMITERS 304
|
||||||
#define TK_DIVIDE 305
|
#define TK_DETACH 305
|
||||||
#define TK_DOT 306
|
#define TK_DIVIDE 306
|
||||||
#define TK_EACH 307
|
#define TK_DOT 307
|
||||||
#define TK_FAIL 308
|
#define TK_EACH 308
|
||||||
#define TK_FILE 309
|
#define TK_FAIL 309
|
||||||
#define TK_FOR 310
|
#define TK_FILE 310
|
||||||
#define TK_GLOB 311
|
#define TK_FOR 311
|
||||||
#define TK_ID 312
|
#define TK_GLOB 312
|
||||||
#define TK_IMMEDIATE 313
|
#define TK_ID 313
|
||||||
#define TK_IMPORT 314
|
#define TK_IMMEDIATE 314
|
||||||
#define TK_INITIALLY 315
|
#define TK_IMPORT 315
|
||||||
#define TK_INSTEAD 316
|
#define TK_INITIALLY 316
|
||||||
#define TK_ISNULL 317
|
#define TK_INSTEAD 317
|
||||||
#define TK_KEY 318
|
#define TK_ISNULL 318
|
||||||
#define TK_MODULES 319
|
#define TK_KEY 319
|
||||||
#define TK_NK_BITNOT 320
|
#define TK_MODULES 320
|
||||||
#define TK_NK_SEMI 321
|
#define TK_NK_BITNOT 321
|
||||||
#define TK_NOTNULL 322
|
#define TK_NK_SEMI 322
|
||||||
#define TK_OF 323
|
#define TK_NOTNULL 323
|
||||||
#define TK_PLUS 324
|
#define TK_OF 324
|
||||||
#define TK_PRIVILEGE 325
|
#define TK_PLUS 325
|
||||||
#define TK_RAISE 326
|
#define TK_PRIVILEGE 326
|
||||||
#define TK_RESTRICT 327
|
#define TK_RAISE 327
|
||||||
#define TK_ROW 328
|
#define TK_RESTRICT 328
|
||||||
#define TK_SEMI 329
|
#define TK_ROW 329
|
||||||
#define TK_STAR 330
|
#define TK_SEMI 330
|
||||||
#define TK_STATEMENT 331
|
#define TK_STAR 331
|
||||||
#define TK_STRICT 332
|
#define TK_STATEMENT 332
|
||||||
#define TK_STRING 333
|
#define TK_STRICT 333
|
||||||
#define TK_TIMES 334
|
#define TK_STRING 334
|
||||||
#define TK_VALUES 335
|
#define TK_TIMES 335
|
||||||
#define TK_VARIABLE 336
|
#define TK_VALUES 336
|
||||||
#define TK_VIEW 337
|
#define TK_VARIABLE 337
|
||||||
#define TK_WAL 338
|
#define TK_VIEW 338
|
||||||
|
#define TK_WAL 339
|
||||||
|
|
||||||
|
|
||||||
#define TK_NK_SPACE 600
|
#define TK_NK_SPACE 600
|
||||||
|
|
|
@ -222,6 +222,10 @@ typedef struct SCreateUserStmt {
|
||||||
char userName[TSDB_USER_LEN];
|
char userName[TSDB_USER_LEN];
|
||||||
char password[TSDB_USET_PASSWORD_LEN];
|
char password[TSDB_USET_PASSWORD_LEN];
|
||||||
int8_t sysinfo;
|
int8_t sysinfo;
|
||||||
|
int32_t numIpRanges;
|
||||||
|
SIpV4Range* pIpRanges;
|
||||||
|
|
||||||
|
SNodeList* pNodeListIpRanges;
|
||||||
} SCreateUserStmt;
|
} SCreateUserStmt;
|
||||||
|
|
||||||
typedef struct SAlterUserStmt {
|
typedef struct SAlterUserStmt {
|
||||||
|
@ -231,6 +235,10 @@ typedef struct SAlterUserStmt {
|
||||||
char password[TSDB_USET_PASSWORD_LEN];
|
char password[TSDB_USET_PASSWORD_LEN];
|
||||||
int8_t enable;
|
int8_t enable;
|
||||||
int8_t sysinfo;
|
int8_t sysinfo;
|
||||||
|
int32_t numIpRanges;
|
||||||
|
SIpV4Range* pIpRanges;
|
||||||
|
|
||||||
|
SNodeList* pNodeListIpRanges;
|
||||||
} SAlterUserStmt;
|
} SAlterUserStmt;
|
||||||
|
|
||||||
typedef struct SDropUserStmt {
|
typedef struct SDropUserStmt {
|
||||||
|
|
|
@ -710,6 +710,7 @@ int32_t* taosGetErrno();
|
||||||
#define TSDB_CODE_PAR_SYSTABLE_NOT_ALLOWED_FUNC TAOS_DEF_ERROR_CODE(0, 0x2668)
|
#define TSDB_CODE_PAR_SYSTABLE_NOT_ALLOWED_FUNC TAOS_DEF_ERROR_CODE(0, 0x2668)
|
||||||
#define TSDB_CODE_PAR_SYSTABLE_NOT_ALLOWED TAOS_DEF_ERROR_CODE(0, 0x2669)
|
#define TSDB_CODE_PAR_SYSTABLE_NOT_ALLOWED TAOS_DEF_ERROR_CODE(0, 0x2669)
|
||||||
#define TSDB_CODE_PAR_INVALID_VARBINARY TAOS_DEF_ERROR_CODE(0, 0x266A)
|
#define TSDB_CODE_PAR_INVALID_VARBINARY TAOS_DEF_ERROR_CODE(0, 0x266A)
|
||||||
|
#define TSDB_CODE_PAR_INVALID_IP_RANGE TAOS_DEF_ERROR_CODE(0, 0x266B)
|
||||||
#define TSDB_CODE_PAR_INTERNAL_ERROR TAOS_DEF_ERROR_CODE(0, 0x26FF)
|
#define TSDB_CODE_PAR_INTERNAL_ERROR TAOS_DEF_ERROR_CODE(0, 0x26FF)
|
||||||
|
|
||||||
//planner
|
//planner
|
||||||
|
|
|
@ -81,6 +81,7 @@ int64_t tsMndLogRetention = 2000;
|
||||||
int8_t tsGrant = 1;
|
int8_t tsGrant = 1;
|
||||||
int32_t tsMndGrantMode = 0;
|
int32_t tsMndGrantMode = 0;
|
||||||
bool tsMndSkipGrant = false;
|
bool tsMndSkipGrant = false;
|
||||||
|
bool tsEnableWhiteList = false; // ip white list cfg
|
||||||
|
|
||||||
// dnode
|
// dnode
|
||||||
int64_t tsDndStart = 0;
|
int64_t tsDndStart = 0;
|
||||||
|
@ -659,6 +660,7 @@ static int32_t taosAddServerCfg(SConfig *pCfg) {
|
||||||
if (cfgAddInt64(pCfg, "minDiskFreeSize", tsMinDiskFreeSize, TFS_MIN_DISK_FREE_SIZE, 1024 * 1024 * 1024,
|
if (cfgAddInt64(pCfg, "minDiskFreeSize", tsMinDiskFreeSize, TFS_MIN_DISK_FREE_SIZE, 1024 * 1024 * 1024,
|
||||||
CFG_SCOPE_SERVER) != 0)
|
CFG_SCOPE_SERVER) != 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
if (cfgAddBool(pCfg, "enableWhiteList", tsEnableWhiteList, CFG_SCOPE_SERVER) != 0) return -1;
|
||||||
|
|
||||||
GRANT_CFG_ADD;
|
GRANT_CFG_ADD;
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -1047,6 +1049,7 @@ static int32_t taosSetServerCfg(SConfig *pCfg) {
|
||||||
tsMndLogRetention = cfgGetItem(pCfg, "mndLogRetention")->i64;
|
tsMndLogRetention = cfgGetItem(pCfg, "mndLogRetention")->i64;
|
||||||
tsMndSkipGrant = cfgGetItem(pCfg, "skipGrant")->bval;
|
tsMndSkipGrant = cfgGetItem(pCfg, "skipGrant")->bval;
|
||||||
tsMndGrantMode = cfgGetItem(pCfg, "grantMode")->i32;
|
tsMndGrantMode = cfgGetItem(pCfg, "grantMode")->i32;
|
||||||
|
tsEnableWhiteList = cfgGetItem(pCfg, "enableWhiteList")->bval;
|
||||||
|
|
||||||
tsStartUdfd = cfgGetItem(pCfg, "udf")->bval;
|
tsStartUdfd = cfgGetItem(pCfg, "udf")->bval;
|
||||||
tstrncpy(tsUdfdResFuncs, cfgGetItem(pCfg, "udfdResFuncs")->str, sizeof(tsUdfdResFuncs));
|
tstrncpy(tsUdfdResFuncs, cfgGetItem(pCfg, "udfdResFuncs")->str, sizeof(tsUdfdResFuncs));
|
||||||
|
|
|
@ -1060,6 +1060,7 @@ int32_t tSerializeSStatusReq(void *buf, int32_t bufLen, SStatusReq *pReq) {
|
||||||
if (tEncodeCStr(&encoder, pReq->clusterCfg.timezone) < 0) return -1;
|
if (tEncodeCStr(&encoder, pReq->clusterCfg.timezone) < 0) return -1;
|
||||||
if (tEncodeCStr(&encoder, pReq->clusterCfg.locale) < 0) return -1;
|
if (tEncodeCStr(&encoder, pReq->clusterCfg.locale) < 0) return -1;
|
||||||
if (tEncodeCStr(&encoder, pReq->clusterCfg.charset) < 0) return -1;
|
if (tEncodeCStr(&encoder, pReq->clusterCfg.charset) < 0) return -1;
|
||||||
|
if (tEncodeI8(&encoder, pReq->clusterCfg.enableWhiteList) < 0) return -1;
|
||||||
|
|
||||||
// vnode loads
|
// vnode loads
|
||||||
int32_t vlen = (int32_t)taosArrayGetSize(pReq->pVloads);
|
int32_t vlen = (int32_t)taosArrayGetSize(pReq->pVloads);
|
||||||
|
@ -1147,6 +1148,7 @@ int32_t tDeserializeSStatusReq(void *buf, int32_t bufLen, SStatusReq *pReq) {
|
||||||
if (tDecodeCStrTo(&decoder, pReq->clusterCfg.timezone) < 0) return -1;
|
if (tDecodeCStrTo(&decoder, pReq->clusterCfg.timezone) < 0) return -1;
|
||||||
if (tDecodeCStrTo(&decoder, pReq->clusterCfg.locale) < 0) return -1;
|
if (tDecodeCStrTo(&decoder, pReq->clusterCfg.locale) < 0) return -1;
|
||||||
if (tDecodeCStrTo(&decoder, pReq->clusterCfg.charset) < 0) return -1;
|
if (tDecodeCStrTo(&decoder, pReq->clusterCfg.charset) < 0) return -1;
|
||||||
|
if (tDecodeI8(&decoder, &pReq->clusterCfg.enableWhiteList) < 0) return -1;
|
||||||
|
|
||||||
// vnode loads
|
// vnode loads
|
||||||
int32_t vlen = 0;
|
int32_t vlen = 0;
|
||||||
|
@ -1380,6 +1382,11 @@ int32_t tSerializeSCreateUserReq(void *buf, int32_t bufLen, SCreateUserReq *pReq
|
||||||
if (tEncodeI8(&encoder, pReq->enable) < 0) return -1;
|
if (tEncodeI8(&encoder, pReq->enable) < 0) return -1;
|
||||||
if (tEncodeCStr(&encoder, pReq->user) < 0) return -1;
|
if (tEncodeCStr(&encoder, pReq->user) < 0) return -1;
|
||||||
if (tEncodeCStr(&encoder, pReq->pass) < 0) return -1;
|
if (tEncodeCStr(&encoder, pReq->pass) < 0) return -1;
|
||||||
|
if (tEncodeI32(&encoder, pReq->numIpRanges) < 0) return -1;
|
||||||
|
for (int32_t i = 0; i < pReq->numIpRanges; ++i) {
|
||||||
|
if (tEncodeU32(&encoder, pReq->pIpRanges[i].ip) < 0) return -1;
|
||||||
|
if (tEncodeU32(&encoder, pReq->pIpRanges[i].mask) < 0) return -1;
|
||||||
|
}
|
||||||
tEndEncode(&encoder);
|
tEndEncode(&encoder);
|
||||||
|
|
||||||
int32_t tlen = encoder.pos;
|
int32_t tlen = encoder.pos;
|
||||||
|
@ -1398,12 +1405,21 @@ int32_t tDeserializeSCreateUserReq(void *buf, int32_t bufLen, SCreateUserReq *pR
|
||||||
if (tDecodeI8(&decoder, &pReq->enable) < 0) return -1;
|
if (tDecodeI8(&decoder, &pReq->enable) < 0) return -1;
|
||||||
if (tDecodeCStrTo(&decoder, pReq->user) < 0) return -1;
|
if (tDecodeCStrTo(&decoder, pReq->user) < 0) return -1;
|
||||||
if (tDecodeCStrTo(&decoder, pReq->pass) < 0) return -1;
|
if (tDecodeCStrTo(&decoder, pReq->pass) < 0) return -1;
|
||||||
|
if (tDecodeI32(&decoder, &pReq->numIpRanges) < 0) return -1;
|
||||||
|
pReq->pIpRanges = taosMemoryMalloc(pReq->numIpRanges * sizeof(SIpV4Range));
|
||||||
|
if (pReq->pIpRanges == NULL) return -1;
|
||||||
|
for (int32_t i = 0; i < pReq->numIpRanges; ++i) {
|
||||||
|
if (tDecodeU32(&decoder, &(pReq->pIpRanges[i].ip)) < 0) return -1;
|
||||||
|
if (tDecodeU32(&decoder, &(pReq->pIpRanges[i].mask)) < 0) return -1;
|
||||||
|
}
|
||||||
tEndDecode(&decoder);
|
tEndDecode(&decoder);
|
||||||
|
|
||||||
tDecoderClear(&decoder);
|
tDecoderClear(&decoder);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void tFreeSCreateUserReq(SCreateUserReq *pReq) { taosMemoryFree(pReq->pIpRanges); }
|
||||||
|
|
||||||
int32_t tSerializeSAlterUserReq(void *buf, int32_t bufLen, SAlterUserReq *pReq) {
|
int32_t tSerializeSAlterUserReq(void *buf, int32_t bufLen, SAlterUserReq *pReq) {
|
||||||
SEncoder encoder = {0};
|
SEncoder encoder = {0};
|
||||||
tEncoderInit(&encoder, buf, bufLen);
|
tEncoderInit(&encoder, buf, bufLen);
|
||||||
|
@ -1422,6 +1438,11 @@ int32_t tSerializeSAlterUserReq(void *buf, int32_t bufLen, SAlterUserReq *pReq)
|
||||||
if (tEncodeCStr(&encoder, pReq->tabName) < 0) return -1;
|
if (tEncodeCStr(&encoder, pReq->tabName) < 0) return -1;
|
||||||
}
|
}
|
||||||
if (tEncodeBinary(&encoder, pReq->tagCond, pReq->tagCondLen) < 0) return -1;
|
if (tEncodeBinary(&encoder, pReq->tagCond, pReq->tagCondLen) < 0) return -1;
|
||||||
|
if (tEncodeI32(&encoder, pReq->numIpRanges) < 0) return -1;
|
||||||
|
for (int32_t i = 0; i < pReq->numIpRanges; ++i) {
|
||||||
|
if (tEncodeU32(&encoder, pReq->pIpRanges[i].ip) < 0) return -1;
|
||||||
|
if (tEncodeU32(&encoder, pReq->pIpRanges[i].mask) < 0) return -1;
|
||||||
|
}
|
||||||
tEndEncode(&encoder);
|
tEndEncode(&encoder);
|
||||||
|
|
||||||
int32_t tlen = encoder.pos;
|
int32_t tlen = encoder.pos;
|
||||||
|
@ -1451,13 +1472,23 @@ int32_t tDeserializeSAlterUserReq(void *buf, int32_t bufLen, SAlterUserReq *pReq
|
||||||
if (tDecodeBinaryAlloc(&decoder, (void **)&pReq->tagCond, &tagCondLen) < 0) return -1;
|
if (tDecodeBinaryAlloc(&decoder, (void **)&pReq->tagCond, &tagCondLen) < 0) return -1;
|
||||||
pReq->tagCondLen = tagCondLen;
|
pReq->tagCondLen = tagCondLen;
|
||||||
}
|
}
|
||||||
|
if (tDecodeI32(&decoder, &pReq->numIpRanges) < 0) return -1;
|
||||||
|
pReq->pIpRanges = taosMemoryMalloc(pReq->numIpRanges * sizeof(SIpV4Range));
|
||||||
|
if (pReq->pIpRanges == NULL) return -1;
|
||||||
|
for (int32_t i = 0; i < pReq->numIpRanges; ++i) {
|
||||||
|
if (tDecodeU32(&decoder, &(pReq->pIpRanges[i].ip)) < 0) return -1;
|
||||||
|
if (tDecodeU32(&decoder, &(pReq->pIpRanges[i].mask)) < 0) return -1;
|
||||||
|
}
|
||||||
tEndDecode(&decoder);
|
tEndDecode(&decoder);
|
||||||
|
|
||||||
tDecoderClear(&decoder);
|
tDecoderClear(&decoder);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void tFreeSAlterUserReq(SAlterUserReq *pReq) { taosMemoryFreeClear(pReq->tagCond); }
|
void tFreeSAlterUserReq(SAlterUserReq *pReq) {
|
||||||
|
taosMemoryFreeClear(pReq->tagCond);
|
||||||
|
taosMemoryFree(pReq->pIpRanges);
|
||||||
|
}
|
||||||
|
|
||||||
int32_t tSerializeSGetUserAuthReq(void *buf, int32_t bufLen, SGetUserAuthReq *pReq) {
|
int32_t tSerializeSGetUserAuthReq(void *buf, int32_t bufLen, SGetUserAuthReq *pReq) {
|
||||||
SEncoder encoder = {0};
|
SEncoder encoder = {0};
|
||||||
|
@ -4730,7 +4761,7 @@ int32_t tDeserializeSAlterVnodeReplicaReq(void *buf, int32_t bufLen, SAlterVnode
|
||||||
if (tDecodeSReplica(&decoder, pReplica) < 0) return -1;
|
if (tDecodeSReplica(&decoder, pReplica) < 0) return -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (!tDecodeIsEnd(&decoder)){
|
if (!tDecodeIsEnd(&decoder)) {
|
||||||
if (tDecodeI32(&decoder, &pReq->changeVersion) < 0) return -1;
|
if (tDecodeI32(&decoder, &pReq->changeVersion) < 0) return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5601,17 +5632,17 @@ void tFreeSSubQueryMsg(SSubQueryMsg *pReq) {
|
||||||
taosMemoryFreeClear(pReq->msg);
|
taosMemoryFreeClear(pReq->msg);
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t tSerializeSOperatorParam(SEncoder* pEncoder, SOperatorParam* pOpParam) {
|
int32_t tSerializeSOperatorParam(SEncoder *pEncoder, SOperatorParam *pOpParam) {
|
||||||
if (tEncodeI32(pEncoder, pOpParam->opType) < 0) return -1;
|
if (tEncodeI32(pEncoder, pOpParam->opType) < 0) return -1;
|
||||||
if (tEncodeI32(pEncoder, pOpParam->downstreamIdx) < 0) return -1;
|
if (tEncodeI32(pEncoder, pOpParam->downstreamIdx) < 0) return -1;
|
||||||
switch (pOpParam->opType) {
|
switch (pOpParam->opType) {
|
||||||
case QUERY_NODE_PHYSICAL_PLAN_TABLE_SCAN: {
|
case QUERY_NODE_PHYSICAL_PLAN_TABLE_SCAN: {
|
||||||
STableScanOperatorParam* pScan = (STableScanOperatorParam*)pOpParam->value;
|
STableScanOperatorParam *pScan = (STableScanOperatorParam *)pOpParam->value;
|
||||||
if (tEncodeI8(pEncoder, pScan->tableSeq) < 0) return -1;
|
if (tEncodeI8(pEncoder, pScan->tableSeq) < 0) return -1;
|
||||||
int32_t uidNum = taosArrayGetSize(pScan->pUidList);
|
int32_t uidNum = taosArrayGetSize(pScan->pUidList);
|
||||||
if (tEncodeI32(pEncoder, uidNum) < 0) return -1;
|
if (tEncodeI32(pEncoder, uidNum) < 0) return -1;
|
||||||
for (int32_t m = 0; m < uidNum; ++m) {
|
for (int32_t m = 0; m < uidNum; ++m) {
|
||||||
int64_t* pUid = taosArrayGet(pScan->pUidList, m);
|
int64_t *pUid = taosArrayGet(pScan->pUidList, m);
|
||||||
if (tEncodeI64(pEncoder, *pUid) < 0) return -1;
|
if (tEncodeI64(pEncoder, *pUid) < 0) return -1;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -5623,21 +5654,21 @@ int32_t tSerializeSOperatorParam(SEncoder* pEncoder, SOperatorParam* pOpParam) {
|
||||||
int32_t n = taosArrayGetSize(pOpParam->pChildren);
|
int32_t n = taosArrayGetSize(pOpParam->pChildren);
|
||||||
if (tEncodeI32(pEncoder, n) < 0) return -1;
|
if (tEncodeI32(pEncoder, n) < 0) return -1;
|
||||||
for (int32_t i = 0; i < n; ++i) {
|
for (int32_t i = 0; i < n; ++i) {
|
||||||
SOperatorParam* pChild = *(SOperatorParam**)taosArrayGet(pOpParam->pChildren, i);
|
SOperatorParam *pChild = *(SOperatorParam **)taosArrayGet(pOpParam->pChildren, i);
|
||||||
if (tSerializeSOperatorParam(pEncoder, pChild) < 0) return -1;
|
if (tSerializeSOperatorParam(pEncoder, pChild) < 0) return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t tDeserializeSOperatorParam(SDecoder *pDecoder, SOperatorParam* pOpParam) {
|
int32_t tDeserializeSOperatorParam(SDecoder *pDecoder, SOperatorParam *pOpParam) {
|
||||||
if (tDecodeI32(pDecoder, &pOpParam->opType) < 0) return -1;
|
if (tDecodeI32(pDecoder, &pOpParam->opType) < 0) return -1;
|
||||||
if (tDecodeI32(pDecoder, &pOpParam->downstreamIdx) < 0) return -1;
|
if (tDecodeI32(pDecoder, &pOpParam->downstreamIdx) < 0) return -1;
|
||||||
switch (pOpParam->opType) {
|
switch (pOpParam->opType) {
|
||||||
case QUERY_NODE_PHYSICAL_PLAN_TABLE_SCAN: {
|
case QUERY_NODE_PHYSICAL_PLAN_TABLE_SCAN: {
|
||||||
STableScanOperatorParam* pScan = taosMemoryMalloc(sizeof(STableScanOperatorParam));
|
STableScanOperatorParam *pScan = taosMemoryMalloc(sizeof(STableScanOperatorParam));
|
||||||
if (NULL == pScan) return -1;
|
if (NULL == pScan) return -1;
|
||||||
if (tDecodeI8(pDecoder, (int8_t*)&pScan->tableSeq) < 0) return -1;
|
if (tDecodeI8(pDecoder, (int8_t *)&pScan->tableSeq) < 0) return -1;
|
||||||
int32_t uidNum = 0;
|
int32_t uidNum = 0;
|
||||||
int64_t uid = 0;
|
int64_t uid = 0;
|
||||||
if (tDecodeI32(pDecoder, &uidNum) < 0) return -1;
|
if (tDecodeI32(pDecoder, &uidNum) < 0) return -1;
|
||||||
|
@ -5664,7 +5695,7 @@ int32_t tDeserializeSOperatorParam(SDecoder *pDecoder, SOperatorParam* pOpParam)
|
||||||
pOpParam->pChildren = taosArrayInit(childrenNum, POINTER_BYTES);
|
pOpParam->pChildren = taosArrayInit(childrenNum, POINTER_BYTES);
|
||||||
if (NULL == pOpParam->pChildren) return -1;
|
if (NULL == pOpParam->pChildren) return -1;
|
||||||
for (int32_t i = 0; i < childrenNum; ++i) {
|
for (int32_t i = 0; i < childrenNum; ++i) {
|
||||||
SOperatorParam* pChild = taosMemoryCalloc(1, sizeof(SOperatorParam));
|
SOperatorParam *pChild = taosMemoryCalloc(1, sizeof(SOperatorParam));
|
||||||
if (NULL == pChild) return -1;
|
if (NULL == pChild) return -1;
|
||||||
if (tDeserializeSOperatorParam(pDecoder, pChild) < 0) return -1;
|
if (tDeserializeSOperatorParam(pDecoder, pChild) < 0) return -1;
|
||||||
taosArrayPush(pOpParam->pChildren, &pChild);
|
taosArrayPush(pOpParam->pChildren, &pChild);
|
||||||
|
@ -5676,7 +5707,6 @@ int32_t tDeserializeSOperatorParam(SDecoder *pDecoder, SOperatorParam* pOpParam)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int32_t tSerializeSResFetchReq(void *buf, int32_t bufLen, SResFetchReq *pReq) {
|
int32_t tSerializeSResFetchReq(void *buf, int32_t bufLen, SResFetchReq *pReq) {
|
||||||
int32_t headLen = sizeof(SMsgHead);
|
int32_t headLen = sizeof(SMsgHead);
|
||||||
if (buf != NULL) {
|
if (buf != NULL) {
|
||||||
|
@ -5925,7 +5955,7 @@ int32_t tDeserializeSTaskNotifyReq(void *buf, int32_t bufLen, STaskNotifyReq *pR
|
||||||
if (tDecodeU64(&decoder, &pReq->taskId) < 0) return -1;
|
if (tDecodeU64(&decoder, &pReq->taskId) < 0) return -1;
|
||||||
if (tDecodeI64(&decoder, &pReq->refId) < 0) return -1;
|
if (tDecodeI64(&decoder, &pReq->refId) < 0) return -1;
|
||||||
if (tDecodeI32(&decoder, &pReq->execId) < 0) return -1;
|
if (tDecodeI32(&decoder, &pReq->execId) < 0) return -1;
|
||||||
if (tDecodeI32(&decoder, (int32_t*)&pReq->type) < 0) return -1;
|
if (tDecodeI32(&decoder, (int32_t *)&pReq->type) < 0) return -1;
|
||||||
|
|
||||||
tEndDecode(&decoder);
|
tEndDecode(&decoder);
|
||||||
|
|
||||||
|
@ -5933,7 +5963,6 @@ int32_t tDeserializeSTaskNotifyReq(void *buf, int32_t bufLen, STaskNotifyReq *pR
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int32_t tSerializeSQueryTableRsp(void *buf, int32_t bufLen, SQueryTableRsp *pRsp) {
|
int32_t tSerializeSQueryTableRsp(void *buf, int32_t bufLen, SQueryTableRsp *pRsp) {
|
||||||
SEncoder encoder = {0};
|
SEncoder encoder = {0};
|
||||||
tEncoderInit(&encoder, buf, bufLen);
|
tEncoderInit(&encoder, buf, bufLen);
|
||||||
|
|
|
@ -91,6 +91,7 @@ void dmSendStatusReq(SDnodeMgmt *pMgmt) {
|
||||||
req.clusterCfg.statusInterval = tsStatusInterval;
|
req.clusterCfg.statusInterval = tsStatusInterval;
|
||||||
req.clusterCfg.checkTime = 0;
|
req.clusterCfg.checkTime = 0;
|
||||||
req.clusterCfg.ttlChangeOnWrite = tsTtlChangeOnWrite;
|
req.clusterCfg.ttlChangeOnWrite = tsTtlChangeOnWrite;
|
||||||
|
req.clusterCfg.enableWhiteList = tsEnableWhiteList ? 1 : 0;
|
||||||
char timestr[32] = "1970-01-01 00:00:00.00";
|
char timestr[32] = "1970-01-01 00:00:00.00";
|
||||||
(void)taosParseTime(timestr, &req.clusterCfg.checkTime, (int32_t)strlen(timestr), TSDB_TIME_PRECISION_MILLI, 0);
|
(void)taosParseTime(timestr, &req.clusterCfg.checkTime, (int32_t)strlen(timestr), TSDB_TIME_PRECISION_MILLI, 0);
|
||||||
memcpy(req.clusterCfg.timezone, tsTimezoneStr, TD_TIMEZONE_LEN);
|
memcpy(req.clusterCfg.timezone, tsTimezoneStr, TD_TIMEZONE_LEN);
|
||||||
|
|
|
@ -136,6 +136,7 @@ typedef enum {
|
||||||
DND_REASON_LOCALE_NOT_MATCH,
|
DND_REASON_LOCALE_NOT_MATCH,
|
||||||
DND_REASON_CHARSET_NOT_MATCH,
|
DND_REASON_CHARSET_NOT_MATCH,
|
||||||
DND_REASON_TTL_CHANGE_ON_WRITE_NOT_MATCH,
|
DND_REASON_TTL_CHANGE_ON_WRITE_NOT_MATCH,
|
||||||
|
DND_REASON_ENABLE_WHITELIST_NOT_MATCH,
|
||||||
DND_REASON_OTHERS
|
DND_REASON_OTHERS
|
||||||
} EDndReason;
|
} EDndReason;
|
||||||
|
|
||||||
|
|
|
@ -15,6 +15,8 @@
|
||||||
|
|
||||||
#define _DEFAULT_SOURCE
|
#define _DEFAULT_SOURCE
|
||||||
#include "mndDnode.h"
|
#include "mndDnode.h"
|
||||||
|
#include "audit.h"
|
||||||
|
#include "mndCluster.h"
|
||||||
#include "mndDb.h"
|
#include "mndDb.h"
|
||||||
#include "mndMnode.h"
|
#include "mndMnode.h"
|
||||||
#include "mndPrivilege.h"
|
#include "mndPrivilege.h"
|
||||||
|
@ -25,8 +27,6 @@
|
||||||
#include "mndUser.h"
|
#include "mndUser.h"
|
||||||
#include "mndVgroup.h"
|
#include "mndVgroup.h"
|
||||||
#include "tmisce.h"
|
#include "tmisce.h"
|
||||||
#include "mndCluster.h"
|
|
||||||
#include "audit.h"
|
|
||||||
|
|
||||||
#define TSDB_DNODE_VER_NUMBER 2
|
#define TSDB_DNODE_VER_NUMBER 2
|
||||||
#define TSDB_DNODE_RESERVE_SIZE 64
|
#define TSDB_DNODE_RESERVE_SIZE 64
|
||||||
|
@ -421,6 +421,11 @@ static int32_t mndCheckClusterCfgPara(SMnode *pMnode, SDnodeObj *pDnode, const S
|
||||||
tsTtlChangeOnWrite);
|
tsTtlChangeOnWrite);
|
||||||
return DND_REASON_TTL_CHANGE_ON_WRITE_NOT_MATCH;
|
return DND_REASON_TTL_CHANGE_ON_WRITE_NOT_MATCH;
|
||||||
}
|
}
|
||||||
|
int8_t enable = tsEnableWhiteList ? 1 : 0;
|
||||||
|
if (pCfg->enableWhiteList != enable) {
|
||||||
|
mError("dnode:%d, enable :%d inconsistent with cluster:%d", pDnode->id, pCfg->enableWhiteList, enable);
|
||||||
|
return DND_REASON_ENABLE_WHITELIST_NOT_MATCH;
|
||||||
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -926,14 +931,10 @@ _OVER:
|
||||||
|
|
||||||
extern int32_t mndProcessRestoreDnodeReqImpl(SRpcMsg *pReq);
|
extern int32_t mndProcessRestoreDnodeReqImpl(SRpcMsg *pReq);
|
||||||
|
|
||||||
int32_t mndProcessRestoreDnodeReq(SRpcMsg *pReq){
|
int32_t mndProcessRestoreDnodeReq(SRpcMsg *pReq) { return mndProcessRestoreDnodeReqImpl(pReq); }
|
||||||
return mndProcessRestoreDnodeReqImpl(pReq);
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifndef TD_ENTERPRISE
|
#ifndef TD_ENTERPRISE
|
||||||
int32_t mndProcessRestoreDnodeReqImpl(SRpcMsg *pReq){
|
int32_t mndProcessRestoreDnodeReqImpl(SRpcMsg *pReq) { return 0; }
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static int32_t mndDropDnode(SMnode *pMnode, SRpcMsg *pReq, SDnodeObj *pDnode, SMnodeObj *pMObj, SQnodeObj *pQObj,
|
static int32_t mndDropDnode(SMnode *pMnode, SRpcMsg *pReq, SDnodeObj *pDnode, SMnodeObj *pMObj, SQnodeObj *pQObj,
|
||||||
|
@ -1004,15 +1005,14 @@ static int32_t mndProcessDropDnodeReq(SRpcMsg *pReq) {
|
||||||
goto _OVER;
|
goto _OVER;
|
||||||
}
|
}
|
||||||
|
|
||||||
mInfo("dnode:%d, start to drop, ep:%s:%d, force:%s, unsafe:%s",
|
mInfo("dnode:%d, start to drop, ep:%s:%d, force:%s, unsafe:%s", dropReq.dnodeId, dropReq.fqdn, dropReq.port,
|
||||||
dropReq.dnodeId, dropReq.fqdn, dropReq.port, dropReq.force?"true":"false", dropReq.unsafe?"true":"false");
|
dropReq.force ? "true" : "false", dropReq.unsafe ? "true" : "false");
|
||||||
if (mndCheckOperPrivilege(pMnode, pReq->info.conn.user, MND_OPER_DROP_MNODE) != 0) {
|
if (mndCheckOperPrivilege(pMnode, pReq->info.conn.user, MND_OPER_DROP_MNODE) != 0) {
|
||||||
goto _OVER;
|
goto _OVER;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool force = dropReq.force;
|
bool force = dropReq.force;
|
||||||
if(dropReq.unsafe)
|
if (dropReq.unsafe) {
|
||||||
{
|
|
||||||
force = true;
|
force = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1043,19 +1043,19 @@ static int32_t mndProcessDropDnodeReq(SRpcMsg *pReq) {
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t numOfVnodes = mndGetVnodesNum(pMnode, pDnode->id);
|
int32_t numOfVnodes = mndGetVnodesNum(pMnode, pDnode->id);
|
||||||
bool isonline = mndIsDnodeOnline(pDnode, taosGetTimestampMs());
|
bool isonline = mndIsDnodeOnline(pDnode, taosGetTimestampMs());
|
||||||
|
|
||||||
if (isonline && force) {
|
if (isonline && force) {
|
||||||
terrno = TSDB_CODE_DNODE_ONLY_USE_WHEN_OFFLINE;
|
terrno = TSDB_CODE_DNODE_ONLY_USE_WHEN_OFFLINE;
|
||||||
mError("dnode:%d, failed to drop since %s, vnodes:%d mnode:%d qnode:%d snode:%d", pDnode->id, terrstr(),
|
mError("dnode:%d, failed to drop since %s, vnodes:%d mnode:%d qnode:%d snode:%d", pDnode->id, terrstr(),
|
||||||
numOfVnodes, pMObj != NULL, pQObj != NULL, pSObj != NULL);
|
numOfVnodes, pMObj != NULL, pQObj != NULL, pSObj != NULL);
|
||||||
goto _OVER;
|
goto _OVER;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!isonline && !force) {
|
if (!isonline && !force) {
|
||||||
terrno = TSDB_CODE_DNODE_OFFLINE;
|
terrno = TSDB_CODE_DNODE_OFFLINE;
|
||||||
mError("dnode:%d, failed to drop since %s, vnodes:%d mnode:%d qnode:%d snode:%d", pDnode->id, terrstr(),
|
mError("dnode:%d, failed to drop since %s, vnodes:%d mnode:%d qnode:%d snode:%d", pDnode->id, terrstr(),
|
||||||
numOfVnodes, pMObj != NULL, pQObj != NULL, pSObj != NULL);
|
numOfVnodes, pMObj != NULL, pQObj != NULL, pSObj != NULL);
|
||||||
goto _OVER;
|
goto _OVER;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1065,8 +1065,8 @@ static int32_t mndProcessDropDnodeReq(SRpcMsg *pReq) {
|
||||||
char obj1[30] = {0};
|
char obj1[30] = {0};
|
||||||
sprintf(obj1, "%d", dropReq.dnodeId);
|
sprintf(obj1, "%d", dropReq.dnodeId);
|
||||||
|
|
||||||
//char obj2[150] = {0};
|
// char obj2[150] = {0};
|
||||||
//sprintf(obj2, "%s:%d", dropReq.fqdn, dropReq.port);
|
// sprintf(obj2, "%s:%d", dropReq.fqdn, dropReq.port);
|
||||||
|
|
||||||
char detail[100] = {0};
|
char detail[100] = {0};
|
||||||
sprintf(detail, "force:%d, unsafe:%d", dropReq.force, dropReq.unsafe);
|
sprintf(detail, "force:%d, unsafe:%d", dropReq.force, dropReq.unsafe);
|
||||||
|
@ -1164,8 +1164,8 @@ static int32_t mndProcessConfigDnodeReq(SRpcMsg *pReq) {
|
||||||
if (code < 0) return code;
|
if (code < 0) return code;
|
||||||
|
|
||||||
if (flag < 0) {
|
if (flag < 0) {
|
||||||
mError("dnode:%d, failed to config ttlBatchDropNum since value:%d. Valid range: [0, %d]", cfgReq.dnodeId,
|
mError("dnode:%d, failed to config ttlBatchDropNum since value:%d. Valid range: [0, %d]", cfgReq.dnodeId, flag,
|
||||||
flag, INT32_MAX);
|
INT32_MAX);
|
||||||
terrno = TSDB_CODE_INVALID_CFG;
|
terrno = TSDB_CODE_INVALID_CFG;
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
|
@ -669,7 +669,7 @@ _OVER:
|
||||||
|
|
||||||
mndReleaseUser(pMnode, pUser);
|
mndReleaseUser(pMnode, pUser);
|
||||||
mndReleaseUser(pMnode, pOperUser);
|
mndReleaseUser(pMnode, pOperUser);
|
||||||
|
tFreeSCreateUserReq(&createReq);
|
||||||
return code;
|
return code;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -924,8 +924,17 @@ void nodesDestroyNode(SNode* pNode) {
|
||||||
nodesDestroyNode((SNode*)pStmt->pVal);
|
nodesDestroyNode((SNode*)pStmt->pVal);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case QUERY_NODE_CREATE_USER_STMT: // no pointer field
|
case QUERY_NODE_CREATE_USER_STMT: {
|
||||||
case QUERY_NODE_ALTER_USER_STMT: // no pointer field
|
SCreateUserStmt* pStmt = (SCreateUserStmt*)pNode;
|
||||||
|
taosMemoryFree(pStmt->pIpRanges);
|
||||||
|
nodesDestroyList(pStmt->pNodeListIpRanges);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case QUERY_NODE_ALTER_USER_STMT: {
|
||||||
|
SAlterUserStmt* pStmt = (SAlterUserStmt*)pNode;
|
||||||
|
taosMemoryFree(pStmt->pIpRanges);
|
||||||
|
nodesDestroyList(pStmt->pNodeListIpRanges);
|
||||||
|
}
|
||||||
case QUERY_NODE_DROP_USER_STMT: // no pointer field
|
case QUERY_NODE_DROP_USER_STMT: // no pointer field
|
||||||
case QUERY_NODE_USE_DATABASE_STMT: // no pointer field
|
case QUERY_NODE_USE_DATABASE_STMT: // no pointer field
|
||||||
case QUERY_NODE_CREATE_DNODE_STMT: // no pointer field
|
case QUERY_NODE_CREATE_DNODE_STMT: // no pointer field
|
||||||
|
|
|
@ -192,7 +192,8 @@ SNode* createShowDnodeVariablesStmt(SAstCreateContext* pCxt, SNode* pDnodeId, SN
|
||||||
SNode* createShowVnodesStmt(SAstCreateContext* pCxt, SNode* pDnodeId, SNode* pDnodeEndpoint);
|
SNode* createShowVnodesStmt(SAstCreateContext* pCxt, SNode* pDnodeId, SNode* pDnodeEndpoint);
|
||||||
SNode* createShowTableTagsStmt(SAstCreateContext* pCxt, SNode* pTbName, SNode* pDbName, SNodeList* pTags);
|
SNode* createShowTableTagsStmt(SAstCreateContext* pCxt, SNode* pTbName, SNode* pDbName, SNodeList* pTags);
|
||||||
SNode* createCreateUserStmt(SAstCreateContext* pCxt, SToken* pUserName, const SToken* pPassword, int8_t sysinfo);
|
SNode* createCreateUserStmt(SAstCreateContext* pCxt, SToken* pUserName, const SToken* pPassword, int8_t sysinfo);
|
||||||
SNode* createAlterUserStmt(SAstCreateContext* pCxt, SToken* pUserName, int8_t alterType, const SToken* pVal);
|
SNode* addCreateUserStmtWhiteList(SAstCreateContext* pCxt, SNode* pStmt, SNodeList* pIpRangesNodeList);
|
||||||
|
SNode* createAlterUserStmt(SAstCreateContext* pCxt, SToken* pUserName, int8_t alterType, void* pAlterInfo);
|
||||||
SNode* createDropUserStmt(SAstCreateContext* pCxt, SToken* pUserName);
|
SNode* createDropUserStmt(SAstCreateContext* pCxt, SToken* pUserName);
|
||||||
SNode* createCreateDnodeStmt(SAstCreateContext* pCxt, const SToken* pFqdn, const SToken* pPort);
|
SNode* createCreateDnodeStmt(SAstCreateContext* pCxt, const SToken* pFqdn, const SToken* pPort);
|
||||||
SNode* createDropDnodeStmt(SAstCreateContext* pCxt, const SToken* pDnode, bool force, bool unsafe);
|
SNode* createDropDnodeStmt(SAstCreateContext* pCxt, const SToken* pDnode, bool force, bool unsafe);
|
||||||
|
|
|
@ -81,11 +81,31 @@ alter_account_option ::= USERS literal.
|
||||||
alter_account_option ::= CONNS literal. { }
|
alter_account_option ::= CONNS literal. { }
|
||||||
alter_account_option ::= STATE literal. { }
|
alter_account_option ::= STATE literal. { }
|
||||||
|
|
||||||
|
%type ip_range_list { SNodeList* }
|
||||||
|
%destructor ip_range_list { nodesDestroyList($$); }
|
||||||
|
ip_range_list(A) ::= NK_STRING(B). { A = createNodeList(pCxt, createValueNode(pCxt, TSDB_DATA_TYPE_BINARY, &B)); }
|
||||||
|
ip_range_list(A) ::= ip_range_list(B) NK_COMMA NK_STRING(C). { A = addNodeToList(pCxt, B, createValueNode(pCxt, TSDB_DATA_TYPE_BINARY, &C)); }
|
||||||
|
|
||||||
|
%type white_list { SNodeList* }
|
||||||
|
%destructor white_list { nodesDestroyList($$); }
|
||||||
|
white_list(A) ::= HOST ip_range_list(B). { A = B; }
|
||||||
|
|
||||||
|
%type white_list_opt { SNodeList* }
|
||||||
|
%destructor white_list_opt { nodesDestroyList($$); }
|
||||||
|
white_list_opt(A) ::= . { A = NULL; }
|
||||||
|
white_list_opt(A) ::= white_list(B). { A = B; }
|
||||||
|
|
||||||
/************************************************ create/alter/drop user **********************************************/
|
/************************************************ create/alter/drop user **********************************************/
|
||||||
cmd ::= CREATE USER user_name(A) PASS NK_STRING(B) sysinfo_opt(C). { pCxt->pRootNode = createCreateUserStmt(pCxt, &A, &B, C); }
|
cmd ::= CREATE USER user_name(A) PASS NK_STRING(B) sysinfo_opt(C)
|
||||||
|
white_list_opt(D). {
|
||||||
|
pCxt->pRootNode = createCreateUserStmt(pCxt, &A, &B, C);
|
||||||
|
pCxt->pRootNode = addCreateUserStmtWhiteList(pCxt, pCxt->pRootNode, D);
|
||||||
|
}
|
||||||
cmd ::= ALTER USER user_name(A) PASS NK_STRING(B). { pCxt->pRootNode = createAlterUserStmt(pCxt, &A, TSDB_ALTER_USER_PASSWD, &B); }
|
cmd ::= ALTER USER user_name(A) PASS NK_STRING(B). { pCxt->pRootNode = createAlterUserStmt(pCxt, &A, TSDB_ALTER_USER_PASSWD, &B); }
|
||||||
cmd ::= ALTER USER user_name(A) ENABLE NK_INTEGER(B). { pCxt->pRootNode = createAlterUserStmt(pCxt, &A, TSDB_ALTER_USER_ENABLE, &B); }
|
cmd ::= ALTER USER user_name(A) ENABLE NK_INTEGER(B). { pCxt->pRootNode = createAlterUserStmt(pCxt, &A, TSDB_ALTER_USER_ENABLE, &B); }
|
||||||
cmd ::= ALTER USER user_name(A) SYSINFO NK_INTEGER(B). { pCxt->pRootNode = createAlterUserStmt(pCxt, &A, TSDB_ALTER_USER_SYSINFO, &B); }
|
cmd ::= ALTER USER user_name(A) SYSINFO NK_INTEGER(B). { pCxt->pRootNode = createAlterUserStmt(pCxt, &A, TSDB_ALTER_USER_SYSINFO, &B); }
|
||||||
|
cmd ::= ALTER USER user_name(A) ADD white_list(B). { pCxt->pRootNode = createAlterUserStmt(pCxt, &A, TSDB_ALTER_USER_ADD_WHITE_LIST, B); }
|
||||||
|
cmd ::= ALTER USER user_name(A) DROP white_list(B). { pCxt->pRootNode = createAlterUserStmt(pCxt, &A, TSDB_ALTER_USER_DROP_WHITE_LIST, B); }
|
||||||
cmd ::= DROP USER user_name(A). { pCxt->pRootNode = createDropUserStmt(pCxt, &A); }
|
cmd ::= DROP USER user_name(A). { pCxt->pRootNode = createDropUserStmt(pCxt, &A); }
|
||||||
|
|
||||||
%type sysinfo_opt { int8_t }
|
%type sysinfo_opt { int8_t }
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
* You should have received a copy of the GNU Affero General Public License
|
* 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/>.
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
#include <uv.h>
|
||||||
#include <regex.h>
|
#include <regex.h>
|
||||||
|
|
||||||
#include "parAst.h"
|
#include "parAst.h"
|
||||||
|
@ -1653,6 +1653,86 @@ SNode* createShowTableTagsStmt(SAstCreateContext* pCxt, SNode* pTbName, SNode* p
|
||||||
return (SNode*)pStmt;
|
return (SNode*)pStmt;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int32_t getIpV4RangeFromWhitelistItem(char* ipRange, SIpV4Range* pIpRange) {
|
||||||
|
int32_t code = TSDB_CODE_SUCCESS;
|
||||||
|
char* ipCopy = taosStrdup(ipRange);
|
||||||
|
char* slash = strchr(ipCopy, '/');
|
||||||
|
if (slash) {
|
||||||
|
*slash = '\0';
|
||||||
|
struct in_addr addr;
|
||||||
|
if (uv_inet_pton(AF_INET, ipCopy, &addr) == 0) {
|
||||||
|
int prefix = atoi(slash + 1);
|
||||||
|
if (prefix < 0 || prefix > 32) {
|
||||||
|
code = TSDB_CODE_PAR_INVALID_IP_RANGE;
|
||||||
|
} else {
|
||||||
|
pIpRange->ip = addr.s_addr;
|
||||||
|
uint32_t mask = (1 << (32 - prefix)) - 1;
|
||||||
|
mask = htonl(~mask);
|
||||||
|
pIpRange->mask = mask;
|
||||||
|
code = TSDB_CODE_SUCCESS;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
code = TSDB_CODE_PAR_INVALID_IP_RANGE;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
struct in_addr addr;
|
||||||
|
if (uv_inet_pton(AF_INET, ipCopy, &addr) == 0) {
|
||||||
|
pIpRange->ip = addr.s_addr;
|
||||||
|
pIpRange->mask = 0xFFFFFFFF;
|
||||||
|
code = TSDB_CODE_SUCCESS;
|
||||||
|
} else {
|
||||||
|
code = TSDB_CODE_PAR_INVALID_IP_RANGE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
taosMemoryFreeClear(ipCopy);
|
||||||
|
return code;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int32_t fillIpRangesFromWhiteList(SAstCreateContext* pCxt, SNodeList* pIpRangesNodeList, SIpV4Range* pIpRanges) {
|
||||||
|
int32_t i = 0;
|
||||||
|
int32_t code = 0;
|
||||||
|
|
||||||
|
SNode* pNode = NULL;
|
||||||
|
FOREACH(pNode, pIpRangesNodeList) {
|
||||||
|
if (QUERY_NODE_VALUE != nodeType(pNode)) {
|
||||||
|
pCxt->errCode = generateSyntaxErrMsg(&pCxt->msgBuf, TSDB_CODE_PAR_INVALID_IP_RANGE);
|
||||||
|
return TSDB_CODE_PAR_INVALID_IP_RANGE;
|
||||||
|
}
|
||||||
|
SValueNode* pValNode = (SValueNode*)(pNode);
|
||||||
|
code = getIpV4RangeFromWhitelistItem(pValNode->literal, pIpRanges + i);
|
||||||
|
++i;
|
||||||
|
if (code != TSDB_CODE_SUCCESS) {
|
||||||
|
pCxt->errCode = generateSyntaxErrMsgExt(&pCxt->msgBuf, code, "Invalid IP range %s", pValNode->literal);
|
||||||
|
return code;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return TSDB_CODE_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
SNode* addCreateUserStmtWhiteList(SAstCreateContext* pCxt, SNode* pCreateUserStmt, SNodeList* pIpRangesNodeList) {
|
||||||
|
if (NULL == pCreateUserStmt || NULL == pIpRangesNodeList) {
|
||||||
|
return pCreateUserStmt;
|
||||||
|
}
|
||||||
|
|
||||||
|
((SCreateUserStmt*)pCreateUserStmt)->pNodeListIpRanges = pIpRangesNodeList;
|
||||||
|
SCreateUserStmt* pCreateUser = (SCreateUserStmt*)pCreateUserStmt;
|
||||||
|
pCreateUser->numIpRanges = LIST_LENGTH(pIpRangesNodeList);
|
||||||
|
pCreateUser->pIpRanges = taosMemoryMalloc(pCreateUser->numIpRanges * sizeof(SIpV4Range));
|
||||||
|
if (NULL == pCreateUser->pIpRanges) {
|
||||||
|
pCxt->errCode = TSDB_CODE_OUT_OF_MEMORY;
|
||||||
|
nodesDestroyNode(pCreateUserStmt);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
int32_t code = fillIpRangesFromWhiteList(pCxt, pIpRangesNodeList, pCreateUser->pIpRanges);
|
||||||
|
if (TSDB_CODE_SUCCESS != code) {
|
||||||
|
nodesDestroyNode(pCreateUserStmt);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
return pCreateUserStmt;
|
||||||
|
}
|
||||||
|
|
||||||
SNode* createCreateUserStmt(SAstCreateContext* pCxt, SToken* pUserName, const SToken* pPassword, int8_t sysinfo) {
|
SNode* createCreateUserStmt(SAstCreateContext* pCxt, SToken* pUserName, const SToken* pPassword, int8_t sysinfo) {
|
||||||
CHECK_PARSER_STATUS(pCxt);
|
CHECK_PARSER_STATUS(pCxt);
|
||||||
char password[TSDB_USET_PASSWORD_LEN + 3] = {0};
|
char password[TSDB_USET_PASSWORD_LEN + 3] = {0};
|
||||||
|
@ -1667,7 +1747,7 @@ SNode* createCreateUserStmt(SAstCreateContext* pCxt, SToken* pUserName, const ST
|
||||||
return (SNode*)pStmt;
|
return (SNode*)pStmt;
|
||||||
}
|
}
|
||||||
|
|
||||||
SNode* createAlterUserStmt(SAstCreateContext* pCxt, SToken* pUserName, int8_t alterType, const SToken* pVal) {
|
SNode* createAlterUserStmt(SAstCreateContext* pCxt, SToken* pUserName, int8_t alterType, void* pAlterInfo) {
|
||||||
CHECK_PARSER_STATUS(pCxt);
|
CHECK_PARSER_STATUS(pCxt);
|
||||||
if (!checkUserName(pCxt, pUserName)) {
|
if (!checkUserName(pCxt, pUserName)) {
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -1679,6 +1759,7 @@ SNode* createAlterUserStmt(SAstCreateContext* pCxt, SToken* pUserName, int8_t al
|
||||||
switch (alterType) {
|
switch (alterType) {
|
||||||
case TSDB_ALTER_USER_PASSWD: {
|
case TSDB_ALTER_USER_PASSWD: {
|
||||||
char password[TSDB_USET_PASSWORD_LEN] = {0};
|
char password[TSDB_USET_PASSWORD_LEN] = {0};
|
||||||
|
SToken* pVal = pAlterInfo;
|
||||||
if (!checkPassword(pCxt, pVal, password)) {
|
if (!checkPassword(pCxt, pVal, password)) {
|
||||||
nodesDestroyNode((SNode*)pStmt);
|
nodesDestroyNode((SNode*)pStmt);
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -1686,12 +1767,35 @@ SNode* createAlterUserStmt(SAstCreateContext* pCxt, SToken* pUserName, int8_t al
|
||||||
strcpy(pStmt->password, password);
|
strcpy(pStmt->password, password);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case TSDB_ALTER_USER_ENABLE:
|
case TSDB_ALTER_USER_ENABLE: {
|
||||||
|
SToken* pVal = pAlterInfo;
|
||||||
pStmt->enable = taosStr2Int8(pVal->z, NULL, 10);
|
pStmt->enable = taosStr2Int8(pVal->z, NULL, 10);
|
||||||
break;
|
break;
|
||||||
case TSDB_ALTER_USER_SYSINFO:
|
}
|
||||||
|
case TSDB_ALTER_USER_SYSINFO: {
|
||||||
|
SToken* pVal = pAlterInfo;
|
||||||
pStmt->sysinfo = taosStr2Int8(pVal->z, NULL, 10);
|
pStmt->sysinfo = taosStr2Int8(pVal->z, NULL, 10);
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
|
case TSDB_ALTER_USER_ADD_WHITE_LIST:
|
||||||
|
case TSDB_ALTER_USER_DROP_WHITE_LIST: {
|
||||||
|
SNodeList* pIpRangesNodeList = pAlterInfo;
|
||||||
|
pStmt->pNodeListIpRanges = pIpRangesNodeList;
|
||||||
|
pStmt->numIpRanges = LIST_LENGTH(pIpRangesNodeList);
|
||||||
|
pStmt->pIpRanges = taosMemoryMalloc(pStmt->numIpRanges * sizeof(SIpV4Range));
|
||||||
|
if (NULL == pStmt->pIpRanges) {
|
||||||
|
pCxt->errCode = TSDB_CODE_OUT_OF_MEMORY;
|
||||||
|
nodesDestroyNode((SNode*)pStmt);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
int32_t code = fillIpRangesFromWhiteList(pCxt, pIpRangesNodeList, pStmt->pIpRanges);
|
||||||
|
if (TSDB_CODE_SUCCESS != code) {
|
||||||
|
nodesDestroyNode((SNode*)pStmt);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -109,6 +109,7 @@ static SKeyword keywordTable[] = {
|
||||||
{"GRANTS", TK_GRANTS},
|
{"GRANTS", TK_GRANTS},
|
||||||
{"GROUP", TK_GROUP},
|
{"GROUP", TK_GROUP},
|
||||||
{"HAVING", TK_HAVING},
|
{"HAVING", TK_HAVING},
|
||||||
|
{"HOST", TK_HOST},
|
||||||
{"IF", TK_IF},
|
{"IF", TK_IF},
|
||||||
{"IGNORE", TK_IGNORE},
|
{"IGNORE", TK_IGNORE},
|
||||||
{"IMPORT", TK_IMPORT},
|
{"IMPORT", TK_IMPORT},
|
||||||
|
|
|
@ -5745,7 +5745,14 @@ static int32_t translateCreateUser(STranslateContext* pCxt, SCreateUserStmt* pSt
|
||||||
createReq.enable = 1;
|
createReq.enable = 1;
|
||||||
strcpy(createReq.pass, pStmt->password);
|
strcpy(createReq.pass, pStmt->password);
|
||||||
|
|
||||||
return buildCmdMsg(pCxt, TDMT_MND_CREATE_USER, (FSerializeFunc)tSerializeSCreateUserReq, &createReq);
|
createReq.numIpRanges = pStmt->numIpRanges;
|
||||||
|
if (pStmt->numIpRanges > 0) {
|
||||||
|
createReq.pIpRanges = taosMemoryMalloc(createReq.numIpRanges * sizeof(SIpV4Range));
|
||||||
|
memcpy(createReq.pIpRanges, pStmt->pIpRanges, sizeof(SIpV4Range) * createReq.numIpRanges);
|
||||||
|
}
|
||||||
|
int32_t code = buildCmdMsg(pCxt, TDMT_MND_CREATE_USER, (FSerializeFunc)tSerializeSCreateUserReq, &createReq);
|
||||||
|
tFreeSCreateUserReq(&createReq);
|
||||||
|
return code;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32_t translateAlterUser(STranslateContext* pCxt, SAlterUserStmt* pStmt) {
|
static int32_t translateAlterUser(STranslateContext* pCxt, SAlterUserStmt* pStmt) {
|
||||||
|
@ -5760,7 +5767,14 @@ static int32_t translateAlterUser(STranslateContext* pCxt, SAlterUserStmt* pStmt
|
||||||
snprintf(alterReq.objname, sizeof(alterReq.objname), "%s", pCxt->pParseCxt->db);
|
snprintf(alterReq.objname, sizeof(alterReq.objname), "%s", pCxt->pParseCxt->db);
|
||||||
}
|
}
|
||||||
|
|
||||||
return buildCmdMsg(pCxt, TDMT_MND_ALTER_USER, (FSerializeFunc)tSerializeSAlterUserReq, &alterReq);
|
alterReq.numIpRanges = pStmt->numIpRanges;
|
||||||
|
if (pStmt->numIpRanges > 0) {
|
||||||
|
alterReq.pIpRanges = taosMemoryMalloc(alterReq.numIpRanges * sizeof(SIpV4Range));
|
||||||
|
memcpy(alterReq.pIpRanges, pStmt->pIpRanges, sizeof(SIpV4Range) * alterReq.numIpRanges);
|
||||||
|
}
|
||||||
|
int32_t code = buildCmdMsg(pCxt, TDMT_MND_ALTER_USER, (FSerializeFunc)tSerializeSAlterUserReq, &alterReq);
|
||||||
|
tFreeSAlterUserReq(&alterReq);
|
||||||
|
return code;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32_t translateDropUser(STranslateContext* pCxt, SDropUserStmt* pStmt) {
|
static int32_t translateDropUser(STranslateContext* pCxt, SDropUserStmt* pStmt) {
|
||||||
|
|
|
@ -182,6 +182,8 @@ static char* getSyntaxErrFormat(int32_t errCode) {
|
||||||
return "No valid function in window query";
|
return "No valid function in window query";
|
||||||
case TSDB_CODE_PAR_INVALID_OPTR_USAGE:
|
case TSDB_CODE_PAR_INVALID_OPTR_USAGE:
|
||||||
return "Invalid usage of expr: %s";
|
return "Invalid usage of expr: %s";
|
||||||
|
case TSDB_CODE_PAR_INVALID_IP_RANGE:
|
||||||
|
return "invalid ip range";
|
||||||
case TSDB_CODE_OUT_OF_MEMORY:
|
case TSDB_CODE_OUT_OF_MEMORY:
|
||||||
return "Out of memory";
|
return "Out of memory";
|
||||||
default:
|
default:
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -556,7 +556,6 @@ TAOS_DEFINE_ERROR(TSDB_CODE_PAR_NOT_ALLOWED_WIN_QUERY, "Window query not su
|
||||||
TAOS_DEFINE_ERROR(TSDB_CODE_PAR_INVALID_DROP_COL, "No columns can be dropped")
|
TAOS_DEFINE_ERROR(TSDB_CODE_PAR_INVALID_DROP_COL, "No columns can be dropped")
|
||||||
TAOS_DEFINE_ERROR(TSDB_CODE_PAR_INVALID_COL_JSON, "Only tag can be json type")
|
TAOS_DEFINE_ERROR(TSDB_CODE_PAR_INVALID_COL_JSON, "Only tag can be json type")
|
||||||
TAOS_DEFINE_ERROR(TSDB_CODE_PAR_VALUE_TOO_LONG, "Value too long for column/tag")
|
TAOS_DEFINE_ERROR(TSDB_CODE_PAR_VALUE_TOO_LONG, "Value too long for column/tag")
|
||||||
TAOS_DEFINE_ERROR(TSDB_CODE_PAR_INVALID_VARBINARY, "Invalidate varbinary type")
|
|
||||||
TAOS_DEFINE_ERROR(TSDB_CODE_PAR_INVALID_DELETE_WHERE, "The DELETE statement must have a definite time window range")
|
TAOS_DEFINE_ERROR(TSDB_CODE_PAR_INVALID_DELETE_WHERE, "The DELETE statement must have a definite time window range")
|
||||||
TAOS_DEFINE_ERROR(TSDB_CODE_PAR_INVALID_REDISTRIBUTE_VG, "The REDISTRIBUTE VGROUP statement only support 1 to 3 dnodes")
|
TAOS_DEFINE_ERROR(TSDB_CODE_PAR_INVALID_REDISTRIBUTE_VG, "The REDISTRIBUTE VGROUP statement only support 1 to 3 dnodes")
|
||||||
TAOS_DEFINE_ERROR(TSDB_CODE_PAR_FILL_NOT_ALLOWED_FUNC, "Fill not allowed")
|
TAOS_DEFINE_ERROR(TSDB_CODE_PAR_FILL_NOT_ALLOWED_FUNC, "Fill not allowed")
|
||||||
|
@ -573,6 +572,8 @@ TAOS_DEFINE_ERROR(TSDB_CODE_PAR_GET_META_ERROR, "Fail to get table i
|
||||||
TAOS_DEFINE_ERROR(TSDB_CODE_PAR_NOT_UNIQUE_TABLE_ALIAS, "Not unique table/alias")
|
TAOS_DEFINE_ERROR(TSDB_CODE_PAR_NOT_UNIQUE_TABLE_ALIAS, "Not unique table/alias")
|
||||||
TAOS_DEFINE_ERROR(TSDB_CODE_PAR_SYSTABLE_NOT_ALLOWED_FUNC, "System table not allowed")
|
TAOS_DEFINE_ERROR(TSDB_CODE_PAR_SYSTABLE_NOT_ALLOWED_FUNC, "System table not allowed")
|
||||||
TAOS_DEFINE_ERROR(TSDB_CODE_PAR_SYSTABLE_NOT_ALLOWED, "System table not allowed")
|
TAOS_DEFINE_ERROR(TSDB_CODE_PAR_SYSTABLE_NOT_ALLOWED, "System table not allowed")
|
||||||
|
TAOS_DEFINE_ERROR(TSDB_CODE_PAR_INVALID_VARBINARY, "Invalidate varbinary type")
|
||||||
|
TAOS_DEFINE_ERROR(TSDB_CODE_PAR_INVALID_IP_RANGE, "Invalid IPV4 address ranges")
|
||||||
TAOS_DEFINE_ERROR(TSDB_CODE_PAR_INTERNAL_ERROR, "Parser internal error")
|
TAOS_DEFINE_ERROR(TSDB_CODE_PAR_INTERNAL_ERROR, "Parser internal error")
|
||||||
|
|
||||||
//planner
|
//planner
|
||||||
|
|
|
@ -809,6 +809,7 @@
|
||||||
|
|
||||||
,,y,script,./test.sh -f tsim/user/basic.sim
|
,,y,script,./test.sh -f tsim/user/basic.sim
|
||||||
,,y,script,./test.sh -f tsim/user/password.sim
|
,,y,script,./test.sh -f tsim/user/password.sim
|
||||||
|
,,y,script,./test.sh -f tsim/user/whitelist.sim
|
||||||
,,y,script,./test.sh -f tsim/user/privilege_db.sim
|
,,y,script,./test.sh -f tsim/user/privilege_db.sim
|
||||||
,,y,script,./test.sh -f tsim/user/privilege_sysinfo.sim
|
,,y,script,./test.sh -f tsim/user/privilege_sysinfo.sim
|
||||||
,,y,script,./test.sh -f tsim/user/privilege_topic.sim
|
,,y,script,./test.sh -f tsim/user/privilege_topic.sim
|
||||||
|
|
|
@ -0,0 +1,28 @@
|
||||||
|
system sh/stop_dnodes.sh
|
||||||
|
system sh/deploy.sh -n dnode1 -i 1
|
||||||
|
system sh/exec.sh -n dnode1 -s start
|
||||||
|
sql connect
|
||||||
|
|
||||||
|
print ============= step1
|
||||||
|
sql create user u_read pass 'taosdata1' host '127.0.0.1/24','192.168.1.0/24'
|
||||||
|
sql create user u_write pass 'taosdata1' host '127.0.0.1','192.168.1.0'
|
||||||
|
|
||||||
|
sql alter user u_read add host '3.3.3.4/24'
|
||||||
|
sql alter user u_write drop host '4.4.4.5/25'
|
||||||
|
|
||||||
|
sql show users
|
||||||
|
if $rows != 3 then
|
||||||
|
return -1
|
||||||
|
endi
|
||||||
|
|
||||||
|
print ============= step2
|
||||||
|
sql_error create user read1 pass 'taosdata1' host '127.0.0/24'
|
||||||
|
sql_error create user write1 pass 'taosdata1' host '4.4.4.4/33'
|
||||||
|
|
||||||
|
sql show users
|
||||||
|
if $rows != 3 then
|
||||||
|
return -1
|
||||||
|
endi
|
||||||
|
|
||||||
|
|
||||||
|
system sh/exec.sh -n dnode1 -s stop -x SIGINT
|
Loading…
Reference in New Issue