Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DiDi
kafka-manager
提交
52244325
K
kafka-manager
项目概览
DiDi
/
kafka-manager
9 个月 前同步成功
通知
58
Star
6372
Fork
1229
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
kafka-manager
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
52244325
编写于
5月 18, 2021
作者:
T
tangcongfa_v@didichuxing.com
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
权限调整
上级
d4ee5e91
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
69 addition
and
1 deletion
+69
-1
kafka-manager-core/src/main/java/com/xiaojukeji/kafka/manager/service/service/TopicManagerService.java
...ji/kafka/manager/service/service/TopicManagerService.java
+8
-0
kafka-manager-core/src/main/java/com/xiaojukeji/kafka/manager/service/service/impl/TopicManagerServiceImpl.java
...manager/service/service/impl/TopicManagerServiceImpl.java
+33
-0
kafka-manager-extends/kafka-manager-openapi/src/main/java/com/xiaojukeji/kafka/manager/openapi/common/dto/TopicAuthorityDTO.java
...i/kafka/manager/openapi/common/dto/TopicAuthorityDTO.java
+1
-1
kafka-manager-web/src/main/java/com/xiaojukeji/kafka/manager/web/api/versionone/thirdpart/ThirdPartTopicController.java
...eb/api/versionone/thirdpart/ThirdPartTopicController.java
+12
-0
kafka-manager-web/src/main/java/com/xiaojukeji/kafka/manager/web/converters/AuthorityConverter.java
...keji/kafka/manager/web/converters/AuthorityConverter.java
+15
-0
未找到文件。
kafka-manager-core/src/main/java/com/xiaojukeji/kafka/manager/service/service/TopicManagerService.java
浏览文件 @
52244325
...
...
@@ -11,6 +11,7 @@ import com.xiaojukeji.kafka.manager.common.entity.ao.topic.MineTopicSummary;
import
com.xiaojukeji.kafka.manager.common.entity.pojo.TopicDO
;
import
com.xiaojukeji.kafka.manager.common.entity.pojo.TopicExpiredDO
;
import
com.xiaojukeji.kafka.manager.common.entity.pojo.TopicStatisticsDO
;
import
com.xiaojukeji.kafka.manager.common.entity.pojo.gateway.AuthorityDO
;
import
java.util.Date
;
import
java.util.List
;
...
...
@@ -130,5 +131,12 @@ public interface TopicManagerService {
* @return
*/
ResultStatus
addTopicQuota
(
TopicQuota
topicQuota
);
/**
* topic权限调整
* @param authorityDO topic权限
* @return
*/
ResultStatus
addAuthority
(
AuthorityDO
authorityDO
);
}
kafka-manager-core/src/main/java/com/xiaojukeji/kafka/manager/service/service/impl/TopicManagerServiceImpl.java
浏览文件 @
52244325
...
...
@@ -21,6 +21,7 @@ import com.xiaojukeji.kafka.manager.common.entity.pojo.gateway.AuthorityDO;
import
com.xiaojukeji.kafka.manager.common.utils.DateUtils
;
import
com.xiaojukeji.kafka.manager.common.utils.JsonUtils
;
import
com.xiaojukeji.kafka.manager.common.utils.NumberUtils
;
import
com.xiaojukeji.kafka.manager.common.utils.SpringTool
;
import
com.xiaojukeji.kafka.manager.common.utils.ValidateUtils
;
import
com.xiaojukeji.kafka.manager.common.zookeeper.znode.brokers.TopicMetadata
;
import
com.xiaojukeji.kafka.manager.common.zookeeper.znode.config.TopicQuotaData
;
...
...
@@ -653,6 +654,38 @@ public class TopicManagerServiceImpl implements TopicManagerService {
return
ResultStatus
.
MYSQL_ERROR
;
}
@Override
public
ResultStatus
addAuthority
(
AuthorityDO
authorityDO
)
{
// 查询该用户拥有的应用
List
<
AppDO
>
appDOs
=
appService
.
getByPrincipal
(
SpringTool
.
getUserName
());
if
(
ValidateUtils
.
isEmptyList
(
appDOs
))
{
// 该用户无应用,需要先申请应用
return
ResultStatus
.
APP_NOT_EXIST
;
}
List
<
Long
>
appIds
=
appDOs
.
stream
().
map
(
AppDO:
:
getId
).
collect
(
Collectors
.
toList
());
if
(!
appIds
.
contains
(
authorityDO
.
getAppId
()))
{
// 入参中的appId,该用户未拥有
return
ResultStatus
.
APP_NOT_EXIST
;
}
// 获取物理集群id
Long
physicalClusterId
=
logicalClusterMetadataManager
.
getPhysicalClusterId
(
authorityDO
.
getClusterId
());
if
(
ValidateUtils
.
isNull
(
physicalClusterId
))
{
// 集群不存在
return
ResultStatus
.
CLUSTER_NOT_EXIST
;
}
TopicDO
topic
=
getByTopicName
(
physicalClusterId
,
authorityDO
.
getTopicName
());
if
(
ValidateUtils
.
isNull
(
topic
))
{
// topic不存在
return
ResultStatus
.
TOPIC_NOT_EXIST
;
}
// 设置物理集群id
authorityDO
.
setClusterId
(
physicalClusterId
);
if
(
authorityService
.
addAuthority
(
authorityDO
)
>
0
)
{
return
ResultStatus
.
SUCCESS
;
}
return
ResultStatus
.
MYSQL_ERROR
;
}
private
RdTopicBasic
convert2RdTopicBasic
(
ClusterDO
clusterDO
,
String
topicName
,
TopicDO
topicDO
,
...
...
kafka-manager-extends/kafka-manager-openapi/src/main/java/com/xiaojukeji/kafka/manager/openapi/common/dto/TopicAuthorityDTO.java
浏览文件 @
52244325
...
...
@@ -11,7 +11,7 @@ public class TopicAuthorityDTO extends ClusterTopicDTO {
@ApiModelProperty
(
value
=
"appId"
)
private
String
appId
;
@ApiModelProperty
(
value
=
"0:无权限, 1:读, 2:写, 3:读写"
)
@ApiModelProperty
(
value
=
"0:无权限, 1:读, 2:写, 3:读写
, 4:可管理
"
)
private
Integer
access
;
public
String
getAppId
()
{
...
...
kafka-manager-web/src/main/java/com/xiaojukeji/kafka/manager/web/api/versionone/thirdpart/ThirdPartTopicController.java
浏览文件 @
52244325
...
...
@@ -14,12 +14,14 @@ import com.xiaojukeji.kafka.manager.common.entity.vo.normal.consumer.ConsumerGro
import
com.xiaojukeji.kafka.manager.common.entity.vo.normal.topic.TopicAuthorizedAppVO
;
import
com.xiaojukeji.kafka.manager.common.entity.vo.normal.topic.TopicRequestTimeDetailVO
;
import
com.xiaojukeji.kafka.manager.common.zookeeper.znode.brokers.TopicMetadata
;
import
com.xiaojukeji.kafka.manager.openapi.common.dto.TopicAuthorityDTO
;
import
com.xiaojukeji.kafka.manager.openapi.common.vo.TopicOffsetChangedVO
;
import
com.xiaojukeji.kafka.manager.common.utils.ValidateUtils
;
import
com.xiaojukeji.kafka.manager.common.entity.pojo.ClusterDO
;
import
com.xiaojukeji.kafka.manager.service.cache.PhysicalClusterMetadataManager
;
import
com.xiaojukeji.kafka.manager.service.service.*
;
import
com.xiaojukeji.kafka.manager.common.constant.ApiPrefix
;
import
com.xiaojukeji.kafka.manager.web.converters.AuthorityConverter
;
import
com.xiaojukeji.kafka.manager.web.converters.CommonModelConverter
;
import
com.xiaojukeji.kafka.manager.web.converters.ConsumerModelConverter
;
import
com.xiaojukeji.kafka.manager.web.converters.TopicModelConverter
;
...
...
@@ -147,4 +149,14 @@ public class ThirdPartTopicController {
return
Result
.
buildFrom
(
topicManagerService
.
addTopicQuota
(
TopicQuota
.
buildFrom
(
dto
)));
}
@ApiOperation
(
value
=
"权限调整"
,
notes
=
"权限调整"
)
@RequestMapping
(
value
=
"{topics/authority/add}"
,
method
=
RequestMethod
.
POST
)
@ResponseBody
public
Result
addAuthority
(
@RequestBody
TopicAuthorityDTO
dto
)
{
//非空校验
if
(
ValidateUtils
.
isNull
(
dto
)
||
!
dto
.
paramLegal
())
{
return
Result
.
buildFrom
(
ResultStatus
.
PARAM_ILLEGAL
);
}
return
Result
.
buildFrom
(
topicManagerService
.
addAuthority
(
AuthorityConverter
.
convert2AuthorityDO
(
dto
)));
}
}
kafka-manager-web/src/main/java/com/xiaojukeji/kafka/manager/web/converters/AuthorityConverter.java
0 → 100644
浏览文件 @
52244325
package
com.xiaojukeji.kafka.manager.web.converters
;
import
com.xiaojukeji.kafka.manager.common.entity.pojo.gateway.AuthorityDO
;
import
com.xiaojukeji.kafka.manager.openapi.common.dto.TopicAuthorityDTO
;
public
class
AuthorityConverter
{
public
static
AuthorityDO
convert2AuthorityDO
(
TopicAuthorityDTO
dto
)
{
AuthorityDO
authorityDO
=
new
AuthorityDO
();
authorityDO
.
setAppId
(
dto
.
getAppId
());
authorityDO
.
setClusterId
(
dto
.
getClusterId
());
authorityDO
.
setTopicName
(
dto
.
getTopicName
());
authorityDO
.
setAccess
(
dto
.
getAccess
());
return
authorityDO
;
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录