Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
6da52762
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22016
Fork
4786
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
6da52762
编写于
8月 01, 2023
作者:
W
wade zhang
提交者:
GitHub
8月 01, 2023
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #22264 from taosdata/szhou/fix-ts3749
fix: restore user privilege processing if the rows generated by the u…
上级
ae9745ec
785326c4
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
24 addition
and
3 deletion
+24
-3
source/dnode/mnode/impl/src/mndShow.c
source/dnode/mnode/impl/src/mndShow.c
+3
-0
source/dnode/mnode/impl/src/mndUser.c
source/dnode/mnode/impl/src/mndUser.c
+21
-3
未找到文件。
source/dnode/mnode/impl/src/mndShow.c
浏览文件 @
6da52762
...
...
@@ -20,6 +20,7 @@
#define SHOW_STEP_SIZE 100
#define SHOW_COLS_STEP_SIZE 4096
#define SHOW_PRIVILEGES_STEP_SIZE 2048
static
SShowObj
*
mndCreateShowObj
(
SMnode
*
pMnode
,
SRetrieveTableReq
*
pReq
);
static
void
mndFreeShowObj
(
SShowObj
*
pShow
);
...
...
@@ -234,6 +235,8 @@ static int32_t mndProcessRetrieveSysTableReq(SRpcMsg *pReq) {
if
(
pShow
->
type
==
TSDB_MGMT_TABLE_COL
){
// expend capacity for ins_columns
rowsToRead
=
SHOW_COLS_STEP_SIZE
;
}
else
if
(
pShow
->
type
==
TSDB_MGMT_TABLE_PRIVILEGES
)
{
rowsToRead
=
SHOW_PRIVILEGES_STEP_SIZE
;
}
ShowRetrieveFp
retrieveFp
=
pMgmt
->
retrieveFps
[
pShow
->
type
];
if
(
retrieveFp
==
NULL
)
{
...
...
source/dnode/mnode/impl/src/mndUser.c
浏览文件 @
6da52762
...
...
@@ -1213,16 +1213,34 @@ static int32_t mndRetrievePrivileges(SRpcMsg *pReq, SShowObj *pShow, SSDataBlock
int32_t
cols
=
0
;
char
*
pWrite
;
bool
fetchNextUser
=
pShow
->
restore
?
false
:
true
;
pShow
->
restore
=
false
;
while
(
numOfRows
<
rows
)
{
if
(
fetchNextUser
)
{
pShow
->
pIter
=
sdbFetch
(
pSdb
,
SDB_USER
,
pShow
->
pIter
,
(
void
**
)
&
pUser
);
if
(
pShow
->
pIter
==
NULL
)
break
;
}
else
{
fetchNextUser
=
true
;
void
*
pKey
=
taosHashGetKey
(
pShow
->
pIter
,
NULL
);
pUser
=
sdbAcquire
(
pSdb
,
SDB_USER
,
pKey
);
if
(
!
pUser
)
{
continue
;
}
}
int32_t
numOfReadDbs
=
taosHashGetSize
(
pUser
->
readDbs
);
int32_t
numOfWriteDbs
=
taosHashGetSize
(
pUser
->
writeDbs
);
int32_t
numOfTopics
=
taosHashGetSize
(
pUser
->
topics
);
int32_t
numOfReadTbs
=
taosHashGetSize
(
pUser
->
readTbs
);
int32_t
numOfWriteTbs
=
taosHashGetSize
(
pUser
->
writeTbs
);
if
(
numOfRows
+
numOfReadDbs
+
numOfWriteDbs
+
numOfTopics
+
numOfReadTbs
+
numOfWriteTbs
>=
rows
)
break
;
if
(
numOfRows
+
numOfReadDbs
+
numOfWriteDbs
+
numOfTopics
+
numOfReadTbs
+
numOfWriteTbs
>=
rows
)
{
mInfo
(
"will restore. current num of rows: %d, read dbs %d, write dbs %d, topics %d, read tables %d, write tables %d"
,
numOfRows
,
numOfReadDbs
,
numOfWriteDbs
,
numOfTopics
,
numOfReadTbs
,
numOfWriteTbs
);
pShow
->
restore
=
true
;
sdbRelease
(
pSdb
,
pUser
);
break
;
}
if
(
pUser
->
superUser
)
{
cols
=
0
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录