From 1245ae575c84d81843f5f7dcfd28fb5ee464dd68 Mon Sep 17 00:00:00 2001 From: sthuang <167743503+shaoting-huang@users.noreply.github.com> Date: Fri, 22 Nov 2024 19:42:32 +0800 Subject: [PATCH] fix: fix grant v2 service (#37945) issue: https://github.com/milvus-io/milvus/issues/37031 Signed-off-by: shaoting-huang --- .../proxy/httpserver/handler_v2.go | 20 ++++++++----------- .../proxy/httpserver/handler_v2_test.go | 3 ++- internal/distributed/proxy/service.go | 4 ++++ 3 files changed, 14 insertions(+), 13 deletions(-) diff --git a/internal/distributed/proxy/httpserver/handler_v2.go b/internal/distributed/proxy/httpserver/handler_v2.go index 6fe1c7d84608f..a83d3c011d153 100644 --- a/internal/distributed/proxy/httpserver/handler_v2.go +++ b/internal/distributed/proxy/httpserver/handler_v2.go @@ -1705,21 +1705,17 @@ func (h *HandlersV2) operatePrivilegeToRole(ctx context.Context, c *gin.Context, } func (h *HandlersV2) operatePrivilegeToRoleV2(ctx context.Context, c *gin.Context, httpReq *GrantV2Req, operateType milvuspb.OperatePrivilegeType) (interface{}, error) { - req := &milvuspb.OperatePrivilegeRequest{ - Entity: &milvuspb.GrantEntity{ - Role: &milvuspb.RoleEntity{Name: httpReq.RoleName}, - Object: &milvuspb.ObjectEntity{Name: commonpb.ObjectType_Global.String()}, - ObjectName: httpReq.CollectionName, - DbName: httpReq.DbName, - Grantor: &milvuspb.GrantorEntity{ - Privilege: &milvuspb.PrivilegeEntity{Name: httpReq.Privilege}, - }, + req := &milvuspb.OperatePrivilegeV2Request{ + Role: &milvuspb.RoleEntity{Name: httpReq.RoleName}, + Grantor: &milvuspb.GrantorEntity{ + Privilege: &milvuspb.PrivilegeEntity{Name: httpReq.Privilege}, }, - Type: operateType, - Version: "v2", + Type: operateType, + DbName: httpReq.DbName, + CollectionName: httpReq.CollectionName, } resp, err := wrapperProxy(ctx, c, req, h.checkAuth, false, "/milvus.proto.milvus.MilvusService/OperatePrivilege", func(reqCtx context.Context, req any) (interface{}, error) { - return h.proxy.OperatePrivilege(reqCtx, req.(*milvuspb.OperatePrivilegeRequest)) + return h.proxy.OperatePrivilegeV2(reqCtx, req.(*milvuspb.OperatePrivilegeV2Request)) }) if err == nil { HTTPReturn(c, http.StatusOK, wrapperReturnDefault()) diff --git a/internal/distributed/proxy/httpserver/handler_v2_test.go b/internal/distributed/proxy/httpserver/handler_v2_test.go index 87e83c815c17e..5248f9c9a69b8 100644 --- a/internal/distributed/proxy/httpserver/handler_v2_test.go +++ b/internal/distributed/proxy/httpserver/handler_v2_test.go @@ -1106,7 +1106,8 @@ func TestMethodPost(t *testing.T) { mp.EXPECT().UpdateCredential(mock.Anything, mock.Anything).Return(commonSuccessStatus, nil).Once() mp.EXPECT().OperateUserRole(mock.Anything, mock.Anything).Return(commonSuccessStatus, nil).Twice() mp.EXPECT().CreateRole(mock.Anything, mock.Anything).Return(commonSuccessStatus, nil).Once() - mp.EXPECT().OperatePrivilege(mock.Anything, mock.Anything).Return(commonSuccessStatus, nil).Times(4) + mp.EXPECT().OperatePrivilege(mock.Anything, mock.Anything).Return(commonSuccessStatus, nil).Times(2) + mp.EXPECT().OperatePrivilegeV2(mock.Anything, mock.Anything).Return(commonSuccessStatus, nil).Times(2) mp.EXPECT().CreateIndex(mock.Anything, mock.Anything).Return(commonSuccessStatus, nil).Twice() mp.EXPECT().CreateIndex(mock.Anything, mock.Anything).Return(commonErrorStatus, nil).Once() mp.EXPECT().CreateAlias(mock.Anything, mock.Anything).Return(commonSuccessStatus, nil).Once() diff --git a/internal/distributed/proxy/service.go b/internal/distributed/proxy/service.go index b941663cecc61..9c70b6d96f7c0 100644 --- a/internal/distributed/proxy/service.go +++ b/internal/distributed/proxy/service.go @@ -1048,6 +1048,10 @@ func (s *Server) OperatePrivilege(ctx context.Context, req *milvuspb.OperatePriv return s.proxy.OperatePrivilege(ctx, req) } +func (s *Server) OperatePrivilegeV2(ctx context.Context, req *milvuspb.OperatePrivilegeV2Request) (*commonpb.Status, error) { + return s.proxy.OperatePrivilegeV2(ctx, req) +} + func (s *Server) SelectGrant(ctx context.Context, req *milvuspb.SelectGrantRequest) (*milvuspb.SelectGrantResponse, error) { return s.proxy.SelectGrant(ctx, req) }