mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-25 12:42:12 +08:00 
			
		
		
		
	feat: optimize friend and group applications (#3384)
* pb * fix: Modifying other fields while setting IsPrivateChat does not take effect * fix: quote message error revoke * refactoring scheduled tasks * refactoring scheduled tasks * refactoring scheduled tasks * refactoring scheduled tasks * refactoring scheduled tasks * refactoring scheduled tasks * upgrading pkg tools * fix * fix * optimize log output * feat: support GetLastMessage * feat: support GetLastMessage * feat: s3 switch * feat: s3 switch * fix: GetUsersOnline * feat: SendBusinessNotification supported configuration parameters * feat: SendBusinessNotification supported configuration parameters * feat: SendBusinessNotification supported configuration parameters * feat: seq conversion failed without exiting * fix: DeleteDoc crash * fix: fill send time * fix: fill send time * fix: crash caused by withdrawing messages from users who have left the group * fix: user msg timestamp * seq read config * seq read config * fix: the source message of the reference is withdrawn, and the referenced message is deleted * feat: optimize the default notification.yml * fix: shouldPushOffline * fix: the sorting is wrong after canceling the administrator in group settings * feat: Sending messages supports returning fields modified by webhook * feat: Sending messages supports returning fields modified by webhook * feat: Sending messages supports returning fields modified by webhook * fix: oss specifies content-type when uploading * fix: the version number contains a line break * fix: the version number contains a line break * feat: GetConversationsHasReadAndMaxSeq support pinned * feat: GetConversationsHasReadAndMaxSeq support pinned * feat: GetConversationsHasReadAndMaxSeq support pinned * fix: transferring the group owner to a muted member, incremental version error * feat: unified conversion code * feat: update gomake * fix: in standalone mode, the user online status is wrong * fix: add permission check * fix: add permission check * fix: add rpc interface permission check * fix: CreateGroupChatConversations * feat: optimize friend and group applications * feat: optimize friend and group applications * feat: optimize friend and group applications * feat: optimize friend and group applications (cherry picked from commit 8e61f30e9c59916671e4a75844dcc0a4dfcd5d8a) # Conflicts: # go.mod # go.sum
This commit is contained in:
		
							parent
							
								
									bc326704f1
								
							
						
					
					
						commit
						1684c82458
					
				
							
								
								
									
										2
									
								
								go.mod
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								go.mod
									
									
									
									
									
								
							| @ -35,7 +35,7 @@ require ( | ||||
| 	github.com/hashicorp/golang-lru/v2 v2.0.7 | ||||
| 	github.com/kelindar/bitmap v1.5.2 | ||||
| 	github.com/likexian/gokit v0.25.13 | ||||
| 	github.com/openimsdk/gomake v0.0.14-alpha.5 | ||||
| 	github.com/openimsdk/gomake v0.0.15-alpha.5 | ||||
| 	github.com/redis/go-redis/v9 v9.4.0 | ||||
| 	github.com/robfig/cron/v3 v3.0.1 | ||||
| 	github.com/shirou/gopsutil v3.21.11+incompatible | ||||
|  | ||||
| @ -690,7 +690,7 @@ func (g *groupServer) GetGroupApplicationList(ctx context.Context, req *pbgroup. | ||||
| 		} | ||||
| 	} else { | ||||
| 		req.GroupIDs = datautil.Distinct(req.GroupIDs) | ||||
| 		if !authverify.IsAdmin(ctx) { | ||||
| 		if !authverify.IsAppManagerUid(ctx, g.config.Share.IMAdminUserID) { | ||||
| 			for _, groupID := range req.GroupIDs { | ||||
| 				if err := g.CheckGroupAdmin(ctx, groupID); err != nil { | ||||
| 					return nil, err | ||||
| @ -772,7 +772,7 @@ func (g *groupServer) GetGroupsInfo(ctx context.Context, req *pbgroup.GetGroupsI | ||||
| } | ||||
| 
 | ||||
| func (g *groupServer) GetGroupApplicationUnhandledCount(ctx context.Context, req *pbgroup.GetGroupApplicationUnhandledCountReq) (*pbgroup.GetGroupApplicationUnhandledCountResp, error) { | ||||
| 	if err := authverify.CheckAccess(ctx, req.UserID); err != nil { | ||||
| 	if err := authverify.CheckAccessV3(ctx, req.UserID, g.config.Share.IMAdminUserID); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	groupIDs, err := g.db.FindUserManagedGroupID(ctx, req.UserID) | ||||
|  | ||||
| @ -48,7 +48,3 @@ func (m *MsgNotificationSender) MarkAsReadNotification(ctx context.Context, conv | ||||
| 	} | ||||
| 	m.NotificationWithSessionType(ctx, sendID, recvID, constant.HasReadReceipt, sessionType, tips) | ||||
| } | ||||
| 
 | ||||
| func (m *MsgNotificationSender) StreamMsgNotification(ctx context.Context, sendID string, recvID string, sessionType int32, tips *sdkws.StreamMsgTips) { | ||||
| 	m.NotificationWithSessionType(ctx, sendID, recvID, constant.StreamMsgNotification, sessionType, tips) | ||||
| } | ||||
|  | ||||
| @ -17,6 +17,7 @@ package relation | ||||
| import ( | ||||
| 	"context" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/notification/common_user" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/rpcli" | ||||
| 
 | ||||
| 	"github.com/openimsdk/tools/mq/memamq" | ||||
| @ -328,7 +329,7 @@ func (s *friendServer) GetDesignatedFriendsApply(ctx context.Context, | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	resp = &relation.GetDesignatedFriendsApplyResp{} | ||||
| 	resp.FriendRequests, err = convert.FriendRequestDB2Pb(ctx, friendRequests, s.userClient.GetUsersInfoMap) | ||||
| 	resp.FriendRequests, err = convert.FriendRequestDB2Pb(ctx, friendRequests, s.getCommonUserMap) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| @ -375,7 +376,7 @@ func (s *friendServer) GetPaginationFriendsApplyFrom(ctx context.Context, req *r | ||||
| 		return nil, err | ||||
| 	} | ||||
| 
 | ||||
| 	resp.FriendRequests, err = convert.FriendRequestDB2Pb(ctx, friendRequests, s.userClient.GetUsersInfoMap) | ||||
| 	resp.FriendRequests, err = convert.FriendRequestDB2Pb(ctx, friendRequests, s.getCommonUserMap) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| @ -553,7 +554,7 @@ func (s *friendServer) UpdateFriends( | ||||
| } | ||||
| 
 | ||||
| func (s *friendServer) GetSelfUnhandledApplyCount(ctx context.Context, req *relation.GetSelfUnhandledApplyCountReq) (*relation.GetSelfUnhandledApplyCountResp, error) { | ||||
| 	if err := authverify.CheckAccess(ctx, req.UserID); err != nil { | ||||
| 	if err := authverify.CheckAccessV3(ctx, req.UserID, s.config.Share.IMAdminUserID); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 
 | ||||
|  | ||||
							
								
								
									
										13
									
								
								magefile.go
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								magefile.go
									
									
									
									
									
								
							| @ -4,14 +4,23 @@ | ||||
| package main | ||||
| 
 | ||||
| import ( | ||||
| 	"github.com/openimsdk/gomake/mageutil" | ||||
| 	"flag" | ||||
| 	"os" | ||||
| 
 | ||||
| 	"github.com/openimsdk/gomake/mageutil" | ||||
| ) | ||||
| 
 | ||||
| var Default = Build | ||||
| 
 | ||||
| func Build() { | ||||
| 	mageutil.Build() | ||||
| 	flag.Parse() | ||||
| 
 | ||||
| 	bin := flag.Args() | ||||
| 	if len(bin) != 0 { | ||||
| 		bin = bin[1:] | ||||
| 	} | ||||
| 
 | ||||
| 	mageutil.Build(bin) | ||||
| } | ||||
| 
 | ||||
| func Start() { | ||||
|  | ||||
| @ -4,6 +4,11 @@ import ( | ||||
| 	"context" | ||||
| 	"errors" | ||||
| 	"fmt" | ||||
| 	"log" | ||||
| 	"net/http" | ||||
| 	"path/filepath" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"github.com/mitchellh/mapstructure" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/config" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/cache/redis" | ||||
| @ -19,10 +24,6 @@ import ( | ||||
| 	"github.com/openimsdk/tools/s3/oss" | ||||
| 	"github.com/spf13/viper" | ||||
| 	"go.mongodb.org/mongo-driver/mongo" | ||||
| 	"log" | ||||
| 	"net/http" | ||||
| 	"path/filepath" | ||||
| 	"time" | ||||
| ) | ||||
| 
 | ||||
| const defaultTimeout = time.Second * 10 | ||||
| @ -159,7 +160,7 @@ func doObject(db database.ObjectInfo, newS3, oldS3 s3.Interface, skip int) (*Res | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	putURL, err := newS3.PresignedPutObject(ctx, obj.Key, time.Hour) | ||||
| 	putURL, err := newS3.PresignedPutObject(ctx, obj.Key, time.Hour, &s3.PutOption{ContentType: obj.ContentType}) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| @ -176,7 +177,7 @@ func doObject(db database.ObjectInfo, newS3, oldS3 s3.Interface, skip int) (*Res | ||||
| 		return nil, fmt.Errorf("download object failed %s", downloadResp.Status) | ||||
| 	} | ||||
| 	log.Printf("file size %d", obj.Size) | ||||
| 	request, err := http.NewRequest(http.MethodPut, putURL, downloadResp.Body) | ||||
| 	request, err := http.NewRequest(http.MethodPut, putURL.URL, downloadResp.Body) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user