Files
open-im-server/pkg/proto/group/group.proto
T

391 lines
8.5 KiB
Protocol Buffer
Raw Normal View History

2023-06-29 22:35:31 +08:00
syntax = "proto3";
2023-06-30 09:45:02 +08:00
package OpenIMServer.group;
import "sdkws/sdkws.proto";
import "wrapperspb/wrapperspb.proto";
option go_package = "github.com/OpenIMSDK/Open-IM-Server/pkg/proto/group";
2023-06-29 22:35:31 +08:00
message CreateGroupReq{
2023-06-30 09:45:02 +08:00
repeated string memberUserIDs = 1;
sdkws.GroupInfo groupInfo = 2;
repeated string adminUserIDs = 3;
string ownerUserID = 4; //owner
2023-06-29 22:35:31 +08:00
}
message CreateGroupResp{
2023-06-30 09:45:02 +08:00
sdkws.GroupInfo groupInfo = 1;
2023-06-29 22:35:31 +08:00
}
message GetGroupsInfoReq{
2023-06-30 09:45:02 +08:00
repeated string groupIDs = 1;
2023-06-29 22:35:31 +08:00
}
message GetGroupsInfoResp{
2023-06-30 09:45:02 +08:00
repeated sdkws.GroupInfo groupInfos = 1;
2023-06-29 22:35:31 +08:00
}
message SetGroupInfoReq{
2023-06-30 09:45:02 +08:00
sdkws.GroupInfoForSet groupInfoForSet = 1;
2023-06-29 22:35:31 +08:00
}
message SetGroupInfoResp{
}
message GetGroupApplicationListReq {
2023-06-30 09:45:02 +08:00
sdkws.RequestPagination pagination = 1;
string fromUserID = 2; //owner or admin
2023-06-29 22:35:31 +08:00
}
message GetGroupApplicationListResp {
2023-06-30 09:45:02 +08:00
uint32 total = 1;
repeated sdkws.GroupRequest groupRequests = 2;
2023-06-29 22:35:31 +08:00
}
message GetUserReqApplicationListReq{
2023-06-30 09:45:02 +08:00
sdkws.RequestPagination pagination = 1;
string userID = 2;
2023-06-29 22:35:31 +08:00
}
message GetUserReqApplicationListResp{
2023-06-30 09:45:02 +08:00
uint32 total = 1;
repeated sdkws.GroupRequest groupRequests = 2;
2023-06-29 22:35:31 +08:00
}
message TransferGroupOwnerReq {
2023-06-30 09:45:02 +08:00
string groupID = 1;
string oldOwnerUserID = 2;
string newOwnerUserID = 3;
2023-06-29 22:35:31 +08:00
}
message TransferGroupOwnerResp{
2023-06-30 09:45:02 +08:00
2023-06-29 22:35:31 +08:00
}
message JoinGroupReq{
2023-06-30 09:45:02 +08:00
string groupID = 1;
string reqMessage = 2;
int32 joinSource = 3;
string inviterUserID = 4;
2023-06-29 22:35:31 +08:00
}
message JoinGroupResp{
}
message GroupApplicationResponseReq{
2023-06-30 09:45:02 +08:00
string groupID = 1;
string fromUserID = 2; //
string handledMsg = 3;
int32 handleResult = 4;
2023-06-29 22:35:31 +08:00
}
message GroupApplicationResponseResp{
2023-06-30 09:45:02 +08:00
2023-06-29 22:35:31 +08:00
}
message QuitGroupReq{
2023-06-30 09:45:02 +08:00
string groupID = 1;
2023-06-29 22:35:31 +08:00
}
message QuitGroupResp{
}
message GetGroupMemberListReq {
2023-06-30 09:45:02 +08:00
sdkws.RequestPagination pagination = 1;
string groupID = 2;
int32 filter = 3;
2023-06-29 22:35:31 +08:00
}
message GetGroupMemberListResp {
2023-06-30 09:45:02 +08:00
uint32 total = 1;
repeated sdkws.GroupMemberFullInfo members = 2;
2023-06-29 22:35:31 +08:00
}
message GetGroupMembersInfoReq {
2023-06-30 09:45:02 +08:00
string groupID = 1;
repeated string userIDs = 2;
2023-06-29 22:35:31 +08:00
}
message GetGroupMembersInfoResp {
2023-06-30 09:45:02 +08:00
repeated sdkws.GroupMemberFullInfo members = 1;
2023-06-29 22:35:31 +08:00
}
message KickGroupMemberReq {
2023-06-30 09:45:02 +08:00
string groupID = 1;
repeated string kickedUserIDs = 2;
string reason = 3;
2023-06-29 22:35:31 +08:00
}
message KickGroupMemberResp {
2023-06-30 09:45:02 +08:00
2023-06-29 22:35:31 +08:00
}
message GetJoinedGroupListReq {
2023-06-30 09:45:02 +08:00
sdkws.RequestPagination pagination = 1;
string fromUserID = 2;
2023-06-29 22:35:31 +08:00
}
message GetJoinedGroupListResp{
2023-06-30 09:45:02 +08:00
uint32 total = 1;
repeated sdkws.GroupInfo groups = 2;
2023-06-29 22:35:31 +08:00
}
message InviteUserToGroupReq {
2023-06-30 09:45:02 +08:00
string groupID = 1;
string reason = 2;
repeated string invitedUserIDs = 3;
2023-06-29 22:35:31 +08:00
}
message InviteUserToGroupResp {
2023-06-30 09:45:02 +08:00
2023-06-29 22:35:31 +08:00
}
message GetGroupAllMemberReq {
2023-06-30 09:45:02 +08:00
sdkws.RequestPagination pagination = 1;
string groupID = 2;
2023-06-29 22:35:31 +08:00
}
message GetGroupAllMemberResp {
2023-06-30 09:45:02 +08:00
repeated sdkws.GroupMemberFullInfo members = 1;
2023-06-29 22:35:31 +08:00
}
message CMSGroup {
2023-06-30 09:45:02 +08:00
sdkws.GroupInfo groupInfo = 1;
string groupOwnerUserName = 2;
string groupOwnerUserID = 3;
2023-06-29 22:35:31 +08:00
}
message GetGroupsReq {
2023-06-30 09:45:02 +08:00
sdkws.RequestPagination pagination = 1;
string groupName = 2;
string groupID = 3;
2023-06-29 22:35:31 +08:00
}
message GetGroupsResp {
2023-06-30 09:45:02 +08:00
uint32 total = 1;
repeated CMSGroup groups = 2;
2023-06-29 22:35:31 +08:00
}
message GetGroupMemberReq {
2023-06-30 09:45:02 +08:00
string groupID = 1;
2023-06-29 22:35:31 +08:00
}
2023-06-30 09:45:02 +08:00
message GetGroupMembersCMSReq {
sdkws.RequestPagination pagination = 1;
string groupID = 2;
string userName = 3;
2023-06-29 22:35:31 +08:00
}
2023-06-30 09:45:02 +08:00
message GetGroupMembersCMSResp {
uint32 total = 1;
repeated sdkws.GroupMemberFullInfo members = 2;
}
2023-06-29 22:35:31 +08:00
2023-06-30 09:45:02 +08:00
message DismissGroupReq{
string groupID = 1;
bool deleteMember = 2;
2023-06-29 22:35:31 +08:00
}
2023-06-30 09:45:02 +08:00
message DismissGroupResp{
2023-06-29 22:35:31 +08:00
}
2023-06-30 09:45:02 +08:00
message MuteGroupMemberReq{
string groupID = 1;
string userID = 2;
uint32 mutedSeconds = 3;
2023-06-29 22:35:31 +08:00
}
2023-06-30 09:45:02 +08:00
message MuteGroupMemberResp{
2023-06-29 22:35:31 +08:00
}
2023-06-30 09:45:02 +08:00
message CancelMuteGroupMemberReq{
string groupID = 1;
string userID = 2;
2023-06-29 22:35:31 +08:00
}
2023-06-30 09:45:02 +08:00
message CancelMuteGroupMemberResp{
2023-06-29 22:35:31 +08:00
}
2023-06-30 09:45:02 +08:00
message MuteGroupReq{
string groupID = 1;
2023-06-29 22:35:31 +08:00
}
2023-06-30 09:45:02 +08:00
message MuteGroupResp{
2023-06-29 22:35:31 +08:00
}
2023-06-30 09:45:02 +08:00
message CancelMuteGroupReq{
string groupID = 1;
2023-06-29 22:35:31 +08:00
}
2023-06-30 09:45:02 +08:00
message CancelMuteGroupResp{
2023-06-29 22:35:31 +08:00
}
2023-06-30 09:45:02 +08:00
message GetJoinedSuperGroupListReq {
string userID = 1;
2023-06-29 22:35:31 +08:00
}
2023-06-30 09:45:02 +08:00
message GetJoinedSuperGroupListResp {
repeated sdkws.GroupInfo groups = 1;
2023-06-29 22:35:31 +08:00
}
2023-06-30 09:45:02 +08:00
message GetSuperGroupsInfoReq {
repeated string groupIDs = 1;
}
2023-06-29 22:35:31 +08:00
2023-06-30 09:45:02 +08:00
message GetSuperGroupsInfoResp {
repeated sdkws.GroupInfo groupInfos = 1;
2023-06-29 22:35:31 +08:00
}
2023-06-30 09:45:02 +08:00
message SetGroupMemberInfo{
string groupID = 1;
string userID = 2;
OpenIMServer.protobuf.StringValue nickname = 3;
OpenIMServer.protobuf.StringValue faceURL = 4;
OpenIMServer.protobuf.Int32Value roleLevel = 5;
OpenIMServer.protobuf.StringValue ex = 6;
2023-06-29 22:35:31 +08:00
}
2023-06-30 09:45:02 +08:00
message SetGroupMemberInfoReq{
repeated SetGroupMemberInfo members = 1;
}
2023-06-29 22:35:31 +08:00
2023-06-30 09:45:02 +08:00
message SetGroupMemberInfoResp{
2023-06-29 22:35:31 +08:00
}
2023-06-30 09:45:02 +08:00
message GetGroupAbstractInfoReq{
repeated string groupIDs = 1;
2023-06-29 22:35:31 +08:00
}
2023-06-30 09:45:02 +08:00
message GroupAbstractInfo{
string groupID = 1;
uint32 groupMemberNumber = 2;
uint64 groupMemberListHash = 3;
2023-06-29 22:35:31 +08:00
}
2023-06-30 09:45:02 +08:00
message GetGroupAbstractInfoResp{
repeated GroupAbstractInfo groupAbstractInfos = 1;
2023-06-29 22:35:31 +08:00
}
2023-06-30 09:45:02 +08:00
message GetUserInGroupMembersReq {
string userID = 1;
repeated string groupIDs = 2;
}
2023-06-29 22:35:31 +08:00
2023-06-30 09:45:02 +08:00
message GetUserInGroupMembersResp{
repeated sdkws.GroupMemberFullInfo members = 1;
2023-06-29 22:35:31 +08:00
}
2023-06-30 09:45:02 +08:00
message GetGroupMemberUserIDsReq{
string groupID = 1;
2023-06-29 22:35:31 +08:00
}
2023-06-30 09:45:02 +08:00
message GetGroupMemberUserIDsResp{
repeated string userIDs = 1;
}
2023-06-29 22:35:31 +08:00
2023-06-30 09:45:02 +08:00
message GetGroupMemberRoleLevelReq{
string groupID = 1;
repeated int32 roleLevels = 2;
}
2023-06-29 22:35:31 +08:00
2023-06-30 09:45:02 +08:00
message GetGroupMemberRoleLevelResp {
repeated sdkws.GroupMemberFullInfo members = 1;
}
2023-06-29 22:35:31 +08:00
2023-06-30 09:45:02 +08:00
message GetGroupInfoCacheReq {
2022-04-18 11:52:17 +08:00
string groupID = 1;
}
2023-06-30 09:45:02 +08:00
message GetGroupInfoCacheResp {
sdkws.GroupInfo groupInfo = 1;
}
2022-04-18 11:52:17 +08:00
2023-06-30 09:45:02 +08:00
message GetGroupMemberCacheReq {
string groupID = 1;
string groupMemberID = 2;
}
2022-04-18 11:52:17 +08:00
2023-06-30 09:45:02 +08:00
message GetGroupMemberCacheResp {
sdkws.GroupMemberFullInfo member = 1;
}
2023-06-29 22:35:31 +08:00
service group{
2023-06-30 09:45:02 +08:00
//创建群
2023-06-29 22:35:31 +08:00
rpc createGroup(CreateGroupReq) returns(CreateGroupResp);
2023-06-30 09:45:02 +08:00
//申请加群
2023-06-29 22:35:31 +08:00
rpc joinGroup(JoinGroupReq) returns(JoinGroupResp);
2023-06-30 09:45:02 +08:00
//退出群
2023-06-29 22:35:31 +08:00
rpc quitGroup(QuitGroupReq) returns(QuitGroupResp);
2023-06-30 09:45:02 +08:00
//获取指定群信息
2023-06-29 22:35:31 +08:00
rpc getGroupsInfo(GetGroupsInfoReq) returns(GetGroupsInfoResp);
2023-06-30 09:45:02 +08:00
//设置群信息
2023-06-29 22:35:31 +08:00
rpc setGroupInfo(SetGroupInfoReq) returns(SetGroupInfoResp);
2023-06-30 09:45:02 +08:00
//(以管理员或群主身份)获取群的加群申请
2023-06-29 22:35:31 +08:00
rpc getGroupApplicationList(GetGroupApplicationListReq) returns(GetGroupApplicationListResp);
2023-06-30 09:45:02 +08:00
//获取用户自己的主动加群申请
2023-06-29 22:35:31 +08:00
rpc getUserReqApplicationList(GetUserReqApplicationListReq) returns(GetUserReqApplicationListResp);
2023-06-30 09:45:02 +08:00
//转让群主
2023-06-29 22:35:31 +08:00
rpc transferGroupOwner(TransferGroupOwnerReq) returns(TransferGroupOwnerResp);
2023-06-30 09:45:02 +08:00
//群主或管理员处理进群申请
2023-06-29 22:35:31 +08:00
rpc groupApplicationResponse(GroupApplicationResponseReq) returns(GroupApplicationResponseResp);
2023-06-30 09:45:02 +08:00
//获取某个群的群成员
2023-06-29 22:35:31 +08:00
rpc getGroupMemberList(GetGroupMemberListReq) returns(GetGroupMemberListResp);
2023-06-30 09:45:02 +08:00
//获取某个群的指定群成员
2023-06-29 22:35:31 +08:00
rpc getGroupMembersInfo(GetGroupMembersInfoReq) returns(GetGroupMembersInfoResp);
2023-06-30 09:45:02 +08:00
//踢出群
2023-06-29 22:35:31 +08:00
rpc kickGroupMember(KickGroupMemberReq) returns (KickGroupMemberResp);
2023-06-30 09:45:02 +08:00
//获取某个人已加入群
2023-06-29 22:35:31 +08:00
rpc getJoinedGroupList(GetJoinedGroupListReq) returns (GetJoinedGroupListResp);
2023-06-30 09:45:02 +08:00
//邀请某些人进群
2023-06-29 22:35:31 +08:00
rpc inviteUserToGroup(InviteUserToGroupReq) returns (InviteUserToGroupResp);
2022-04-18 11:52:17 +08:00
2023-06-30 09:45:02 +08:00
rpc getGroups(GetGroupsReq) returns(GetGroupsResp);
rpc getGroupMembersCMS(GetGroupMembersCMSReq) returns(GetGroupMembersCMSResp);
//解散群
rpc dismissGroup(DismissGroupReq) returns(DismissGroupResp);
//对某个群成员禁言
rpc muteGroupMember(MuteGroupMemberReq) returns(MuteGroupMemberResp);
//对某个群成员取消禁言
rpc cancelMuteGroupMember(CancelMuteGroupMemberReq) returns(CancelMuteGroupMemberResp);
//对某个群禁言
rpc muteGroup(MuteGroupReq) returns(MuteGroupResp);
//对某个群取消禁言
rpc cancelMuteGroup(CancelMuteGroupReq) returns(CancelMuteGroupResp);
//获取某个用户加入的超级群
rpc getJoinedSuperGroupList(GetJoinedSuperGroupListReq) returns (GetJoinedSuperGroupListResp);
//获取指定的超级群信息
rpc getSuperGroupsInfo(GetSuperGroupsInfoReq) returns (GetSuperGroupsInfoResp);
//设置群成员昵称
//设置群成员信息
rpc setGroupMemberInfo(SetGroupMemberInfoReq) returns (SetGroupMemberInfoResp);
//获取群信息hash值
rpc getGroupAbstractInfo(GetGroupAbstractInfoReq) returns (GetGroupAbstractInfoResp);
//获取某个用户在指定群中的信息
rpc getUserInGroupMembers(GetUserInGroupMembersReq) returns (GetUserInGroupMembersResp);
//获取群成员用户ID
rpc getGroupMemberUserIDs(GetGroupMemberUserIDsReq) returns (GetGroupMemberUserIDsResp);
//查询群组中对应级别的成员
rpc GetGroupMemberRoleLevel(GetGroupMemberRoleLevelReq)returns (GetGroupMemberRoleLevelResp);
rpc GetGroupInfoCache(GetGroupInfoCacheReq) returns (GetGroupInfoCacheResp);
rpc GetGroupMemberCache(GetGroupMemberCacheReq) returns (GetGroupMemberCacheResp);
2023-06-29 22:35:31 +08:00
}
2023-06-30 22:32:30 +08:00