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

406 lines
10 KiB
Protocol Buffer
Raw Normal View History

2021-05-26 20:06:02 +08:00
syntax = "proto3";
2022-09-20 23:31:28 +08:00
import "Open-IM-Server/pkg/proto/sdk_ws/ws.proto";
import "Open-IM-Server/pkg/proto/sdk_ws/wrappers.proto";
2022-09-21 08:36:33 +08:00
option go_package = "Open_IM/pkg/proto/group;group";
2021-05-26 20:06:02 +08:00
package group;
2021-12-23 17:22:49 +08:00
message GroupAddMemberInfo{
2023-01-05 17:09:35 +08:00
string userID = 1;
int32 roleLevel = 2;
2021-06-28 15:33:26 +08:00
}
2021-12-21 21:40:50 +08:00
2021-12-23 17:22:49 +08:00
message CreateGroupReq{
2023-01-05 17:09:35 +08:00
repeated GroupAddMemberInfo initMemberList = 1;
server_api_params.GroupInfo groupInfo = 2;
string operationID = 3;
string opUserID = 4; //app manager or group owner
string ownerUserID = 5; //owner
2022-02-11 18:49:17 +08:00
2021-05-26 20:06:02 +08:00
}
message CreateGroupResp{
2023-01-05 17:09:35 +08:00
server_api_params.CommonResp commonResp = 1;
server_api_params.GroupInfo groupInfo = 3;
2021-05-26 20:06:02 +08:00
}
2021-12-26 18:47:11 +08:00
2021-06-28 15:33:26 +08:00
message GetGroupsInfoReq{
2023-01-05 17:09:35 +08:00
repeated string groupIDList = 1;
string operationID = 2;
string opUserID = 3; //No verification permission
2021-05-26 20:06:02 +08:00
}
2021-06-28 15:33:26 +08:00
message GetGroupsInfoResp{
2023-01-05 17:09:35 +08:00
server_api_params.CommonResp commonResp = 1;
repeated server_api_params.GroupInfo groupInfoList = 3;
2021-05-26 20:06:02 +08:00
}
2021-12-23 17:22:49 +08:00
2021-06-28 15:33:26 +08:00
message SetGroupInfoReq{
2022-06-28 20:39:27 +08:00
server_api_params.GroupInfoForSet groupInfoForSet = 1;
2023-01-05 17:09:35 +08:00
string opUserID = 2; //app manager or group owner
string operationID = 3;
2021-06-28 15:33:26 +08:00
}
2021-12-26 18:47:11 +08:00
message SetGroupInfoResp{
2023-01-05 15:45:21 +08:00
server_api_params.CommonResp commonResp = 1;
2021-12-26 18:47:11 +08:00
}
2021-06-28 15:33:26 +08:00
2021-12-23 18:29:39 +08:00
2021-06-28 15:33:26 +08:00
message GetGroupApplicationListReq {
2023-01-05 17:09:35 +08:00
string opUserID = 1; //app manager or group owner(manager)
string operationID = 2;
string fromUserID = 3; //owner or manager
2021-05-26 20:06:02 +08:00
}
2021-06-28 15:33:26 +08:00
message GetGroupApplicationListResp {
2023-01-05 17:09:35 +08:00
server_api_params.CommonResp commonResp = 1;
repeated server_api_params.GroupRequest groupRequestList = 3;
2021-06-28 15:33:26 +08:00
}
2021-05-26 20:06:02 +08:00
2022-02-09 19:20:46 +08:00
message GetUserReqApplicationListReq{
2023-01-05 17:09:35 +08:00
string userID = 1;
string opUserID = 2;
string operationID = 3;
2022-02-09 19:20:46 +08:00
}
message GetUserReqApplicationListResp{
2023-01-05 15:45:21 +08:00
server_api_params.CommonResp commonResp = 1;
2023-01-05 17:09:35 +08:00
repeated server_api_params.GroupRequest groupRequestList = 2;
2022-02-09 19:20:46 +08:00
}
2021-12-26 18:47:11 +08:00
2021-06-28 15:33:26 +08:00
message TransferGroupOwnerReq {
2023-01-05 17:09:35 +08:00
string groupID = 1;
string oldOwnerUserID = 2;
string newOwnerUserID = 3;
string operationID = 4;
string opUserID = 5; //app manager or group owner
2021-05-26 20:06:02 +08:00
}
2021-12-26 18:47:11 +08:00
message TransferGroupOwnerResp{
2023-01-05 15:45:21 +08:00
server_api_params.CommonResp commonResp = 1;
2021-12-26 18:47:11 +08:00
}
2021-05-26 20:06:02 +08:00
2021-06-28 15:33:26 +08:00
message JoinGroupReq{
2023-01-05 17:09:35 +08:00
string groupID = 1;
string reqMessage = 2;
string opUserID = 3;
string operationID = 4;
int32 joinSource = 5;
string inviterUserID = 6;
2022-07-12 19:24:06 +08:00
2021-05-26 20:06:02 +08:00
}
2021-12-26 18:47:11 +08:00
message JoinGroupResp{
2023-01-05 15:45:21 +08:00
server_api_params.CommonResp commonResp = 1;
2021-12-26 18:47:11 +08:00
}
2021-05-26 20:06:02 +08:00
2021-06-28 15:33:26 +08:00
message GroupApplicationResponseReq{
2023-01-05 17:09:35 +08:00
string operationID = 1;
string opUserID = 2;
string groupID = 3;
string fromUserID = 4; //
string handledMsg = 5;
int32 handleResult = 6;
2021-06-28 15:33:26 +08:00
}
2021-12-26 18:47:11 +08:00
message GroupApplicationResponseResp{
2023-01-05 15:45:21 +08:00
server_api_params.CommonResp commonResp = 1;
2021-05-26 20:06:02 +08:00
}
2021-12-26 18:47:11 +08:00
2021-06-28 15:33:26 +08:00
message QuitGroupReq{
2023-01-05 17:09:35 +08:00
string groupID = 1;
string operationID = 2;
string opUserID = 3;
2021-05-26 20:06:02 +08:00
}
2021-12-26 18:47:11 +08:00
message QuitGroupResp{
2023-01-05 15:45:21 +08:00
server_api_params.CommonResp commonResp = 1;
2021-12-26 18:47:11 +08:00
}
2021-05-26 20:06:02 +08:00
2021-06-28 15:33:26 +08:00
message GetGroupMemberListReq {
2023-01-05 17:09:35 +08:00
string groupID = 1;
string opUserID = 2; //No verification permission
string operationID = 3;
int32 filter = 4;
int32 nextSeq = 5;
2021-06-28 15:33:26 +08:00
}
message GetGroupMemberListResp {
2023-01-05 17:09:35 +08:00
server_api_params.CommonResp commonResp = 1;
2022-01-15 15:25:12 +08:00
repeated server_api_params.GroupMemberFullInfo memberList = 3;
2021-09-06 17:48:14 +08:00
int32 nextSeq = 4;
2021-06-28 15:33:26 +08:00
}
message GetGroupMembersInfoReq {
2023-01-05 17:09:35 +08:00
string groupID = 1;
2021-09-06 17:48:14 +08:00
repeated string memberList = 2;
2023-01-05 17:09:35 +08:00
string opUserID = 3; //No verification permission
string operationID = 4;
2021-05-26 20:06:02 +08:00
}
2021-06-28 15:33:26 +08:00
message GetGroupMembersInfoResp {
2023-01-05 17:09:35 +08:00
server_api_params.CommonResp commonResp = 1;
2022-01-15 15:25:12 +08:00
repeated server_api_params.GroupMemberFullInfo memberList = 3;
2021-06-28 15:33:26 +08:00
}
2021-05-26 20:06:02 +08:00
2021-06-28 15:33:26 +08:00
message KickGroupMemberReq {
2023-01-05 17:09:35 +08:00
string groupID = 1;
repeated string kickedUserIDList = 2;
string reason = 3;
string operationID = 5;
string opUserID = 6; //app manger or group manager
2021-06-28 15:33:26 +08:00
}
message Id2Result {
2023-01-05 17:09:35 +08:00
string userID = 1;
int32 result = 2; //0 ok; -1 error
2021-05-26 20:06:02 +08:00
}
2021-06-28 15:33:26 +08:00
message KickGroupMemberResp {
2023-01-05 17:09:35 +08:00
server_api_params.CommonResp commonResp = 1;
repeated Id2Result id2ResultList = 3;
2021-06-28 15:33:26 +08:00
}
2021-05-26 20:06:02 +08:00
2021-12-23 17:22:49 +08:00
message GetJoinedGroupListReq {
2023-01-05 17:09:35 +08:00
string fromUserID = 1;
2021-09-06 17:48:14 +08:00
string operationID = 2;
2023-01-05 17:09:35 +08:00
string opUserID = 3; //app manager or FromUserID
2021-06-28 15:33:26 +08:00
}
2021-12-23 17:22:49 +08:00
message GetJoinedGroupListResp{
2023-01-05 17:09:35 +08:00
server_api_params.CommonResp commonResp = 1;
repeated server_api_params.GroupInfo groupList = 3;
2021-06-28 15:33:26 +08:00
}
2021-12-23 17:22:49 +08:00
message InviteUserToGroupReq {
2023-01-05 17:09:35 +08:00
string operationID = 2;
string groupID = 3;
string reason = 4;
repeated string invitedUserIDList = 5;
string opUserID = 6; //group member or app manager
2021-06-28 15:33:26 +08:00
}
2021-12-23 17:22:49 +08:00
message InviteUserToGroupResp {
2023-01-05 17:09:35 +08:00
server_api_params.CommonResp commonResp = 1;
repeated Id2Result id2ResultList = 3; // 0 ok, -1 error
2021-06-28 15:33:26 +08:00
}
2021-12-23 17:22:49 +08:00
2021-06-28 15:33:26 +08:00
message GetGroupAllMemberReq {
2023-01-05 17:09:35 +08:00
string groupID = 1;
string opUserID = 2; //No verification permission
string operationID = 3;
int32 offset = 4;
int32 count = 5;
2021-06-28 15:33:26 +08:00
}
message GetGroupAllMemberResp {
2023-01-05 17:09:35 +08:00
server_api_params.CommonResp commonResp = 1;
2022-01-15 15:25:12 +08:00
repeated server_api_params.GroupMemberFullInfo memberList = 3;
2021-06-28 15:33:26 +08:00
}
2022-02-07 19:42:09 +08:00
message CMSGroup {
2023-01-05 17:09:35 +08:00
server_api_params.GroupInfo groupInfo = 1;
string groupOwnerUserName = 2;
string groupOwnerUserID = 3;
2022-02-07 19:42:09 +08:00
}
2022-01-25 19:18:04 +08:00
message GetGroupsReq {
2023-01-05 17:09:35 +08:00
server_api_params.RequestPagination pagination = 1;
string groupName = 2;
string groupID = 3;
string operationID = 4;
2022-01-25 19:18:04 +08:00
}
message GetGroupsResp {
2023-01-05 17:09:35 +08:00
repeated CMSGroup groups = 1;
server_api_params.ResponsePagination pagination = 2;
2022-01-27 01:08:02 +08:00
int32 GroupNum = 3;
2023-01-05 15:45:21 +08:00
server_api_params.CommonResp commonResp = 4;
2022-01-25 19:18:04 +08:00
}
message GetGroupMemberReq {
2023-01-05 17:09:35 +08:00
string groupID = 1;
string operationID = 2;
2022-01-25 19:18:04 +08:00
}
2021-06-28 15:33:26 +08:00
2022-02-07 19:42:09 +08:00
message GetGroupMembersCMSReq {
2023-01-05 17:09:35 +08:00
string groupID = 1;
string userName = 2;
server_api_params.RequestPagination pagination = 3;
string operationID = 4;
2022-02-07 19:42:09 +08:00
}
message GetGroupMembersCMSResp {
2022-02-08 20:24:59 +08:00
repeated server_api_params.GroupMemberFullInfo members = 1;
2023-01-05 17:09:35 +08:00
server_api_params.ResponsePagination pagination = 2;
int32 memberNums = 3;
2023-01-05 15:45:21 +08:00
server_api_params.CommonResp commonResp = 4;
2022-01-27 18:31:31 +08:00
}
2022-03-24 15:33:30 +08:00
message DismissGroupReq{
2022-03-28 19:27:05 +08:00
string opUserID = 1; //group or app manager
2022-03-24 15:33:30 +08:00
string operationID = 2;
string groupID = 3;
}
message DismissGroupResp{
2023-01-05 15:45:21 +08:00
server_api_params.CommonResp commonResp = 1;
2022-03-24 15:33:30 +08:00
}
2022-02-08 20:24:59 +08:00
2022-03-28 19:27:05 +08:00
message MuteGroupMemberReq{
string opUserID = 1; //group or app manager
string operationID = 2;
string groupID = 3;
string userID = 4;
uint32 mutedSeconds = 5;
}
message MuteGroupMemberResp{
2023-01-05 15:45:21 +08:00
server_api_params.CommonResp commonResp = 1;
2022-03-28 19:27:05 +08:00
}
message CancelMuteGroupMemberReq{
string opUserID = 1; //group or app manager
string operationID = 2;
string groupID = 3;
string userID = 4;
}
message CancelMuteGroupMemberResp{
2023-01-05 15:45:21 +08:00
server_api_params.CommonResp commonResp = 1;
2022-03-28 19:27:05 +08:00
}
message MuteGroupReq{
string opUserID = 1; //group or app manager
string operationID = 2;
string groupID = 3;
}
message MuteGroupResp{
2023-01-05 15:45:21 +08:00
server_api_params.CommonResp commonResp = 1;
2022-03-28 19:27:05 +08:00
}
message CancelMuteGroupReq{
string opUserID = 1; //group or app manager
string operationID = 2;
string groupID = 3;
}
message CancelMuteGroupResp{
2023-01-05 15:45:21 +08:00
server_api_params.CommonResp commonResp = 1;
2022-03-28 19:27:05 +08:00
}
2022-04-18 11:52:17 +08:00
message SetGroupMemberNicknameReq{
string groupID = 1;
string nickname = 2;
string opUserID = 3;
string operationID = 4;
string userID = 5;
}
message SetGroupMemberNicknameResp{
2023-01-05 15:45:21 +08:00
server_api_params.CommonResp commonResp = 1;
2022-04-18 11:52:17 +08:00
}
2022-05-30 11:55:27 +08:00
message GetJoinedSuperGroupListReq {
string operationID = 1;
string userID = 2;
string opUserID = 3;
}
2022-04-18 11:52:17 +08:00
2022-05-30 11:55:27 +08:00
message GetJoinedSuperGroupListResp {
2023-01-05 15:45:21 +08:00
server_api_params.CommonResp commonResp = 1;
2023-01-05 17:09:35 +08:00
repeated server_api_params.GroupInfo groupList = 3;
2022-05-30 11:55:27 +08:00
}
2022-04-18 11:52:17 +08:00
2022-05-30 16:23:15 +08:00
message GetSuperGroupsInfoReq {
2023-01-05 17:09:35 +08:00
repeated string groupIDList = 1;
string operationID = 2;
string opUserID = 3; //No verification permission
2022-05-30 16:23:15 +08:00
}
message GetSuperGroupsInfoResp {
2023-01-05 15:45:21 +08:00
server_api_params.CommonResp commonResp = 1;
2023-01-05 17:09:35 +08:00
repeated server_api_params.GroupInfo groupInfoList = 3;
2022-05-30 16:23:15 +08:00
}
2022-03-28 19:27:05 +08:00
2022-06-02 18:17:11 +08:00
message SetGroupMemberInfoReq{
string groupID = 1;
string userID = 2;
2022-06-07 16:18:18 +08:00
string opUserID = 3;
string operationID = 4;
google.protobuf.StringValue nickname = 5;
google.protobuf.StringValue faceURL = 6;
google.protobuf.Int32Value roleLevel = 7;
google.protobuf.StringValue ex = 8;
2022-06-02 18:17:11 +08:00
}
2022-04-18 11:52:17 +08:00
2022-06-02 18:17:11 +08:00
message SetGroupMemberInfoResp{
2023-01-05 15:45:21 +08:00
server_api_params.CommonResp commonResp = 1;
2022-06-02 18:17:11 +08:00
}
2022-03-28 19:27:05 +08:00
2022-08-05 13:40:20 +08:00
message GetGroupAbstractInfoReq{
string groupID = 1;
string opUserID = 2;
string operationID = 3;
}
message GetGroupAbstractInfoResp{
2023-01-05 15:45:21 +08:00
server_api_params.CommonResp commonResp = 1;
2022-08-05 13:40:20 +08:00
int32 groupMemberNumber = 2;
uint64 groupMemberListHash = 3;
}
2021-06-28 15:33:26 +08:00
service group{
2021-09-06 17:48:14 +08:00
rpc createGroup(CreateGroupReq) returns(CreateGroupResp);
2021-12-26 18:47:11 +08:00
rpc joinGroup(JoinGroupReq) returns(JoinGroupResp);
rpc quitGroup(QuitGroupReq) returns(QuitGroupResp);
2021-09-06 17:48:14 +08:00
rpc getGroupsInfo(GetGroupsInfoReq) returns(GetGroupsInfoResp);
2021-12-26 18:47:11 +08:00
rpc setGroupInfo(SetGroupInfoReq) returns(SetGroupInfoResp);
2021-09-06 17:48:14 +08:00
rpc getGroupApplicationList(GetGroupApplicationListReq) returns(GetGroupApplicationListResp);
2022-02-09 19:20:46 +08:00
rpc getUserReqApplicationList(GetUserReqApplicationListReq) returns(GetUserReqApplicationListResp);
2021-12-26 18:47:11 +08:00
rpc transferGroupOwner(TransferGroupOwnerReq) returns(TransferGroupOwnerResp);
rpc groupApplicationResponse(GroupApplicationResponseReq) returns(GroupApplicationResponseResp);
2021-09-06 17:48:14 +08:00
rpc getGroupMemberList(GetGroupMemberListReq) returns(GetGroupMemberListResp);
rpc getGroupMembersInfo(GetGroupMembersInfoReq) returns(GetGroupMembersInfoResp);
rpc kickGroupMember(KickGroupMemberReq) returns (KickGroupMemberResp);
2021-12-23 17:22:49 +08:00
rpc getJoinedGroupList(GetJoinedGroupListReq) returns (GetJoinedGroupListResp);
rpc inviteUserToGroup(InviteUserToGroupReq) returns (InviteUserToGroupResp);
2021-09-06 17:48:14 +08:00
rpc getGroupAllMember(GetGroupAllMemberReq) returns(GetGroupAllMemberResp);
2022-01-25 19:18:04 +08:00
rpc GetGroups(GetGroupsReq) returns(GetGroupsResp);
2022-02-07 19:42:09 +08:00
rpc GetGroupMembersCMS(GetGroupMembersCMSReq) returns(GetGroupMembersCMSResp);
2022-08-30 01:38:23 +08:00
2022-03-24 15:33:30 +08:00
rpc DismissGroup(DismissGroupReq) returns(DismissGroupResp);
2022-03-28 19:27:05 +08:00
rpc MuteGroupMember(MuteGroupMemberReq) returns(MuteGroupMemberResp);
rpc CancelMuteGroupMember(CancelMuteGroupMemberReq) returns(CancelMuteGroupMemberResp);
rpc MuteGroup(MuteGroupReq) returns(MuteGroupResp);
rpc CancelMuteGroup(CancelMuteGroupReq) returns(CancelMuteGroupResp);
2022-04-18 11:52:17 +08:00
rpc SetGroupMemberNickname(SetGroupMemberNicknameReq) returns (SetGroupMemberNicknameResp);
2022-05-30 11:55:27 +08:00
rpc GetJoinedSuperGroupList(GetJoinedSuperGroupListReq) returns (GetJoinedSuperGroupListResp);
2022-05-30 16:23:15 +08:00
rpc GetSuperGroupsInfo(GetSuperGroupsInfoReq) returns (GetSuperGroupsInfoResp);
2022-06-02 18:17:11 +08:00
rpc SetGroupMemberInfo(SetGroupMemberInfoReq) returns (SetGroupMemberInfoResp);
2022-08-05 13:40:20 +08:00
rpc GetGroupAbstractInfo(GetGroupAbstractInfoReq) returns (GetGroupAbstractInfoResp);
2021-06-28 15:33:26 +08:00
}
2021-05-26 20:06:02 +08:00