Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
0a912796
T
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1187
Star
22018
Fork
4786
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
0a912796
编写于
3月 10, 2020
作者:
S
slguan
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
refactor mgmtUser and mgmtAcct
上级
501c98c9
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
30 addition
and
92 deletion
+30
-92
src/mnode/inc/mgmtAcct.h
src/mnode/inc/mgmtAcct.h
+2
-9
src/mnode/src/mgmtAcct.c
src/mnode/src/mgmtAcct.c
+20
-75
src/mnode/src/mgmtUser.c
src/mnode/src/mgmtUser.c
+8
-8
未找到文件。
src/mnode/inc/mgmtAcct.h
浏览文件 @
0a912796
...
...
@@ -19,28 +19,21 @@
#ifdef __cplusplus
extern
"C"
{
#endif
#include "mnode.h"
int32_t
mgmtInitAccts
();
void
mgmtCleanUpAccts
();
int32_t
mgmtInitAccts
();
void
mgmtCleanUpAccts
();
SAcctObj
*
mgmtGetAcct
(
char
*
acctName
);
int32_t
mgmtCheckUserLimit
(
SAcctObj
*
pAcct
);
int32_t
mgmtCheckDbLimit
(
SAcctObj
*
pAcct
);
int32_t
mgmtCheckTableLimit
(
SAcctObj
*
pAcct
,
int32_t
numOfTimeSeries
);
int32_t
mgmtGetAcctMeta
(
STableMeta
*
pMeta
,
SShowObj
*
pShow
,
void
*
pConn
);
int32_t
mgmtRetrieveAccts
(
SShowObj
*
pShow
,
char
*
data
,
int32_t
rows
,
void
*
pConn
);
int32_t
mgmtAddDbIntoAcct
(
SAcctObj
*
pAcct
,
SDbObj
*
pDb
);
int32_t
mgmtRemoveDbFromAcct
(
SAcctObj
*
pAcct
,
SDbObj
*
pDb
);
int32_t
mgmtAddUserIntoAcct
(
SAcctObj
*
pAcct
,
SUserObj
*
pUser
);
int32_t
mgmtRemoveUserFromAcct
(
SAcctObj
*
pAcct
,
SUserObj
*
pUser
);
extern
int32_t
(
*
mgmtCreateAcctFp
)(
char
*
name
,
char
*
pass
,
SAcctCfg
*
pCfg
);
extern
int32_t
(
*
mgmtDropAcctFp
)(
char
*
name
);
extern
int32_t
(
*
mgmtAlterAcctFp
)(
char
*
name
,
char
*
pass
,
SAcctCfg
*
pCfg
);
#ifdef __cplusplus
}
#endif
...
...
src/mnode/src/mgmtAcct.c
浏览文件 @
0a912796
...
...
@@ -15,30 +15,16 @@
#define _DEFAULT_SOURCE
#include "os.h"
#include "tschemautil.h"
#include "taoserror.h"
#include "mnode.h"
#include "mgmtAcct.h"
#include "mgmtTable.h"
#include "mgmtUser.h"
extern
void
*
tsUserSdb
;
extern
void
*
tsDbSdb
;
static
SAcctObj
tsAcctObj
;
int32_t
(
*
mgmtInitAcctsFp
)()
=
NULL
;
void
(
*
mgmtCleanUpAcctsFp
)()
=
NULL
;
int32_t
(
*
mgmtCreateAcctFp
)(
char
*
name
,
char
*
pass
,
SAcctCfg
*
pCfg
)
=
NULL
;
int32_t
(
*
mgmtDropAcctFp
)(
char
*
name
)
=
NULL
;
int32_t
(
*
mgmtAlterAcctFp
)(
char
*
name
,
char
*
pass
,
SAcctCfg
*
pCfg
)
=
NULL
;
int32_t
(
*
mgmtGetAcctMetaFp
)(
STableMeta
*
pMeta
,
SShowObj
*
pShow
,
void
*
pConn
)
=
NULL
;
int32_t
(
*
mgmtRetrieveAcctsFp
)(
SShowObj
*
pShow
,
char
*
data
,
int32_t
rows
,
void
*
pConn
)
=
NULL
;
int32_t
(
*
mgmtInitAcctsFp
)()
=
NULL
;
void
(
*
mgmtCleanUpAcctsFp
)()
=
NULL
;
SAcctObj
*
(
*
mgmtGetAcctFp
)(
char
*
acctName
)
=
NULL
;
int32_t
(
*
mgmtCheckUserLimitFp
)(
SAcctObj
*
pAcct
)
=
NULL
;
int32_t
(
*
mgmtCheckDbLimitFp
)(
SAcctObj
*
pAcct
)
=
NULL
;
int32_t
(
*
mgmtCheckTimeSeriesLimitFp
)(
SAcctObj
*
pAcct
,
int32_t
numOfTimeSeries
)
=
NULL
;
int32_t
(
*
mgmtCheckUserLimitFp
)(
SAcctObj
*
pAcct
)
=
NULL
;
int32_t
(
*
mgmtCheckDbLimitFp
)(
SAcctObj
*
pAcct
)
=
NULL
;
int32_t
(
*
mgmtCheckTimeSeriesLimitFp
)(
SAcctObj
*
pAcct
,
int32_t
numOfTimeSeries
)
=
NULL
;
int32_t
mgmtAddDbIntoAcct
(
SAcctObj
*
pAcct
,
SDbObj
*
pDb
)
{
pthread_mutex_lock
(
&
pAcct
->
mutex
);
...
...
@@ -113,88 +99,47 @@ int32_t mgmtRemoveUserFromAcct(SAcctObj *pAcct, SUserObj *pUser) {
int32_t
mgmtInitAccts
()
{
if
(
mgmtInitAcctsFp
)
{
return
mgmtInitAcctsFp
();
return
(
*
mgmtInitAcctsFp
)
();
}
else
{
SAcctObj
*
pAcct
=
&
tsAcctObj
;
pAcct
->
acctId
=
0
;
strcpy
(
pAcct
->
user
,
"root"
);
tsAcctObj
.
acctId
=
0
;
strcpy
(
tsAcctObj
.
user
,
"root"
);
return
0
;
}
}
SAcctObj
*
mgmtGetAcct
(
char
*
acctName
)
{
if
(
mgmtGetAcctFp
)
{
return
mgmtGetAcctFp
(
acctName
);
return
(
*
mgmtGetAcctFp
)
(
acctName
);
}
else
{
return
&
tsAcctObj
;
}
}
void
mgmtCleanUpAccts
()
{
if
(
mgmtCleanUpAcctsFp
)
{
(
*
mgmtCleanUpAcctsFp
)();
}
}
int32_t
mgmtCheckUserLimit
(
SAcctObj
*
pAcct
)
{
if
(
mgmtCheckUserLimitFp
)
{
return
mgmtCheckUserLimitFp
(
pAcct
);
}
else
{
int32_t
numOfUsers
=
sdbGetNumOfRows
(
tsUserSdb
);
if
(
numOfUsers
>=
tsMaxUsers
)
{
mWarn
(
"numOfUsers:%d, exceed tsMaxUsers:%d"
,
numOfUsers
,
tsMaxUsers
);
return
TSDB_CODE_TOO_MANY_USERS
;
}
return
0
;
return
(
*
mgmtCheckUserLimitFp
)(
pAcct
);
}
return
0
;
}
int32_t
mgmtCheckDbLimit
(
SAcctObj
*
pAcct
)
{
if
(
mgmtCheckDbLimitFp
)
{
return
mgmtCheckDbLimitFp
(
pAcct
);
return
(
*
mgmtCheckDbLimitFp
)
(
pAcct
);
}
else
{
int32_t
numOfDbs
=
sdbGetNumOfRows
(
tsDbSdb
);
if
(
numOfDbs
>=
tsMaxDbs
)
{
mWarn
(
"numOfDbs:%d, exceed tsMaxDbs:%d"
,
numOfDbs
,
tsMaxDbs
);
return
TSDB_CODE_TOO_MANY_DATABASES
;
}
return
0
;
}
}
int32_t
mgmtCheckTableLimit
(
SAcctObj
*
pAcct
,
int32_t
numOfTimeSeries
)
{
if
(
mgmtCheckTimeSeriesLimitFp
)
{
return
mgmtCheckTimeSeriesLimitFp
(
pAcct
,
numOfTimeSeries
);
return
(
*
mgmtCheckTimeSeriesLimitFp
)
(
pAcct
,
numOfTimeSeries
);
}
else
{
return
0
;
}
}
void
mgmtCleanUpAccts
()
{
if
(
mgmtCleanUpAcctsFp
)
{
mgmtCleanUpAcctsFp
();
}
}
int32_t
mgmtGetAcctMeta
(
STableMeta
*
pMeta
,
SShowObj
*
pShow
,
void
*
pConn
)
{
if
(
mgmtGetAcctMetaFp
)
{
return
mgmtGetAcctMetaFp
(
pMeta
,
pShow
,
pConn
);
}
else
{
return
TSDB_CODE_OPS_NOT_SUPPORT
;
}
}
int32_t
mgmtRetrieveAccts
(
SShowObj
*
pShow
,
char
*
data
,
int32_t
rows
,
void
*
pConn
)
{
if
(
mgmtRetrieveAcctsFp
)
{
return
mgmtRetrieveAcctsFp
(
pShow
,
data
,
rows
,
pConn
);
}
else
{
return
0
;
}
}
SAcctObj
*
mgmtGetAcctFromConn
(
void
*
pConn
)
{
// SRpcConnInfo connInfo;
// rpcGetConnInfo(pConn, &connInfo);
//
// SUserObj *pUser = mgmtGetUser(connInfo.user);
// if (pUser != NULL) {
// return pUser->pAcct;
// }
return
NULL
;
}
}
\ No newline at end of file
src/mnode/src/mgmtUser.c
浏览文件 @
0a912796
...
...
@@ -18,18 +18,12 @@
#include "trpc.h"
#include "tschemautil.h"
#include "ttime.h"
#include "mnode.h"
#include "mgmtAcct.h"
#include "mgmtGrant.h"
#include "mgmtMnode.h"
#include "mgmtShell.h"
#include "mgmtUser.h"
#include "mgmtAcct.h"
#include "mgmtGrant.h"
#include "mgmtTable.h"
void
*
tsUserSdb
=
NULL
;
static
int32_t
tsUserUpdateSize
=
0
;
...
...
@@ -113,6 +107,12 @@ static int32_t mgmtUpdateUser(SUserObj *pUser) {
}
static
int32_t
mgmtCreateUser
(
SAcctObj
*
pAcct
,
char
*
name
,
char
*
pass
)
{
int32_t
numOfUsers
=
sdbGetNumOfRows
(
tsUserSdb
);
if
(
numOfUsers
>=
tsMaxUsers
)
{
mWarn
(
"numOfUsers:%d, exceed tsMaxUsers:%d"
,
numOfUsers
,
tsMaxUsers
);
return
TSDB_CODE_TOO_MANY_USERS
;
}
int32_t
code
=
mgmtCheckUserLimit
(
pAcct
);
if
(
code
!=
0
)
{
return
code
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录