mirror of
https://github.com/openimsdk/open-im-server.git
synced 2025-04-06 04:15:46 +08:00
add webhooks (#1465)
* add callback before join group * fix bug * fix deployments/templates/alertmanager.yml * fix bug * update callback after join group * merge callback after join group * update callback setrgoup info * test * test * test * update three functions in friend category * test friend and blacklist * test * test * test * Update openim.yaml * merge callback after join group * merge callback after join group * merge callback after join group * fix callbackbeforesetgroupinfo * fix eventtime * update api request required * update api request required * update api request required * delete unused code * delete unused code * fix * Update .env * Update .env * Update callback.go * Update callback.go * Update .env * Update .env * fix: merge * update * fix: merge * fix: fix bugs * update callback enable * update callback enable * update callback enable * update callback enable * update callback enable * update callback enable * Update openim.yaml * Update environment.sh * Update environment.md * Update environment.md * Update environment.sh --------- Co-authored-by: Gordon <1432970085@qq.com>
This commit is contained in:
parent
35bac04f58
commit
0efc235f45
7
.env
7
.env
@ -107,6 +107,9 @@ NODE_EXPORTER_NETWORK_ADDRESS=172.28.0.13
|
|||||||
# Default: OPENIM_ADMIN_NETWORK_ADDRESS=172.28.0.14
|
# Default: OPENIM_ADMIN_NETWORK_ADDRESS=172.28.0.14
|
||||||
OPENIM_ADMIN_FRONT_NETWORK_ADDRESS=172.28.0.14
|
OPENIM_ADMIN_FRONT_NETWORK_ADDRESS=172.28.0.14
|
||||||
|
|
||||||
|
# Address or hostname for the alertmanager network.
|
||||||
|
# Default: ALERT_MANAGER_NETWORK_ADDRESS=172.28.0.14
|
||||||
|
ALERT_MANAGER_NETWORK_ADDRESS=172.28.0.14
|
||||||
# ===============================================
|
# ===============================================
|
||||||
# = Component Extension Configuration =
|
# = Component Extension Configuration =
|
||||||
# ===============================================
|
# ===============================================
|
||||||
@ -306,3 +309,7 @@ GRAFANA_PORT=3000
|
|||||||
# Port for the admin front.
|
# Port for the admin front.
|
||||||
# Default: OPENIM_ADMIN_FRONT_PORT=11002
|
# Default: OPENIM_ADMIN_FRONT_PORT=11002
|
||||||
OPENIM_ADMIN_FRONT_PORT=11002
|
OPENIM_ADMIN_FRONT_PORT=11002
|
||||||
|
|
||||||
|
# Port for the alertmanager.
|
||||||
|
# Default: ALERT_MANAGER_PORT=19093
|
||||||
|
ALERT_MANAGER_PORT=19093
|
||||||
|
@ -23,6 +23,7 @@ func main() {
|
|||||||
msgGatewayCmd.AddWsPortFlag()
|
msgGatewayCmd.AddWsPortFlag()
|
||||||
msgGatewayCmd.AddPortFlag()
|
msgGatewayCmd.AddPortFlag()
|
||||||
msgGatewayCmd.AddPrometheusPortFlag()
|
msgGatewayCmd.AddPrometheusPortFlag()
|
||||||
|
|
||||||
if err := msgGatewayCmd.Exec(); err != nil {
|
if err := msgGatewayCmd.Exec(); err != nil {
|
||||||
panic(err.Error())
|
panic(err.Error())
|
||||||
}
|
}
|
||||||
|
@ -26,7 +26,7 @@ route:
|
|||||||
receivers:
|
receivers:
|
||||||
- name: email
|
- name: email
|
||||||
email_configs:
|
email_configs:
|
||||||
- to: {EMAIL_TO:-'alert@example.com'}
|
- to: '{EMAIL_TO:-'alert@example.com'}'
|
||||||
html: '{{ template "email.to.html" . }}'
|
html: '{{ template "email.to.html" . }}'
|
||||||
headers: { Subject: "[OPENIM-SERVER]Alarm" }
|
headers: { Subject: "[OPENIM-SERVER]Alarm" }
|
||||||
send_resolved: true
|
send_resolved: true
|
||||||
|
@ -375,6 +375,10 @@ callback:
|
|||||||
enable: false
|
enable: false
|
||||||
timeout: 5
|
timeout: 5
|
||||||
failedContinue: true
|
failedContinue: true
|
||||||
|
beforeInviteUserToGroup:
|
||||||
|
enable: true
|
||||||
|
timeout: 5
|
||||||
|
failedContinue: true
|
||||||
beforeSetGroupMemberInfo:
|
beforeSetGroupMemberInfo:
|
||||||
enable: false
|
enable: false
|
||||||
timeout: 5
|
timeout: 5
|
||||||
|
@ -27,7 +27,7 @@ route:
|
|||||||
receivers:
|
receivers:
|
||||||
- name: email
|
- name: email
|
||||||
email_configs:
|
email_configs:
|
||||||
- to: ${ALERTMANAGER_EMAIL_TO}
|
- to: '${ALERTMANAGER_EMAIL_TO}'
|
||||||
html: '{{ template "email.to.html" . }}'
|
html: '{{ template "email.to.html" . }}'
|
||||||
headers: { Subject: "[OPENIM-SERVER]Alarm" }
|
headers: { Subject: "[OPENIM-SERVER]Alarm" }
|
||||||
send_resolved: true
|
send_resolved: true
|
@ -320,7 +320,7 @@ iosPush:
|
|||||||
# Timeout in seconds
|
# Timeout in seconds
|
||||||
# Whether to continue execution if callback fails
|
# Whether to continue execution if callback fails
|
||||||
callback:
|
callback:
|
||||||
url:
|
url: ""
|
||||||
beforeSendSingleMsg:
|
beforeSendSingleMsg:
|
||||||
enable: ${CALLBACK_ENABLE}
|
enable: ${CALLBACK_ENABLE}
|
||||||
timeout: ${CALLBACK_TIMEOUT}
|
timeout: ${CALLBACK_TIMEOUT}
|
||||||
@ -389,6 +389,10 @@ callback:
|
|||||||
enable: ${CALLBACK_ENABLE}
|
enable: ${CALLBACK_ENABLE}
|
||||||
timeout: ${CALLBACK_TIMEOUT}
|
timeout: ${CALLBACK_TIMEOUT}
|
||||||
failedContinue: ${CALLBACK_FAILED_CONTINUE}
|
failedContinue: ${CALLBACK_FAILED_CONTINUE}
|
||||||
|
afterSetGroupMemberInfo:
|
||||||
|
enable: ${CALLBACK_ENABLE}
|
||||||
|
timeout: ${CALLBACK_TIMEOUT}
|
||||||
|
failedContinue: ${CALLBACK_FAILED_CONTINUE}
|
||||||
setMessageReactionExtensions:
|
setMessageReactionExtensions:
|
||||||
enable: ${CALLBACK_ENABLE}
|
enable: ${CALLBACK_ENABLE}
|
||||||
timeout: ${CALLBACK_TIMEOUT}
|
timeout: ${CALLBACK_TIMEOUT}
|
||||||
@ -441,7 +445,66 @@ callback:
|
|||||||
enable: ${CALLBACK_ENABLE}
|
enable: ${CALLBACK_ENABLE}
|
||||||
timeout: ${CALLBACK_TIMEOUT}
|
timeout: ${CALLBACK_TIMEOUT}
|
||||||
failedContinue: ${CALLBACK_FAILED_CONTINUE}
|
failedContinue: ${CALLBACK_FAILED_CONTINUE}
|
||||||
|
afterGroupMsgRead:
|
||||||
|
enable: ${CALLBACK_ENABLE}
|
||||||
|
timeout: ${CALLBACK_TIMEOUT}
|
||||||
|
failedContinue: ${CALLBACK_FAILED_CONTINUE}
|
||||||
|
afterGroupMsgRevoke:
|
||||||
|
enable: ${CALLBACK_ENABLE}
|
||||||
|
timeout: ${CALLBACK_TIMEOUT}
|
||||||
|
failedContinue: ${CALLBACK_FAILED_CONTINUE}
|
||||||
|
afterJoinGroup:
|
||||||
|
enable: ${CALLBACK_ENABLE}
|
||||||
|
timeout: ${CALLBACK_TIMEOUT}
|
||||||
|
failedContinue: ${CALLBACK_FAILED_CONTINUE}
|
||||||
|
beforeInviteUserToGroup:
|
||||||
|
enable: ${CALLBACK_ENABLE}
|
||||||
|
timeout: ${CALLBACK_TIMEOUT}
|
||||||
|
failedContinue: ${CALLBACK_FAILED_CONTINUE}
|
||||||
|
joinGroupAfter:
|
||||||
|
enable: ${CALLBACK_ENABLE}
|
||||||
|
timeout: ${CALLBACK_TIMEOUT}
|
||||||
|
failedContinue: ${CALLBACK_FAILED_CONTINUE}
|
||||||
|
setGroupInfoAfter:
|
||||||
|
enable: ${CALLBACK_ENABLE}
|
||||||
|
timeout: ${CALLBACK_TIMEOUT}
|
||||||
|
failedContinue: ${CALLBACK_FAILED_CONTINUE}
|
||||||
|
setGroupInfoBefore:
|
||||||
|
enable: ${CALLBACK_ENABLE}
|
||||||
|
timeout: ${CALLBACK_TIMEOUT}
|
||||||
|
failedContinue: ${CALLBACK_FAILED_CONTINUE}
|
||||||
|
revokeMsgAfter:
|
||||||
|
enable: ${CALLBACK_ENABLE}
|
||||||
|
timeout: ${CALLBACK_TIMEOUT}
|
||||||
|
failedContinue: ${CALLBACK_FAILED_CONTINUE}
|
||||||
|
addBlackBefore:
|
||||||
|
enable: ${CALLBACK_ENABLE}
|
||||||
|
timeout: ${CALLBACK_TIMEOUT}
|
||||||
|
failedContinue: ${CALLBACK_FAILED_CONTINUE}
|
||||||
|
addFriendAfter:
|
||||||
|
enable: ${CALLBACK_ENABLE}
|
||||||
|
timeout: ${CALLBACK_TIMEOUT}
|
||||||
|
failedContinue: ${CALLBACK_FAILED_CONTINUE}
|
||||||
|
addFriendAgreeBefore:
|
||||||
|
enable: ${CALLBACK_ENABLE}
|
||||||
|
timeout: ${CALLBACK_TIMEOUT}
|
||||||
|
failedContinue: ${CALLBACK_FAILED_CONTINUE}
|
||||||
|
deleteFriendAfter:
|
||||||
|
enable: ${CALLBACK_ENABLE}
|
||||||
|
timeout: ${CALLBACK_TIMEOUT}
|
||||||
|
failedContinue: ${CALLBACK_FAILED_CONTINUE}
|
||||||
|
importFriendsBefore:
|
||||||
|
enable: ${CALLBACK_ENABLE}
|
||||||
|
timeout: ${CALLBACK_TIMEOUT}
|
||||||
|
failedContinue: ${CALLBACK_FAILED_CONTINUE}
|
||||||
|
importFriendsAfter:
|
||||||
|
enable: ${CALLBACK_ENABLE}
|
||||||
|
timeout: ${CALLBACK_TIMEOUT}
|
||||||
|
failedContinue: ${CALLBACK_FAILED_CONTINUE}
|
||||||
|
removeBlackAfter:
|
||||||
|
enable: ${CALLBACK_ENABLE}
|
||||||
|
timeout: ${CALLBACK_TIMEOUT}
|
||||||
|
failedContinue: ${CALLBACK_FAILED_CONTINUE}
|
||||||
###################### Prometheus ######################
|
###################### Prometheus ######################
|
||||||
# Prometheus configuration for various services
|
# Prometheus configuration for various services
|
||||||
# The number of Prometheus ports per service needs to correspond to rpcPort
|
# The number of Prometheus ports per service needs to correspond to rpcPort
|
||||||
|
@ -501,7 +501,7 @@ This section involves setting up additional configuration variables for Websocke
|
|||||||
| TOKEN_EXPIRE | "90" | Token Expiry Time |
|
| TOKEN_EXPIRE | "90" | Token Expiry Time |
|
||||||
| FRIEND_VERIFY | "false" | Friend Verification Enable |
|
| FRIEND_VERIFY | "false" | Friend Verification Enable |
|
||||||
| IOS_PUSH_SOUND | "xxx" | iOS |
|
| IOS_PUSH_SOUND | "xxx" | iOS |
|
||||||
| CALLBACK_ENABLE | "true" | Enable callback | | | |
|
| CALLBACK_ENABLE | "false" | Enable callback |
|
||||||
| CALLBACK_TIMEOUT | "5" | Maximum timeout for callback call |
|
| CALLBACK_TIMEOUT | "5" | Maximum timeout for callback call |
|
||||||
| CALLBACK_FAILED_CONTINUE| "true" | fails to continue to the next step |
|
| CALLBACK_FAILED_CONTINUE| "true" | fails to continue to the next step |
|
||||||
### 2.20. <a name='PrometheusConfiguration-1'></a>Prometheus Configuration
|
### 2.20. <a name='PrometheusConfiguration-1'></a>Prometheus Configuration
|
||||||
|
2
go.mod
2
go.mod
@ -38,7 +38,7 @@ require github.com/google/uuid v1.3.1
|
|||||||
require (
|
require (
|
||||||
github.com/IBM/sarama v1.41.3
|
github.com/IBM/sarama v1.41.3
|
||||||
github.com/OpenIMSDK/protocol v0.0.31
|
github.com/OpenIMSDK/protocol v0.0.31
|
||||||
github.com/OpenIMSDK/tools v0.0.16
|
github.com/OpenIMSDK/tools v0.0.17
|
||||||
github.com/aliyun/aliyun-oss-go-sdk v2.2.9+incompatible
|
github.com/aliyun/aliyun-oss-go-sdk v2.2.9+incompatible
|
||||||
github.com/go-redis/redis v6.15.9+incompatible
|
github.com/go-redis/redis v6.15.9+incompatible
|
||||||
github.com/go-sql-driver/mysql v1.7.1
|
github.com/go-sql-driver/mysql v1.7.1
|
||||||
|
4
go.sum
4
go.sum
@ -20,8 +20,8 @@ github.com/IBM/sarama v1.41.3 h1:MWBEJ12vHC8coMjdEXFq/6ftO6DUZnQlFYcxtOJFa7c=
|
|||||||
github.com/IBM/sarama v1.41.3/go.mod h1:Xxho9HkHd4K/MDUo/T/sOqwtX/17D33++E9Wib6hUdQ=
|
github.com/IBM/sarama v1.41.3/go.mod h1:Xxho9HkHd4K/MDUo/T/sOqwtX/17D33++E9Wib6hUdQ=
|
||||||
github.com/OpenIMSDK/protocol v0.0.31 h1:ax43x9aqA6EKNXNukS5MT5BSTqkUmwO4uTvbJLtzCgE=
|
github.com/OpenIMSDK/protocol v0.0.31 h1:ax43x9aqA6EKNXNukS5MT5BSTqkUmwO4uTvbJLtzCgE=
|
||||||
github.com/OpenIMSDK/protocol v0.0.31/go.mod h1:F25dFrwrIx3lkNoiuf6FkCfxuwf8L4Z8UIsdTHP/r0Y=
|
github.com/OpenIMSDK/protocol v0.0.31/go.mod h1:F25dFrwrIx3lkNoiuf6FkCfxuwf8L4Z8UIsdTHP/r0Y=
|
||||||
github.com/OpenIMSDK/tools v0.0.16 h1:te/GIq2imCMsrRPgU9OObYKbzZ3rT08Lih/o+3QFIz0=
|
github.com/OpenIMSDK/tools v0.0.17 h1:1E1HUOL2W09YUHBb4wBwrXoTSZm5ONVwLxlEX1GhlKw=
|
||||||
github.com/OpenIMSDK/tools v0.0.16/go.mod h1:eg+q4A34Qmu73xkY0mt37FHGMCMfC6CtmOnm0kFEGFI=
|
github.com/OpenIMSDK/tools v0.0.17/go.mod h1:eg+q4A34Qmu73xkY0mt37FHGMCMfC6CtmOnm0kFEGFI=
|
||||||
github.com/QcloudApi/qcloud_sign_golang v0.0.0-20141224014652-e4130a326409/go.mod h1:1pk82RBxDY/JZnPQrtqHlUFfCctgdorsd9M06fMynOM=
|
github.com/QcloudApi/qcloud_sign_golang v0.0.0-20141224014652-e4130a326409/go.mod h1:1pk82RBxDY/JZnPQrtqHlUFfCctgdorsd9M06fMynOM=
|
||||||
github.com/alcortesm/tgz v0.0.0-20161220082320-9c5fe88206d7 h1:uSoVVbwJiQipAclBbw+8quDsfcvFjOpI5iCf4p/cqCs=
|
github.com/alcortesm/tgz v0.0.0-20161220082320-9c5fe88206d7 h1:uSoVVbwJiQipAclBbw+8quDsfcvFjOpI5iCf4p/cqCs=
|
||||||
github.com/alcortesm/tgz v0.0.0-20161220082320-9c5fe88206d7/go.mod h1:6zEj6s6u/ghQa61ZWa/C2Aw3RkjiTBOix7dkqa1VLIs=
|
github.com/alcortesm/tgz v0.0.0-20161220082320-9c5fe88206d7/go.mod h1:6zEj6s6u/ghQa61ZWa/C2Aw3RkjiTBOix7dkqa1VLIs=
|
||||||
|
@ -15,14 +15,6 @@
|
|||||||
package api
|
package api
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/OpenIMSDK/tools/mcontext"
|
|
||||||
"github.com/gin-gonic/gin"
|
|
||||||
"github.com/go-playground/validator/v10"
|
|
||||||
"github.com/mitchellh/mapstructure"
|
|
||||||
|
|
||||||
"github.com/openimsdk/open-im-server/v3/pkg/authverify"
|
|
||||||
"github.com/openimsdk/open-im-server/v3/pkg/common/config"
|
|
||||||
|
|
||||||
"github.com/OpenIMSDK/protocol/constant"
|
"github.com/OpenIMSDK/protocol/constant"
|
||||||
"github.com/OpenIMSDK/protocol/msg"
|
"github.com/OpenIMSDK/protocol/msg"
|
||||||
"github.com/OpenIMSDK/protocol/sdkws"
|
"github.com/OpenIMSDK/protocol/sdkws"
|
||||||
@ -30,7 +22,13 @@ import (
|
|||||||
"github.com/OpenIMSDK/tools/apiresp"
|
"github.com/OpenIMSDK/tools/apiresp"
|
||||||
"github.com/OpenIMSDK/tools/errs"
|
"github.com/OpenIMSDK/tools/errs"
|
||||||
"github.com/OpenIMSDK/tools/log"
|
"github.com/OpenIMSDK/tools/log"
|
||||||
|
"github.com/OpenIMSDK/tools/mcontext"
|
||||||
"github.com/OpenIMSDK/tools/utils"
|
"github.com/OpenIMSDK/tools/utils"
|
||||||
|
"github.com/gin-gonic/gin"
|
||||||
|
"github.com/go-playground/validator/v10"
|
||||||
|
"github.com/mitchellh/mapstructure"
|
||||||
|
"github.com/openimsdk/open-im-server/v3/pkg/authverify"
|
||||||
|
"github.com/openimsdk/open-im-server/v3/pkg/common/config"
|
||||||
|
|
||||||
"github.com/openimsdk/open-im-server/v3/pkg/apistruct"
|
"github.com/openimsdk/open-im-server/v3/pkg/apistruct"
|
||||||
"github.com/openimsdk/open-im-server/v3/pkg/rpcclient"
|
"github.com/openimsdk/open-im-server/v3/pkg/rpcclient"
|
||||||
|
@ -121,6 +121,7 @@ func (ws *WsServer) UnRegister(c *Client) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (ws *WsServer) Validate(s interface{}) error {
|
func (ws *WsServer) Validate(s interface{}) error {
|
||||||
|
//?question?
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -74,6 +74,9 @@ func (s *friendServer) RemoveBlack(
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
s.notificationSender.BlackDeletedNotification(ctx, req)
|
s.notificationSender.BlackDeletedNotification(ctx, req)
|
||||||
|
if err := CallbackAfterRemoveBlack(ctx, req); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
return &pbfriend.RemoveBlackResp{}, nil
|
return &pbfriend.RemoveBlackResp{}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -85,6 +88,9 @@ func (s *friendServer) AddBlack(ctx context.Context, req *pbfriend.AddBlackReq)
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
if err := CallbackBeforeAddBlack(ctx, req); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
black := relation.BlackModel{
|
black := relation.BlackModel{
|
||||||
OwnerUserID: req.OwnerUserID,
|
OwnerUserID: req.OwnerUserID,
|
||||||
BlockUserID: req.BlackUserID,
|
BlockUserID: req.BlackUserID,
|
||||||
|
@ -16,9 +16,8 @@ package friend
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"github.com/OpenIMSDK/tools/utils"
|
|
||||||
|
|
||||||
pbfriend "github.com/OpenIMSDK/protocol/friend"
|
pbfriend "github.com/OpenIMSDK/protocol/friend"
|
||||||
|
"github.com/OpenIMSDK/tools/utils"
|
||||||
cbapi "github.com/openimsdk/open-im-server/v3/pkg/callbackstruct"
|
cbapi "github.com/openimsdk/open-im-server/v3/pkg/callbackstruct"
|
||||||
"github.com/openimsdk/open-im-server/v3/pkg/common/config"
|
"github.com/openimsdk/open-im-server/v3/pkg/common/config"
|
||||||
"github.com/openimsdk/open-im-server/v3/pkg/common/http"
|
"github.com/openimsdk/open-im-server/v3/pkg/common/http"
|
||||||
@ -33,6 +32,7 @@ func CallbackBeforeAddFriend(ctx context.Context, req *pbfriend.ApplyToAddFriend
|
|||||||
FromUserID: req.FromUserID,
|
FromUserID: req.FromUserID,
|
||||||
ToUserID: req.ToUserID,
|
ToUserID: req.ToUserID,
|
||||||
ReqMsg: req.ReqMsg,
|
ReqMsg: req.ReqMsg,
|
||||||
|
Ex: req.Ex,
|
||||||
}
|
}
|
||||||
resp := &cbapi.CallbackBeforeAddFriendResp{}
|
resp := &cbapi.CallbackBeforeAddFriendResp{}
|
||||||
if err := http.CallBackPostReturn(ctx, config.Config.Callback.CallbackUrl, cbReq, resp, config.Config.Callback.CallbackBeforeAddFriend); err != nil {
|
if err := http.CallBackPostReturn(ctx, config.Config.Callback.CallbackUrl, cbReq, resp, config.Config.Callback.CallbackBeforeAddFriend); err != nil {
|
||||||
@ -75,3 +75,116 @@ func CallbackAfterSetFriendRemark(ctx context.Context, req *pbfriend.SetFriendRe
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
func CallbackBeforeAddBlack(ctx context.Context, req *pbfriend.AddBlackReq) error {
|
||||||
|
if !config.Config.Callback.CallbackBeforeAddBlack.Enable {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
cbReq := &cbapi.CallbackBeforeAddBlackReq{
|
||||||
|
CallbackCommand: cbapi.CallbackBeforeAddBlackCommand,
|
||||||
|
OwnerUserID: req.OwnerUserID,
|
||||||
|
BlackUserID: req.BlackUserID,
|
||||||
|
}
|
||||||
|
resp := &cbapi.CallbackBeforeAddBlackResp{}
|
||||||
|
if err := http.CallBackPostReturn(ctx, config.Config.Callback.CallbackUrl, cbReq, resp, config.Config.Callback.CallbackBeforeAddBlack); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
func CallbackAfterAddFriend(ctx context.Context, req *pbfriend.ApplyToAddFriendReq) error {
|
||||||
|
if !config.Config.Callback.CallbackAfterAddFriend.Enable {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
cbReq := &cbapi.CallbackAfterAddFriendReq{
|
||||||
|
CallbackCommand: cbapi.CallbackAfterAddFriendCommand,
|
||||||
|
FromUserID: req.FromUserID,
|
||||||
|
ToUserID: req.ToUserID,
|
||||||
|
ReqMsg: req.ReqMsg,
|
||||||
|
}
|
||||||
|
resp := &cbapi.CallbackAfterAddFriendResp{}
|
||||||
|
if err := http.CallBackPostReturn(ctx, config.Config.Callback.CallbackUrl, cbReq, resp, config.Config.Callback.CallbackAfterAddFriend); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
func CallbackBeforeAddFriendAgree(ctx context.Context, req *pbfriend.RespondFriendApplyReq) error {
|
||||||
|
if !config.Config.Callback.CallbackBeforeAddFriendAgree.Enable {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
cbReq := &cbapi.CallbackBeforeAddFriendAgreeReq{
|
||||||
|
CallbackCommand: cbapi.CallbackBeforeAddFriendAgreeCommand,
|
||||||
|
FromUserID: req.FromUserID,
|
||||||
|
ToUserID: req.ToUserID,
|
||||||
|
HandleMsg: req.HandleMsg,
|
||||||
|
HandleResult: req.HandleResult,
|
||||||
|
}
|
||||||
|
resp := &cbapi.CallbackBeforeAddFriendAgreeResp{}
|
||||||
|
if err := http.CallBackPostReturn(ctx, config.Config.Callback.CallbackUrl, cbReq, resp, config.Config.Callback.CallbackBeforeAddFriendAgree); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
func CallbackAfterDeleteFriend(ctx context.Context, req *pbfriend.DeleteFriendReq) error {
|
||||||
|
if !config.Config.Callback.CallbackAfterDeleteFriend.Enable {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
cbReq := &cbapi.CallbackAfterDeleteFriendReq{
|
||||||
|
CallbackCommand: cbapi.CallbackAfterDeleteFriendCommand,
|
||||||
|
OwnerUserID: req.OwnerUserID,
|
||||||
|
FriendUserID: req.FriendUserID,
|
||||||
|
}
|
||||||
|
resp := &cbapi.CallbackAfterDeleteFriendResp{}
|
||||||
|
if err := http.CallBackPostReturn(ctx, config.Config.Callback.CallbackUrl, cbReq, resp, config.Config.Callback.CallbackAfterDeleteFriend); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
func CallbackBeforeImportFriends(ctx context.Context, req *pbfriend.ImportFriendReq) error {
|
||||||
|
if !config.Config.Callback.CallbackBeforeImportFriends.Enable {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
cbReq := &cbapi.CallbackBeforeImportFriendsReq{
|
||||||
|
CallbackCommand: cbapi.CallbackBeforeImportFriendsCommand,
|
||||||
|
OwnerUserID: req.OwnerUserID,
|
||||||
|
FriendUserIDs: req.FriendUserIDs,
|
||||||
|
}
|
||||||
|
resp := &cbapi.CallbackBeforeImportFriendsResp{}
|
||||||
|
if err := http.CallBackPostReturn(ctx, config.Config.Callback.CallbackUrl, cbReq, resp, config.Config.Callback.CallbackBeforeImportFriends); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if len(resp.FriendUserIDs) != 0 {
|
||||||
|
req.FriendUserIDs = resp.FriendUserIDs
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
func CallbackAfterImportFriends(ctx context.Context, req *pbfriend.ImportFriendReq) error {
|
||||||
|
if !config.Config.Callback.CallbackAfterImportFriends.Enable {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
cbReq := &cbapi.CallbackAfterImportFriendsReq{
|
||||||
|
CallbackCommand: cbapi.CallbackAfterImportFriendsCommand,
|
||||||
|
OwnerUserID: req.OwnerUserID,
|
||||||
|
FriendUserIDs: req.FriendUserIDs,
|
||||||
|
}
|
||||||
|
resp := &cbapi.CallbackAfterImportFriendsResp{}
|
||||||
|
if err := http.CallBackPostReturn(ctx, config.Config.Callback.CallbackUrl, cbReq, resp, config.Config.Callback.CallbackAfterImportFriends); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func CallbackAfterRemoveBlack(ctx context.Context, req *pbfriend.RemoveBlackReq) error {
|
||||||
|
if !config.Config.Callback.CallbackAfterRemoveBlack.Enable {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
cbReq := &cbapi.CallbackAfterRemoveBlackReq{
|
||||||
|
CallbackCommand: cbapi.CallbackAfterRemoveBlackCommand,
|
||||||
|
OwnerUserID: req.OwnerUserID,
|
||||||
|
BlackUserID: req.BlackUserID,
|
||||||
|
}
|
||||||
|
resp := &cbapi.CallbackAfterRemoveBlackResp{}
|
||||||
|
if err := http.CallBackPostReturn(ctx, config.Config.Callback.CallbackUrl, cbReq, resp, config.Config.Callback.CallbackAfterRemoveBlack); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
@ -103,7 +103,7 @@ func (s *friendServer) ApplyToAddFriend(
|
|||||||
if req.ToUserID == req.FromUserID {
|
if req.ToUserID == req.FromUserID {
|
||||||
return nil, errs.ErrCanNotAddYourself.Wrap()
|
return nil, errs.ErrCanNotAddYourself.Wrap()
|
||||||
}
|
}
|
||||||
if err := CallbackBeforeAddFriend(ctx, req); err != nil && err != errs.ErrCallbackContinue {
|
if err = CallbackBeforeAddFriend(ctx, req); err != nil && err != errs.ErrCallbackContinue {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
if _, err := s.userRpcClient.GetUsersInfoMap(ctx, []string{req.ToUserID, req.FromUserID}); err != nil {
|
if _, err := s.userRpcClient.GetUsersInfoMap(ctx, []string{req.ToUserID, req.FromUserID}); err != nil {
|
||||||
@ -120,6 +120,9 @@ func (s *friendServer) ApplyToAddFriend(
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
s.notificationSender.FriendApplicationAddNotification(ctx, req)
|
s.notificationSender.FriendApplicationAddNotification(ctx, req)
|
||||||
|
if err = CallbackAfterAddFriend(ctx, req); err != nil && err != errs.ErrCallbackContinue {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
return resp, nil
|
return resp, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -141,6 +144,10 @@ func (s *friendServer) ImportFriends(
|
|||||||
if utils.Duplicate(req.FriendUserIDs) {
|
if utils.Duplicate(req.FriendUserIDs) {
|
||||||
return nil, errs.ErrArgs.Wrap("friend userID repeated")
|
return nil, errs.ErrArgs.Wrap("friend userID repeated")
|
||||||
}
|
}
|
||||||
|
if err := CallbackBeforeImportFriends(ctx, req); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
if err := s.friendDatabase.BecomeFriends(ctx, req.OwnerUserID, req.FriendUserIDs, constant.BecomeFriendByImport); err != nil {
|
if err := s.friendDatabase.BecomeFriends(ctx, req.OwnerUserID, req.FriendUserIDs, constant.BecomeFriendByImport); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
@ -151,6 +158,9 @@ func (s *friendServer) ImportFriends(
|
|||||||
HandleResult: constant.FriendResponseAgree,
|
HandleResult: constant.FriendResponseAgree,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
if err := CallbackAfterImportFriends(ctx, req); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
return &pbfriend.ImportFriendResp{}, nil
|
return &pbfriend.ImportFriendResp{}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -172,6 +182,9 @@ func (s *friendServer) RespondFriendApply(
|
|||||||
HandleResult: req.HandleResult,
|
HandleResult: req.HandleResult,
|
||||||
}
|
}
|
||||||
if req.HandleResult == constant.FriendResponseAgree {
|
if req.HandleResult == constant.FriendResponseAgree {
|
||||||
|
if err := CallbackBeforeAddFriendAgree(ctx, req); err != nil && err != errs.ErrCallbackContinue {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
err := s.friendDatabase.AgreeFriendRequest(ctx, &friendRequest)
|
err := s.friendDatabase.AgreeFriendRequest(ctx, &friendRequest)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
@ -208,6 +221,9 @@ func (s *friendServer) DeleteFriend(
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
s.notificationSender.FriendDeletedNotification(ctx, req)
|
s.notificationSender.FriendDeletedNotification(ctx, req)
|
||||||
|
if err := CallbackAfterDeleteFriend(ctx, req); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
return resp, nil
|
return resp, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -16,6 +16,7 @@ package group
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
"github.com/OpenIMSDK/tools/log"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/OpenIMSDK/protocol/constant"
|
"github.com/OpenIMSDK/protocol/constant"
|
||||||
@ -124,7 +125,14 @@ func CallbackBeforeMemberJoinGroup(
|
|||||||
GroupEx: groupEx,
|
GroupEx: groupEx,
|
||||||
}
|
}
|
||||||
resp := &callbackstruct.CallbackBeforeMemberJoinGroupResp{}
|
resp := &callbackstruct.CallbackBeforeMemberJoinGroupResp{}
|
||||||
if err = http.CallBackPostReturn(ctx, config.Config.Callback.CallbackUrl, callbackReq, resp, config.Config.Callback.CallbackBeforeMemberJoinGroup); err != nil {
|
err = http.CallBackPostReturn(
|
||||||
|
ctx,
|
||||||
|
config.Config.Callback.CallbackUrl,
|
||||||
|
callbackReq,
|
||||||
|
resp,
|
||||||
|
config.Config.Callback.CallbackBeforeMemberJoinGroup,
|
||||||
|
)
|
||||||
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
if resp.MuteEndTime != nil {
|
if resp.MuteEndTime != nil {
|
||||||
@ -159,7 +167,14 @@ func CallbackBeforeSetGroupMemberInfo(ctx context.Context, req *group.SetGroupMe
|
|||||||
callbackReq.Ex = &req.Ex.Value
|
callbackReq.Ex = &req.Ex.Value
|
||||||
}
|
}
|
||||||
resp := &callbackstruct.CallbackBeforeSetGroupMemberInfoResp{}
|
resp := &callbackstruct.CallbackBeforeSetGroupMemberInfoResp{}
|
||||||
if err = http.CallBackPostReturn(ctx, config.Config.Callback.CallbackUrl, callbackReq, resp, config.Config.Callback.CallbackBeforeSetGroupMemberInfo); err != nil {
|
err = http.CallBackPostReturn(
|
||||||
|
ctx,
|
||||||
|
config.Config.Callback.CallbackUrl,
|
||||||
|
callbackReq,
|
||||||
|
resp,
|
||||||
|
config.Config.Callback.CallbackBeforeSetGroupMemberInfo,
|
||||||
|
)
|
||||||
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
if resp.FaceURL != nil {
|
if resp.FaceURL != nil {
|
||||||
@ -176,13 +191,12 @@ func CallbackBeforeSetGroupMemberInfo(ctx context.Context, req *group.SetGroupMe
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func CallbackAfterSetGroupMemberInfo(ctx context.Context, req *group.SetGroupMemberInfo) (err error) {
|
func CallbackAfterSetGroupMemberInfo(ctx context.Context, req *group.SetGroupMemberInfo) (err error) {
|
||||||
if !config.Config.Callback.CallbackBeforeSetGroupMemberInfo.Enable {
|
if !config.Config.Callback.CallbackBeforeSetGroupMemberInfo.Enable {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
callbackReq := callbackstruct.CallbackAfterSetGroupMemberInfoReq{
|
callbackReq := callbackstruct.CallbackAfterSetGroupMemberInfoReq{
|
||||||
CallbackCommand: callbackstruct.CallbackBeforeSetGroupMemberInfoCommand,
|
CallbackCommand: callbackstruct.CallbackAfterSetGroupMemberInfoCommand,
|
||||||
GroupID: req.GroupID,
|
GroupID: req.GroupID,
|
||||||
UserID: req.UserID,
|
UserID: req.UserID,
|
||||||
}
|
}
|
||||||
@ -199,7 +213,7 @@ func CallbackAfterSetGroupMemberInfo(ctx context.Context, req *group.SetGroupMem
|
|||||||
callbackReq.Ex = &req.Ex.Value
|
callbackReq.Ex = &req.Ex.Value
|
||||||
}
|
}
|
||||||
resp := &callbackstruct.CallbackAfterSetGroupMemberInfoResp{}
|
resp := &callbackstruct.CallbackAfterSetGroupMemberInfoResp{}
|
||||||
if err = http.CallBackPostReturn(ctx, config.Config.Callback.CallbackUrl, callbackReq, resp, config.Config.Callback.CallbackBeforeSetGroupMemberInfo); err != nil {
|
if err = http.CallBackPostReturn(ctx, config.Config.Callback.CallbackUrl, callbackReq, resp, config.Config.Callback.CallbackAfterSetGroupMemberInfo); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
@ -282,3 +296,135 @@ func CallbackTransferGroupOwnerAfter(ctx context.Context, req *pbgroup.TransferG
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
func CallbackBeforeInviteUserToGroup(ctx context.Context, req *group.InviteUserToGroupReq) (err error) {
|
||||||
|
if !config.Config.Callback.CallbackBeforeInviteUserToGroup.Enable {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
callbackReq := &callbackstruct.CallbackBeforeInviteUserToGroupReq{
|
||||||
|
CallbackCommand: callbackstruct.CallbackBeforeInviteJoinGroupCommand,
|
||||||
|
OperationID: mcontext.GetOperationID(ctx),
|
||||||
|
GroupID: req.GroupID,
|
||||||
|
Reason: req.Reason,
|
||||||
|
InvitedUserIDs: req.InvitedUserIDs,
|
||||||
|
}
|
||||||
|
|
||||||
|
resp := &callbackstruct.CallbackBeforeInviteUserToGroupResp{}
|
||||||
|
err = http.CallBackPostReturn(
|
||||||
|
ctx,
|
||||||
|
config.Config.Callback.CallbackUrl,
|
||||||
|
callbackReq,
|
||||||
|
resp,
|
||||||
|
config.Config.Callback.CallbackBeforeInviteUserToGroup,
|
||||||
|
)
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(resp.RefusedMembersAccount) > 0 {
|
||||||
|
// Handle the scenario where certain members are refused
|
||||||
|
// You might want to update the req.Members list or handle it as per your business logic
|
||||||
|
}
|
||||||
|
utils.StructFieldNotNilReplace(req, resp)
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func CallbackAfterJoinGroup(ctx context.Context, req *group.JoinGroupReq) error {
|
||||||
|
if !config.Config.Callback.CallbackAfterJoinGroup.Enable {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
callbackReq := &callbackstruct.CallbackAfterJoinGroupReq{
|
||||||
|
CallbackCommand: callbackstruct.CallbackAfterJoinGroupCommand,
|
||||||
|
OperationID: mcontext.GetOperationID(ctx),
|
||||||
|
GroupID: req.GroupID,
|
||||||
|
ReqMessage: req.ReqMessage,
|
||||||
|
JoinSource: req.JoinSource,
|
||||||
|
InviterUserID: req.InviterUserID,
|
||||||
|
}
|
||||||
|
resp := &callbackstruct.CallbackAfterJoinGroupResp{}
|
||||||
|
if err := http.CallBackPostReturn(ctx, config.Config.Callback.CallbackUrl, callbackReq, resp, config.Config.Callback.CallbackAfterJoinGroup); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func CallbackBeforeSetGroupInfo(ctx context.Context, req *group.SetGroupInfoReq) error {
|
||||||
|
if !config.Config.Callback.CallbackBeforeSetGroupInfo.Enable {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
callbackReq := &callbackstruct.CallbackBeforeSetGroupInfoReq{
|
||||||
|
CallbackCommand: callbackstruct.CallbackBeforeSetGroupInfoCommand,
|
||||||
|
GroupID: req.GroupInfoForSet.GroupID,
|
||||||
|
Notification: req.GroupInfoForSet.Notification,
|
||||||
|
Introduction: req.GroupInfoForSet.Introduction,
|
||||||
|
FaceURL: req.GroupInfoForSet.FaceURL,
|
||||||
|
GroupName: req.GroupInfoForSet.GroupName,
|
||||||
|
}
|
||||||
|
|
||||||
|
if req.GroupInfoForSet.Ex != nil {
|
||||||
|
callbackReq.Ex = req.GroupInfoForSet.Ex.Value
|
||||||
|
}
|
||||||
|
log.ZDebug(ctx, "debug CallbackBeforeSetGroupInfo", callbackReq.Ex)
|
||||||
|
if req.GroupInfoForSet.NeedVerification != nil {
|
||||||
|
callbackReq.NeedVerification = req.GroupInfoForSet.NeedVerification.Value
|
||||||
|
}
|
||||||
|
if req.GroupInfoForSet.LookMemberInfo != nil {
|
||||||
|
callbackReq.LookMemberInfo = req.GroupInfoForSet.LookMemberInfo.Value
|
||||||
|
}
|
||||||
|
if req.GroupInfoForSet.ApplyMemberFriend != nil {
|
||||||
|
callbackReq.ApplyMemberFriend = req.GroupInfoForSet.ApplyMemberFriend.Value
|
||||||
|
}
|
||||||
|
resp := &callbackstruct.CallbackBeforeSetGroupInfoResp{}
|
||||||
|
|
||||||
|
if err := http.CallBackPostReturn(ctx, config.Config.Callback.CallbackUrl, callbackReq, resp, config.Config.Callback.CallbackBeforeSetGroupInfo); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
if resp.Ex != nil {
|
||||||
|
req.GroupInfoForSet.Ex = wrapperspb.String(*resp.Ex)
|
||||||
|
}
|
||||||
|
if resp.NeedVerification != nil {
|
||||||
|
req.GroupInfoForSet.NeedVerification = wrapperspb.Int32(*resp.NeedVerification)
|
||||||
|
}
|
||||||
|
if resp.LookMemberInfo != nil {
|
||||||
|
req.GroupInfoForSet.LookMemberInfo = wrapperspb.Int32(*resp.LookMemberInfo)
|
||||||
|
}
|
||||||
|
if resp.ApplyMemberFriend != nil {
|
||||||
|
req.GroupInfoForSet.ApplyMemberFriend = wrapperspb.Int32(*resp.ApplyMemberFriend)
|
||||||
|
}
|
||||||
|
utils.StructFieldNotNilReplace(req, resp)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
func CallbackAfterSetGroupInfo(ctx context.Context, req *group.SetGroupInfoReq) error {
|
||||||
|
if !config.Config.Callback.CallbackAfterSetGroupInfo.Enable {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
callbackReq := &callbackstruct.CallbackAfterSetGroupInfoReq{
|
||||||
|
CallbackCommand: callbackstruct.CallbackAfterSetGroupInfoCommand,
|
||||||
|
GroupID: req.GroupInfoForSet.GroupID,
|
||||||
|
Notification: req.GroupInfoForSet.Notification,
|
||||||
|
Introduction: req.GroupInfoForSet.Introduction,
|
||||||
|
FaceURL: req.GroupInfoForSet.FaceURL,
|
||||||
|
GroupName: req.GroupInfoForSet.GroupName,
|
||||||
|
}
|
||||||
|
if req.GroupInfoForSet.Ex != nil {
|
||||||
|
callbackReq.Ex = &req.GroupInfoForSet.Ex.Value
|
||||||
|
}
|
||||||
|
if req.GroupInfoForSet.NeedVerification != nil {
|
||||||
|
callbackReq.NeedVerification = &req.GroupInfoForSet.NeedVerification.Value
|
||||||
|
}
|
||||||
|
if req.GroupInfoForSet.LookMemberInfo != nil {
|
||||||
|
callbackReq.LookMemberInfo = &req.GroupInfoForSet.LookMemberInfo.Value
|
||||||
|
}
|
||||||
|
if req.GroupInfoForSet.ApplyMemberFriend != nil {
|
||||||
|
callbackReq.ApplyMemberFriend = &req.GroupInfoForSet.ApplyMemberFriend.Value
|
||||||
|
}
|
||||||
|
resp := &callbackstruct.CallbackAfterSetGroupInfoResp{}
|
||||||
|
if err := http.CallBackPostReturn(ctx, config.Config.Callback.CallbackUrl, callbackReq, resp, config.Config.Callback.CallbackAfterSetGroupInfo); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
utils.StructFieldNotNilReplace(req, resp)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
@ -366,6 +366,7 @@ func (s *groupServer) GetJoinedGroupList(ctx context.Context, req *pbgroup.GetJo
|
|||||||
|
|
||||||
func (s *groupServer) InviteUserToGroup(ctx context.Context, req *pbgroup.InviteUserToGroupReq) (*pbgroup.InviteUserToGroupResp, error) {
|
func (s *groupServer) InviteUserToGroup(ctx context.Context, req *pbgroup.InviteUserToGroupReq) (*pbgroup.InviteUserToGroupResp, error) {
|
||||||
resp := &pbgroup.InviteUserToGroupResp{}
|
resp := &pbgroup.InviteUserToGroupResp{}
|
||||||
|
|
||||||
if len(req.InvitedUserIDs) == 0 {
|
if len(req.InvitedUserIDs) == 0 {
|
||||||
return nil, errs.ErrArgs.Wrap("user empty")
|
return nil, errs.ErrArgs.Wrap("user empty")
|
||||||
}
|
}
|
||||||
@ -376,6 +377,7 @@ func (s *groupServer) InviteUserToGroup(ctx context.Context, req *pbgroup.Invite
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
if group.Status == constant.GroupStatusDismissed {
|
if group.Status == constant.GroupStatusDismissed {
|
||||||
return nil, errs.ErrDismissedAlready.Wrap()
|
return nil, errs.ErrDismissedAlready.Wrap()
|
||||||
}
|
}
|
||||||
@ -399,6 +401,10 @@ func (s *groupServer) InviteUserToGroup(ctx context.Context, req *pbgroup.Invite
|
|||||||
}
|
}
|
||||||
groupMember = groupMembers[0]
|
groupMember = groupMembers[0]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if err := CallbackBeforeInviteUserToGroup(ctx, req); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
if group.NeedVerification == constant.AllNeedVerification {
|
if group.NeedVerification == constant.AllNeedVerification {
|
||||||
if !authverify.IsAppManagerUid(ctx) {
|
if !authverify.IsAppManagerUid(ctx) {
|
||||||
if !(groupMember.RoleLevel == constant.GroupOwner || groupMember.RoleLevel == constant.GroupAdmin) {
|
if !(groupMember.RoleLevel == constant.GroupOwner || groupMember.RoleLevel == constant.GroupAdmin) {
|
||||||
@ -413,6 +419,7 @@ func (s *groupServer) InviteUserToGroup(ctx context.Context, req *pbgroup.Invite
|
|||||||
HandledTime: time.Unix(0, 0),
|
HandledTime: time.Unix(0, 0),
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := s.GroupDatabase.CreateGroupRequest(ctx, requests); err != nil {
|
if err := s.GroupDatabase.CreateGroupRequest(ctx, requests); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
@ -818,6 +825,7 @@ func (s *groupServer) GroupApplicationResponse(ctx context.Context, req *pbgroup
|
|||||||
case constant.GroupResponseRefuse:
|
case constant.GroupResponseRefuse:
|
||||||
s.Notification.GroupApplicationRejectedNotification(ctx, req)
|
s.Notification.GroupApplicationRejectedNotification(ctx, req)
|
||||||
}
|
}
|
||||||
|
|
||||||
return &pbgroup.GroupApplicationResponseResp{}, nil
|
return &pbgroup.GroupApplicationResponseResp{}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -872,10 +880,14 @@ func (s *groupServer) JoinGroup(ctx context.Context, req *pbgroup.JoinGroupReq)
|
|||||||
if err := s.GroupDatabase.CreateGroup(ctx, nil, []*relationtb.GroupMemberModel{groupMember}); err != nil {
|
if err := s.GroupDatabase.CreateGroup(ctx, nil, []*relationtb.GroupMemberModel{groupMember}); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := s.conversationRpcClient.GroupChatFirstCreateConversation(ctx, req.GroupID, []string{req.InviterUserID}); err != nil {
|
if err := s.conversationRpcClient.GroupChatFirstCreateConversation(ctx, req.GroupID, []string{req.InviterUserID}); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
s.Notification.MemberEnterNotification(ctx, req.GroupID, req.InviterUserID)
|
s.Notification.MemberEnterNotification(ctx, req.GroupID, req.InviterUserID)
|
||||||
|
if err = CallbackAfterJoinGroup(ctx, req); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
return resp, nil
|
return resp, nil
|
||||||
}
|
}
|
||||||
groupRequest := relationtb.GroupRequestModel{
|
groupRequest := relationtb.GroupRequestModel{
|
||||||
@ -957,6 +969,9 @@ func (s *groupServer) SetGroupInfo(ctx context.Context, req *pbgroup.SetGroupInf
|
|||||||
return nil, errs.ErrNoPermission.Wrap("no group owner or admin")
|
return nil, errs.ErrNoPermission.Wrap("no group owner or admin")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if err := CallbackBeforeSetGroupInfo(ctx, req); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
group, err := s.GroupDatabase.TakeGroup(ctx, req.GroupInfoForSet.GroupID)
|
group, err := s.GroupDatabase.TakeGroup(ctx, req.GroupInfoForSet.GroupID)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
@ -1025,6 +1040,9 @@ func (s *groupServer) SetGroupInfo(ctx context.Context, req *pbgroup.SetGroupInf
|
|||||||
default:
|
default:
|
||||||
s.Notification.GroupInfoSetNotification(ctx, tips)
|
s.Notification.GroupInfoSetNotification(ctx, tips)
|
||||||
}
|
}
|
||||||
|
if err := CallbackAfterSetGroupInfo(ctx, req); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
return resp, nil
|
return resp, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -24,8 +24,8 @@ import (
|
|||||||
"github.com/OpenIMSDK/tools/log"
|
"github.com/OpenIMSDK/tools/log"
|
||||||
"github.com/OpenIMSDK/tools/mcontext"
|
"github.com/OpenIMSDK/tools/mcontext"
|
||||||
"github.com/OpenIMSDK/tools/utils"
|
"github.com/OpenIMSDK/tools/utils"
|
||||||
|
|
||||||
cbapi "github.com/openimsdk/open-im-server/v3/pkg/callbackstruct"
|
cbapi "github.com/openimsdk/open-im-server/v3/pkg/callbackstruct"
|
||||||
|
|
||||||
"github.com/openimsdk/open-im-server/v3/pkg/common/config"
|
"github.com/openimsdk/open-im-server/v3/pkg/common/config"
|
||||||
"github.com/openimsdk/open-im-server/v3/pkg/common/http"
|
"github.com/openimsdk/open-im-server/v3/pkg/common/http"
|
||||||
)
|
)
|
||||||
@ -98,10 +98,10 @@ func callbackAfterSendSingleMsg(ctx context.Context, msg *pbchat.SendMsgReq) err
|
|||||||
}
|
}
|
||||||
|
|
||||||
func callbackBeforeSendGroupMsg(ctx context.Context, msg *pbchat.SendMsgReq) error {
|
func callbackBeforeSendGroupMsg(ctx context.Context, msg *pbchat.SendMsgReq) error {
|
||||||
if !config.Config.Callback.CallbackAfterSendSingleMsg.Enable {
|
if !config.Config.Callback.CallbackBeforeSendSingleMsg.Enable {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
req := &cbapi.CallbackAfterSendGroupMsgReq{
|
req := &cbapi.CallbackBeforeSendGroupMsgReq{
|
||||||
CommonCallbackReq: toCommonCallback(ctx, msg, cbapi.CallbackBeforeSendGroupMsgCommand),
|
CommonCallbackReq: toCommonCallback(ctx, msg, cbapi.CallbackBeforeSendGroupMsgCommand),
|
||||||
GroupID: msg.MsgData.GroupID,
|
GroupID: msg.MsgData.GroupID,
|
||||||
}
|
}
|
||||||
@ -160,7 +160,6 @@ func callbackMsgModify(ctx context.Context, msg *pbchat.SendMsgReq) error {
|
|||||||
log.ZDebug(ctx, "callbackMsgModify", "msg", msg.MsgData)
|
log.ZDebug(ctx, "callbackMsgModify", "msg", msg.MsgData)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func CallbackGroupMsgRead(ctx context.Context, req *cbapi.CallbackGroupMsgReadReq) error {
|
func CallbackGroupMsgRead(ctx context.Context, req *cbapi.CallbackGroupMsgReadReq) error {
|
||||||
if !config.Config.Callback.CallbackGroupMsgRead.Enable || req.ContentType != constant.Text {
|
if !config.Config.Callback.CallbackGroupMsgRead.Enable || req.ContentType != constant.Text {
|
||||||
return nil
|
return nil
|
||||||
@ -180,10 +179,27 @@ func CallbackSingleMsgRead(ctx context.Context, req *cbapi.CallbackSingleMsgRead
|
|||||||
}
|
}
|
||||||
req.CallbackCommand = cbapi.CallbackSingleMsgRead
|
req.CallbackCommand = cbapi.CallbackSingleMsgRead
|
||||||
|
|
||||||
resp := &cbapi.CallbackGroupMsgReadResp{}
|
resp := &cbapi.CallbackSingleMsgReadResp{}
|
||||||
|
|
||||||
if err := http.CallBackPostReturn(ctx, cbURL(), req, resp, config.Config.Callback.CallbackMsgModify); err != nil {
|
if err := http.CallBackPostReturn(ctx, cbURL(), req, resp, config.Config.Callback.CallbackMsgModify); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
func CallbackAfterRevokeMsg(ctx context.Context, req *pbchat.RevokeMsgReq) error {
|
||||||
|
if !config.Config.Callback.CallbackAfterRevokeMsg.Enable {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
callbackReq := &cbapi.CallbackAfterRevokeMsgReq{
|
||||||
|
CallbackCommand: cbapi.CallbackAfterRevokeMsgCommand,
|
||||||
|
ConversationID: req.ConversationID,
|
||||||
|
Seq: req.Seq,
|
||||||
|
UserID: req.UserID,
|
||||||
|
}
|
||||||
|
resp := &cbapi.CallbackAfterRevokeMsgResp{}
|
||||||
|
if err := http.CallBackPostReturn(ctx, config.Config.Callback.CallbackUrl, callbackReq, resp, config.Config.Callback.CallbackAfterRevokeMsg); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
utils.StructFieldNotNilReplace(req, resp)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
@ -61,6 +61,7 @@ func (m *msgServer) RevokeMsg(ctx context.Context, req *msg.RevokeMsgReq) (*msg.
|
|||||||
if msgs[0].ContentType == constant.MsgRevokeNotification {
|
if msgs[0].ContentType == constant.MsgRevokeNotification {
|
||||||
return nil, errs.ErrMsgAlreadyRevoke.Wrap("msg already revoke")
|
return nil, errs.ErrMsgAlreadyRevoke.Wrap("msg already revoke")
|
||||||
}
|
}
|
||||||
|
|
||||||
data, _ := json.Marshal(msgs[0])
|
data, _ := json.Marshal(msgs[0])
|
||||||
log.ZInfo(ctx, "GetMsgBySeqs", "conversationID", req.ConversationID, "seq", req.Seq, "msg", string(data))
|
log.ZInfo(ctx, "GetMsgBySeqs", "conversationID", req.ConversationID, "seq", req.Seq, "msg", string(data))
|
||||||
var role int32
|
var role int32
|
||||||
@ -128,5 +129,8 @@ func (m *msgServer) RevokeMsg(ctx context.Context, req *msg.RevokeMsgReq) (*msg.
|
|||||||
if err := m.notificationSender.NotificationWithSesstionType(ctx, req.UserID, recvID, constant.MsgRevokeNotification, msgs[0].SessionType, &tips); err != nil {
|
if err := m.notificationSender.NotificationWithSesstionType(ctx, req.UserID, recvID, constant.MsgRevokeNotification, msgs[0].SessionType, &tips); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
if err = CallbackAfterRevokeMsg(ctx, req); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
return &msg.RevokeMsgResp{}, nil
|
return &msg.RevokeMsgResp{}, nil
|
||||||
}
|
}
|
||||||
|
@ -91,8 +91,8 @@ func CallbackAfterUserRegister(ctx context.Context, req *pbuser.UserRegisterReq)
|
|||||||
Users: req.Users,
|
Users: req.Users,
|
||||||
}
|
}
|
||||||
|
|
||||||
resp := &cbapi.CallbackBeforeUserRegisterResp{}
|
resp := &cbapi.CallbackAfterUserRegisterResp{}
|
||||||
if err := http.CallBackPostReturn(ctx, config.Config.Callback.CallbackUrl, cbReq, resp, config.Config.Callback.CallbackBeforeUpdateUserInfo); err != nil {
|
if err := http.CallBackPostReturn(ctx, config.Config.Callback.CallbackUrl, cbReq, resp, config.Config.Callback.CallbackAfterUpdateUserInfo); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
|
@ -16,56 +16,56 @@ package apistruct
|
|||||||
|
|
||||||
type PictureBaseInfo struct {
|
type PictureBaseInfo struct {
|
||||||
UUID string `mapstructure:"uuid"`
|
UUID string `mapstructure:"uuid"`
|
||||||
Type string `mapstructure:"type"`
|
Type string `mapstructure:"type" validate:"required"`
|
||||||
Size int64 `mapstructure:"size"`
|
Size int64 `mapstructure:"size"`
|
||||||
Width int32 `mapstructure:"width"`
|
Width int32 `mapstructure:"width" validate:"required"`
|
||||||
Height int32 `mapstructure:"height"`
|
Height int32 `mapstructure:"height" validate:"required"`
|
||||||
Url string `mapstructure:"url"`
|
Url string `mapstructure:"url" validate:"required"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type PictureElem struct {
|
type PictureElem struct {
|
||||||
SourcePath string `mapstructure:"sourcePath"`
|
SourcePath string `mapstructure:"sourcePath"`
|
||||||
SourcePicture PictureBaseInfo `mapstructure:"sourcePicture"`
|
SourcePicture PictureBaseInfo `mapstructure:"sourcePicture" validate:"required"`
|
||||||
BigPicture PictureBaseInfo `mapstructure:"bigPicture"`
|
BigPicture PictureBaseInfo `mapstructure:"bigPicture" validate:"required"`
|
||||||
SnapshotPicture PictureBaseInfo `mapstructure:"snapshotPicture"`
|
SnapshotPicture PictureBaseInfo `mapstructure:"snapshotPicture" validate:"required"`
|
||||||
}
|
}
|
||||||
type SoundElem struct {
|
type SoundElem struct {
|
||||||
UUID string `mapstructure:"uuid"`
|
UUID string `mapstructure:"uuid"`
|
||||||
SoundPath string `mapstructure:"soundPath"`
|
SoundPath string `mapstructure:"soundPath"`
|
||||||
SourceURL string `mapstructure:"sourceUrl"`
|
SourceURL string `mapstructure:"sourceUrl" validate:"required"`
|
||||||
DataSize int64 `mapstructure:"dataSize"`
|
DataSize int64 `mapstructure:"dataSize"`
|
||||||
Duration int64 `mapstructure:"duration"`
|
Duration int64 `mapstructure:"duration" validate:"required,min=1"`
|
||||||
}
|
}
|
||||||
type VideoElem struct {
|
type VideoElem struct {
|
||||||
VideoPath string `mapstructure:"videoPath" `
|
VideoPath string `mapstructure:"videoPath" `
|
||||||
VideoUUID string `mapstructure:"videoUUID"`
|
VideoUUID string `mapstructure:"videoUUID"`
|
||||||
VideoURL string `mapstructure:"videoUrl"`
|
VideoURL string `mapstructure:"videoUrl" validate:"required"`
|
||||||
VideoType string `mapstructure:"videoType"`
|
VideoType string `mapstructure:"videoType" validate:"required"`
|
||||||
VideoSize int64 `mapstructure:"videoSize"`
|
VideoSize int64 `mapstructure:"videoSize" validate:"required"`
|
||||||
Duration int64 `mapstructure:"duration"`
|
Duration int64 `mapstructure:"duration" validate:"required"`
|
||||||
SnapshotPath string `mapstructure:"snapshotPath"`
|
SnapshotPath string `mapstructure:"snapshotPath"`
|
||||||
SnapshotUUID string `mapstructure:"snapshotUUID"`
|
SnapshotUUID string `mapstructure:"snapshotUUID"`
|
||||||
SnapshotSize int64 `mapstructure:"snapshotSize"`
|
SnapshotSize int64 `mapstructure:"snapshotSize"`
|
||||||
SnapshotURL string `mapstructure:"snapshotUrl"`
|
SnapshotURL string `mapstructure:"snapshotUrl" validate:"required"`
|
||||||
SnapshotWidth int32 `mapstructure:"snapshotWidth"`
|
SnapshotWidth int32 `mapstructure:"snapshotWidth" validate:"required"`
|
||||||
SnapshotHeight int32 `mapstructure:"snapshotHeight"`
|
SnapshotHeight int32 `mapstructure:"snapshotHeight" validate:"required"`
|
||||||
}
|
}
|
||||||
type FileElem struct {
|
type FileElem struct {
|
||||||
FilePath string `mapstructure:"filePath" `
|
FilePath string `mapstructure:"filePath" `
|
||||||
UUID string `mapstructure:"uuid"`
|
UUID string `mapstructure:"uuid"`
|
||||||
SourceURL string `mapstructure:"sourceUrl"`
|
SourceURL string `mapstructure:"sourceUrl" validate:"required"`
|
||||||
FileName string `mapstructure:"fileName"`
|
FileName string `mapstructure:"fileName" validate:"required"`
|
||||||
FileSize int64 `mapstructure:"fileSize"`
|
FileSize int64 `mapstructure:"fileSize" validate:"required"`
|
||||||
}
|
}
|
||||||
type AtElem struct {
|
type AtElem struct {
|
||||||
Text string `mapstructure:"text"`
|
Text string `mapstructure:"text"`
|
||||||
AtUserList []string `mapstructure:"atUserList"`
|
AtUserList []string `mapstructure:"atUserList" validate:"required,max=1000"`
|
||||||
IsAtSelf bool `mapstructure:"isAtSelf"`
|
IsAtSelf bool `mapstructure:"isAtSelf"`
|
||||||
}
|
}
|
||||||
type LocationElem struct {
|
type LocationElem struct {
|
||||||
Description string `mapstructure:"description" `
|
Description string `mapstructure:"description" `
|
||||||
Longitude float64 `mapstructure:"longitude"`
|
Longitude float64 `mapstructure:"longitude" validate:"required"`
|
||||||
Latitude float64 `mapstructure:"latitude"`
|
Latitude float64 `mapstructure:"latitude" validate:"required"`
|
||||||
}
|
}
|
||||||
type CustomElem struct {
|
type CustomElem struct {
|
||||||
Data string `mapstructure:"data" validate:"required"`
|
Data string `mapstructure:"data" validate:"required"`
|
||||||
@ -80,17 +80,18 @@ type TextElem struct {
|
|||||||
type RevokeElem struct {
|
type RevokeElem struct {
|
||||||
RevokeMsgClientID string `mapstructure:"revokeMsgClientID" validate:"required"`
|
RevokeMsgClientID string `mapstructure:"revokeMsgClientID" validate:"required"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type OANotificationElem struct {
|
type OANotificationElem struct {
|
||||||
NotificationName string `mapstructure:"notificationName" json:"notificationName" validate:"required"`
|
NotificationName string `mapstructure:"notificationName" json:"notificationName" validate:"required"`
|
||||||
NotificationFaceURL string `mapstructure:"notificationFaceURL" json:"notificationFaceURL"`
|
NotificationFaceURL string `mapstructure:"notificationFaceURL" json:"notificationFaceURL"`
|
||||||
NotificationType int32 `mapstructure:"notificationType" json:"notificationType" validate:"required"`
|
NotificationType int32 `mapstructure:"notificationType" json:"notificationType" validate:"required"`
|
||||||
Text string `mapstructure:"text" json:"text" validate:"required"`
|
Text string `mapstructure:"text" json:"text" validate:"required"`
|
||||||
Url string `mapstructure:"url" json:"url"`
|
Url string `mapstructure:"url" json:"url"`
|
||||||
MixType int32 `mapstructure:"mixType" json:"mixType"`
|
MixType int32 `mapstructure:"mixType" json:"mixType" validate:"required"`
|
||||||
PictureElem PictureElem `mapstructure:"pictureElem" json:"pictureElem"`
|
PictureElem *PictureElem `mapstructure:"pictureElem" json:"pictureElem"`
|
||||||
SoundElem SoundElem `mapstructure:"soundElem" json:"soundElem"`
|
SoundElem *SoundElem `mapstructure:"soundElem" json:"soundElem"`
|
||||||
VideoElem VideoElem `mapstructure:"videoElem" json:"videoElem"`
|
VideoElem *VideoElem `mapstructure:"videoElem" json:"videoElem"`
|
||||||
FileElem FileElem `mapstructure:"fileElem" json:"fileElem"`
|
FileElem *FileElem `mapstructure:"fileElem" json:"fileElem"`
|
||||||
Ex string `mapstructure:"ex" json:"ex"`
|
Ex string `mapstructure:"ex" json:"ex"`
|
||||||
}
|
}
|
||||||
type MessageRevoked struct {
|
type MessageRevoked struct {
|
||||||
|
@ -1,5 +1,20 @@
|
|||||||
package callbackstruct
|
package callbackstruct
|
||||||
|
|
||||||
|
const CallbackBeforeInviteJoinGroupCommand = "callbackBeforeInviteJoinGroupCommand"
|
||||||
|
const CallbackAfterJoinGroupCommand = "callbackAfterJoinGroupCommand"
|
||||||
|
const CallbackAfterSetGroupInfoCommand = "callbackAfterSetGroupInfoCommand"
|
||||||
|
const CallbackBeforeSetGroupInfoCommand = "callbackBeforeSetGroupInfoCommand"
|
||||||
|
|
||||||
|
const CallbackAfterRevokeMsgCommand = "callbackBeforeAfterMsgCommand"
|
||||||
|
const CallbackBeforeAddBlackCommand = "callbackBeforeAddBlackCommand"
|
||||||
|
const CallbackAfterAddFriendCommand = "callbackAfterAddFriendCommand"
|
||||||
|
const CallbackBeforeAddFriendAgreeCommand = "callbackBeforeAddFriendAgreeCommand"
|
||||||
|
|
||||||
|
const CallbackAfterDeleteFriendCommand = "callbackAfterDeleteFriendCommand"
|
||||||
|
const CallbackBeforeImportFriendsCommand = "callbackBeforeImportFriendsCommand"
|
||||||
|
const CallbackAfterImportFriendsCommand = "callbackAfterImportFriendsCommand"
|
||||||
|
const CallbackAfterRemoveBlackCommand = "callbackAfterRemoveBlackCommand"
|
||||||
|
|
||||||
const (
|
const (
|
||||||
CallbackQuitGroupCommand = "callbackQuitGroupCommand"
|
CallbackQuitGroupCommand = "callbackQuitGroupCommand"
|
||||||
CallbackKillGroupCommand = "callbackKillGroupCommand"
|
CallbackKillGroupCommand = "callbackKillGroupCommand"
|
||||||
@ -29,5 +44,6 @@ const (
|
|||||||
CallbackBeforeCreateGroupCommand = "callbackBeforeCreateGroupCommand"
|
CallbackBeforeCreateGroupCommand = "callbackBeforeCreateGroupCommand"
|
||||||
CallbackAfterCreateGroupCommand = "callbackAfterCreateGroupCommand"
|
CallbackAfterCreateGroupCommand = "callbackAfterCreateGroupCommand"
|
||||||
CallbackBeforeMemberJoinGroupCommand = "callbackBeforeMemberJoinGroupCommand"
|
CallbackBeforeMemberJoinGroupCommand = "callbackBeforeMemberJoinGroupCommand"
|
||||||
CallbackBeforeSetGroupMemberInfoCommand = "CallbackBeforeSetGroupMemberInfoCommand"
|
CallbackBeforeSetGroupMemberInfoCommand = "callbackBeforeSetGroupMemberInfoCommand"
|
||||||
|
CallbackAfterSetGroupMemberInfoCommand = "callbackAfterSetGroupMemberInfoCommand"
|
||||||
)
|
)
|
||||||
|
@ -19,6 +19,7 @@ type CallbackBeforeAddFriendReq struct {
|
|||||||
FromUserID string `json:"fromUserID" `
|
FromUserID string `json:"fromUserID" `
|
||||||
ToUserID string `json:"toUserID"`
|
ToUserID string `json:"toUserID"`
|
||||||
ReqMsg string `json:"reqMsg"`
|
ReqMsg string `json:"reqMsg"`
|
||||||
|
Ex string `json:"ex"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type CallbackBeforeAddFriendResp struct {
|
type CallbackBeforeAddFriendResp struct {
|
||||||
@ -35,17 +36,6 @@ type CallBackAddFriendReplyBeforeResp struct {
|
|||||||
CommonCallbackResp
|
CommonCallbackResp
|
||||||
}
|
}
|
||||||
|
|
||||||
type CallbackAfterAddFriendReq struct {
|
|
||||||
CallbackCommand `json:"callbackCommand"`
|
|
||||||
FromUserID string `json:"fromUserID" `
|
|
||||||
ToUserID string `json:"toUserID"`
|
|
||||||
ReqMsg string `json:"reqMsg"`
|
|
||||||
}
|
|
||||||
|
|
||||||
type CallbackAfterAddFriendResp struct {
|
|
||||||
CommonCallbackResp
|
|
||||||
}
|
|
||||||
|
|
||||||
type CallbackBeforeSetFriendRemarkReq struct {
|
type CallbackBeforeSetFriendRemarkReq struct {
|
||||||
CallbackCommand `json:"callbackCommand"`
|
CallbackCommand `json:"callbackCommand"`
|
||||||
OwnerUserID string `json:"ownerUserID"`
|
OwnerUserID string `json:"ownerUserID"`
|
||||||
@ -68,3 +58,70 @@ type CallbackAfterSetFriendRemarkReq struct {
|
|||||||
type CallbackAfterSetFriendRemarkResp struct {
|
type CallbackAfterSetFriendRemarkResp struct {
|
||||||
CommonCallbackResp
|
CommonCallbackResp
|
||||||
}
|
}
|
||||||
|
type CallbackAfterAddFriendReq struct {
|
||||||
|
CallbackCommand `json:"callbackCommand"`
|
||||||
|
FromUserID string `json:"fromUserID" `
|
||||||
|
ToUserID string `json:"toUserID"`
|
||||||
|
ReqMsg string `json:"reqMsg"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type CallbackAfterAddFriendResp struct {
|
||||||
|
CommonCallbackResp
|
||||||
|
}
|
||||||
|
type CallbackBeforeAddBlackReq struct {
|
||||||
|
CallbackCommand `json:"callbackCommand"`
|
||||||
|
OwnerUserID string `json:"ownerUserID" `
|
||||||
|
BlackUserID string `json:"blackUserID"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type CallbackBeforeAddBlackResp struct {
|
||||||
|
CommonCallbackResp
|
||||||
|
}
|
||||||
|
|
||||||
|
type CallbackBeforeAddFriendAgreeReq struct {
|
||||||
|
CallbackCommand `json:"callbackCommand"`
|
||||||
|
FromUserID string `json:"fromUserID" `
|
||||||
|
ToUserID string `json:"blackUserID"`
|
||||||
|
HandleResult int32 `json:"HandleResult"`
|
||||||
|
HandleMsg string `json:"HandleMsg"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type CallbackBeforeAddFriendAgreeResp struct {
|
||||||
|
CommonCallbackResp
|
||||||
|
}
|
||||||
|
|
||||||
|
type CallbackAfterDeleteFriendReq struct {
|
||||||
|
CallbackCommand `json:"callbackCommand"`
|
||||||
|
OwnerUserID string `json:"ownerUserID" `
|
||||||
|
FriendUserID string `json:"friendUserID"`
|
||||||
|
}
|
||||||
|
type CallbackAfterDeleteFriendResp struct {
|
||||||
|
CommonCallbackResp
|
||||||
|
}
|
||||||
|
|
||||||
|
type CallbackBeforeImportFriendsReq struct {
|
||||||
|
CallbackCommand `json:"callbackCommand"`
|
||||||
|
OwnerUserID string `json:"ownerUserID" `
|
||||||
|
FriendUserIDs []string `json:"friendUserIDs"`
|
||||||
|
}
|
||||||
|
type CallbackBeforeImportFriendsResp struct {
|
||||||
|
CommonCallbackResp
|
||||||
|
FriendUserIDs []string `json:"friendUserIDs"`
|
||||||
|
}
|
||||||
|
type CallbackAfterImportFriendsReq struct {
|
||||||
|
CallbackCommand `json:"callbackCommand"`
|
||||||
|
OwnerUserID string `json:"ownerUserID" `
|
||||||
|
FriendUserIDs []string `json:"friendUserIDs"`
|
||||||
|
}
|
||||||
|
type CallbackAfterImportFriendsResp struct {
|
||||||
|
CommonCallbackResp
|
||||||
|
}
|
||||||
|
|
||||||
|
type CallbackAfterRemoveBlackReq struct {
|
||||||
|
CallbackCommand `json:"callbackCommand"`
|
||||||
|
OwnerUserID string `json:"ownerUserID"`
|
||||||
|
BlackUserID string `json:"blackUserID"`
|
||||||
|
}
|
||||||
|
type CallbackAfterRemoveBlackResp struct {
|
||||||
|
CommonCallbackResp
|
||||||
|
}
|
||||||
|
@ -109,56 +109,6 @@ type CallbackAfterSetGroupMemberInfoResp struct {
|
|||||||
CommonCallbackResp
|
CommonCallbackResp
|
||||||
}
|
}
|
||||||
|
|
||||||
type CallbackAfterGroupMemberExitReq struct {
|
|
||||||
CallbackCommand `json:"callbackCommand"`
|
|
||||||
GroupID string `json:"groupID"`
|
|
||||||
UserID string `json:"userID"`
|
|
||||||
GroupType *int32 `json:"groupType"`
|
|
||||||
ExitType string `json:"exitType"`
|
|
||||||
}
|
|
||||||
|
|
||||||
type CallbackAfterGroupMemberExitResp struct {
|
|
||||||
CommonCallbackResp
|
|
||||||
}
|
|
||||||
|
|
||||||
type CallbackAfterUngroupReq struct {
|
|
||||||
CallbackCommand `json:"callbackCommand"`
|
|
||||||
GroupID string `json:"groupID"`
|
|
||||||
GroupType *int32 `json:"groupType"`
|
|
||||||
OwnerID string `json:"ownerID"`
|
|
||||||
MemberList []string `json:"memberList"`
|
|
||||||
}
|
|
||||||
|
|
||||||
type CallbackAfterUngroupResp struct {
|
|
||||||
CommonCallbackResp
|
|
||||||
}
|
|
||||||
|
|
||||||
type CallbackAfterSetGroupInfoReq struct {
|
|
||||||
CallbackCommand `json:"callbackCommand"`
|
|
||||||
GroupID string `json:"groupID"`
|
|
||||||
GroupType *int32 `json:"groupType"`
|
|
||||||
UserID string `json:"userID"`
|
|
||||||
Name string `json:"name"`
|
|
||||||
Notification string `json:"notification"`
|
|
||||||
GroupUrl string `json:"groupUrl"`
|
|
||||||
}
|
|
||||||
|
|
||||||
type CallbackAfterSetGroupInfoResp struct {
|
|
||||||
CommonCallbackResp
|
|
||||||
}
|
|
||||||
|
|
||||||
type CallbackAfterRevokeMsgReq struct {
|
|
||||||
CallbackCommand `json:"callbackCommand"`
|
|
||||||
GroupID string `json:"groupID"`
|
|
||||||
GroupType *int32 `json:"groupType"`
|
|
||||||
UserID string `json:"userID"`
|
|
||||||
Content string `json:"content"`
|
|
||||||
}
|
|
||||||
|
|
||||||
type CallbackAfterRevokeMsgResp struct {
|
|
||||||
CommonCallbackResp
|
|
||||||
}
|
|
||||||
|
|
||||||
type CallbackQuitGroupReq struct {
|
type CallbackQuitGroupReq struct {
|
||||||
CallbackCommand `json:"callbackCommand"`
|
CallbackCommand `json:"callbackCommand"`
|
||||||
GroupID string `json:"groupID"`
|
GroupID string `json:"groupID"`
|
||||||
@ -214,3 +164,72 @@ type CallbackTransferGroupOwnerReq struct {
|
|||||||
type CallbackTransferGroupOwnerResp struct {
|
type CallbackTransferGroupOwnerResp struct {
|
||||||
CommonCallbackResp
|
CommonCallbackResp
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type CallbackBeforeInviteUserToGroupReq struct {
|
||||||
|
CallbackCommand `json:"callbackCommand"`
|
||||||
|
OperationID string `json:"operationID"`
|
||||||
|
GroupID string `json:"groupID"`
|
||||||
|
Reason string `json:"reason"`
|
||||||
|
InvitedUserIDs []string `json:"invitedUserIDs"`
|
||||||
|
}
|
||||||
|
type CallbackBeforeInviteUserToGroupResp struct {
|
||||||
|
CommonCallbackResp
|
||||||
|
RefusedMembersAccount []string `json:"refusedMembersAccount,omitempty"` // Optional field to list members whose invitation is refused.
|
||||||
|
}
|
||||||
|
|
||||||
|
type CallbackAfterJoinGroupReq struct {
|
||||||
|
CallbackCommand `json:"callbackCommand"`
|
||||||
|
OperationID string `json:"operationID"`
|
||||||
|
GroupID string `json:"groupID"`
|
||||||
|
ReqMessage string `json:"reqMessage"`
|
||||||
|
JoinSource int32 `json:"joinSource"`
|
||||||
|
InviterUserID string `json:"inviterUserID"`
|
||||||
|
}
|
||||||
|
type CallbackAfterJoinGroupResp struct {
|
||||||
|
CommonCallbackResp
|
||||||
|
}
|
||||||
|
|
||||||
|
type CallbackBeforeSetGroupInfoReq struct {
|
||||||
|
CallbackCommand `json:"callbackCommand"`
|
||||||
|
OperationID string `json:"operationID"`
|
||||||
|
GroupID string `json:"groupID"`
|
||||||
|
GroupName string `json:"groupName"`
|
||||||
|
Notification string `json:"notification"`
|
||||||
|
Introduction string `json:"introduction"`
|
||||||
|
FaceURL string `json:"faceURL"`
|
||||||
|
Ex string `json:"ex"`
|
||||||
|
NeedVerification int32 `json:"needVerification"`
|
||||||
|
LookMemberInfo int32 `json:"lookMemberInfo"`
|
||||||
|
ApplyMemberFriend int32 `json:"applyMemberFriend"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type CallbackBeforeSetGroupInfoResp struct {
|
||||||
|
CommonCallbackResp
|
||||||
|
GroupID string ` json:"groupID"`
|
||||||
|
GroupName string `json:"groupName"`
|
||||||
|
Notification string `json:"notification"`
|
||||||
|
Introduction string `json:"introduction"`
|
||||||
|
FaceURL string `json:"faceURL"`
|
||||||
|
Ex *string `json:"ex"`
|
||||||
|
NeedVerification *int32 `json:"needVerification"`
|
||||||
|
LookMemberInfo *int32 `json:"lookMemberInfo"`
|
||||||
|
ApplyMemberFriend *int32 `json:"applyMemberFriend"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type CallbackAfterSetGroupInfoReq struct {
|
||||||
|
CallbackCommand `json:"callbackCommand"`
|
||||||
|
OperationID string `json:"operationID"`
|
||||||
|
GroupID string `json:"groupID"`
|
||||||
|
GroupName string `json:"groupName"`
|
||||||
|
Notification string `json:"notification"`
|
||||||
|
Introduction string `json:"introduction"`
|
||||||
|
FaceURL string `json:"faceURL"`
|
||||||
|
Ex *string `json:"ex"`
|
||||||
|
NeedVerification *int32 `json:"needVerification"`
|
||||||
|
LookMemberInfo *int32 `json:"lookMemberInfo"`
|
||||||
|
ApplyMemberFriend *int32 `json:"applyMemberFriend"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type CallbackAfterSetGroupInfoResp struct {
|
||||||
|
CommonCallbackResp
|
||||||
|
}
|
||||||
|
@ -80,26 +80,6 @@ type CallbackMsgModifyCommandResp struct {
|
|||||||
Ex *string `json:"ex"`
|
Ex *string `json:"ex"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type CallbackSendGroupMsgErrorReq struct {
|
|
||||||
CommonCallbackReq
|
|
||||||
GroupID string `json:"groupID"`
|
|
||||||
}
|
|
||||||
|
|
||||||
type CallbackSendGroupMsgErrorResp struct {
|
|
||||||
CommonCallbackResp
|
|
||||||
}
|
|
||||||
|
|
||||||
type CallbackSingleMsgRevokeReq struct {
|
|
||||||
CallbackCommand `json:"callbackCommand"`
|
|
||||||
SendID string `json:"sendID"`
|
|
||||||
ReceiveID string `json:"receiveID"`
|
|
||||||
Content string `json:"content"`
|
|
||||||
}
|
|
||||||
|
|
||||||
type CallbackSingleMsgRevokeResp struct {
|
|
||||||
CommonCallbackResp
|
|
||||||
}
|
|
||||||
|
|
||||||
type CallbackGroupMsgReadReq struct {
|
type CallbackGroupMsgReadReq struct {
|
||||||
CallbackCommand `json:"callbackCommand"`
|
CallbackCommand `json:"callbackCommand"`
|
||||||
SendID string `json:"sendID"`
|
SendID string `json:"sendID"`
|
||||||
|
11
pkg/callbackstruct/revoke.go
Normal file
11
pkg/callbackstruct/revoke.go
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
package callbackstruct
|
||||||
|
|
||||||
|
type CallbackAfterRevokeMsgReq struct {
|
||||||
|
CallbackCommand `json:"callbackCommand"`
|
||||||
|
ConversationID string `json:"conversationID"`
|
||||||
|
Seq int64 `json:"seq"`
|
||||||
|
UserID string `json:"userID"`
|
||||||
|
}
|
||||||
|
type CallbackAfterRevokeMsgResp struct {
|
||||||
|
CommonCallbackResp
|
||||||
|
}
|
@ -16,7 +16,6 @@ package config
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
|
|
||||||
"github.com/OpenIMSDK/tools/discoveryregistry"
|
"github.com/OpenIMSDK/tools/discoveryregistry"
|
||||||
"gopkg.in/yaml.v3"
|
"gopkg.in/yaml.v3"
|
||||||
)
|
)
|
||||||
@ -282,11 +281,25 @@ type configStruct struct {
|
|||||||
CallbackAfterCreateGroup CallBackConfig `yaml:"afterCreateGroup"`
|
CallbackAfterCreateGroup CallBackConfig `yaml:"afterCreateGroup"`
|
||||||
CallbackBeforeMemberJoinGroup CallBackConfig `yaml:"beforeMemberJoinGroup"`
|
CallbackBeforeMemberJoinGroup CallBackConfig `yaml:"beforeMemberJoinGroup"`
|
||||||
CallbackBeforeSetGroupMemberInfo CallBackConfig `yaml:"beforeSetGroupMemberInfo"`
|
CallbackBeforeSetGroupMemberInfo CallBackConfig `yaml:"beforeSetGroupMemberInfo"`
|
||||||
|
CallbackAfterSetGroupMemberInfo CallBackConfig `yaml:"afterSetGroupMemberInfo"`
|
||||||
CallbackQuitGroup CallBackConfig `yaml:"quitGroup"`
|
CallbackQuitGroup CallBackConfig `yaml:"quitGroup"`
|
||||||
CallbackKillGroupMember CallBackConfig `yaml:"killGroupMember"`
|
CallbackKillGroupMember CallBackConfig `yaml:"killGroupMember"`
|
||||||
CallbackDismissGroup CallBackConfig `yaml:"dismissGroup"`
|
CallbackDismissGroup CallBackConfig `yaml:"dismissGroup"`
|
||||||
CallbackBeforeJoinGroup CallBackConfig `yaml:"joinGroup"`
|
CallbackBeforeJoinGroup CallBackConfig `yaml:"joinGroup"`
|
||||||
CallbackTransferGroupOwnerAfter CallBackConfig `yaml:"transferGroupOwner"`
|
CallbackTransferGroupOwnerAfter CallBackConfig `yaml:"transferGroupOwner"`
|
||||||
|
CallbackBeforeInviteUserToGroup CallBackConfig `yaml:"beforeInviteUserToGroup"`
|
||||||
|
CallbackAfterJoinGroup CallBackConfig `yaml:"joinGroupAfter"`
|
||||||
|
CallbackAfterSetGroupInfo CallBackConfig `yaml:"setGroupInfoAfter"`
|
||||||
|
CallbackBeforeSetGroupInfo CallBackConfig `yaml:"setGroupInfoBefore"`
|
||||||
|
CallbackAfterRevokeMsg CallBackConfig `yaml:"revokeMsgAfter"`
|
||||||
|
CallbackBeforeAddBlack CallBackConfig `yaml:"addBlackBefore"`
|
||||||
|
CallbackAfterAddFriend CallBackConfig `yaml:"addFriendAfter"`
|
||||||
|
CallbackBeforeAddFriendAgree CallBackConfig `yaml:"addFriendAgreeBefore"`
|
||||||
|
|
||||||
|
CallbackAfterDeleteFriend CallBackConfig `yaml:"deleteFriendAfter"`
|
||||||
|
CallbackBeforeImportFriends CallBackConfig `yaml:"importFriendsBefore"`
|
||||||
|
CallbackAfterImportFriends CallBackConfig `yaml:"importFriendsAfter"`
|
||||||
|
CallbackAfterRemoveBlack CallBackConfig `yaml:"removeBlackAfter"`
|
||||||
} `yaml:"callback"`
|
} `yaml:"callback"`
|
||||||
|
|
||||||
Prometheus struct {
|
Prometheus struct {
|
||||||
|
@ -386,10 +386,9 @@ def "IOS_PUSH_SOUND" "xxx" # IOS推送声音
|
|||||||
def "IOS_BADGE_COUNT" "true" # IOS徽章计数
|
def "IOS_BADGE_COUNT" "true" # IOS徽章计数
|
||||||
def "IOS_PRODUCTION" "false" # IOS生产
|
def "IOS_PRODUCTION" "false" # IOS生产
|
||||||
# callback 配置
|
# callback 配置
|
||||||
def "CALLBACK_ENABLE" "true" # 是否开启 Callback
|
def "CALLBACK_ENABLE" "false" # 是否开启 Callback
|
||||||
def "CALLBACK_TIMEOUT" "5" # 最长超时时间
|
def "CALLBACK_TIMEOUT" "5" # 最长超时时间
|
||||||
def "CALLBACK_FAILED_CONTINUE" "true" # 失败后是否继续
|
def "CALLBACK_FAILED_CONTINUE" "true" # 失败后是否继续
|
||||||
|
|
||||||
###################### Prometheus 配置信息 ######################
|
###################### Prometheus 配置信息 ######################
|
||||||
# 是否启用 Prometheus
|
# 是否启用 Prometheus
|
||||||
readonly PROMETHEUS_ENABLE=${PROMETHEUS_ENABLE:-'false'}
|
readonly PROMETHEUS_ENABLE=${PROMETHEUS_ENABLE:-'false'}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user