104 lines
2.9 KiB
Go
104 lines
2.9 KiB
Go
package sociaty
|
|
|
|
import (
|
|
"errors"
|
|
"go_dreamfactory/comm"
|
|
"go_dreamfactory/lego/sys/log"
|
|
"go_dreamfactory/pb"
|
|
)
|
|
|
|
// 公会转让
|
|
func (this *apiComp) AssignCheck(session comm.IUserSession, req *pb.SociatyAssignReq) (errdata *pb.ErrorData) {
|
|
if req.TargetId == "" {
|
|
errdata = &pb.ErrorData{
|
|
Code: pb.ErrorCode_ReqParameterError,
|
|
Title: pb.ErrorCode_ReqParameterError.ToString(),
|
|
}
|
|
this.module.Error("公会转让参数错误", log.Field{Key: "uid", Value: session.GetUserId()}, log.Field{Key: "params", Value: req.String()})
|
|
}
|
|
return
|
|
}
|
|
|
|
func (this *apiComp) Assign(session comm.IUserSession, req *pb.SociatyAssignReq) (errdata *pb.ErrorData) {
|
|
if errdata = this.AssignCheck(session, req); errdata != nil {
|
|
return
|
|
}
|
|
data = &pb.ErrorData{}
|
|
uid := session.GetUserId()
|
|
if uid == req.TargetId {
|
|
errdata = &pb.ErrorData{
|
|
Code: pb.ErrorCode_ReqParameterError,
|
|
Title: pb.ErrorCode_ReqParameterError.ToString(),
|
|
}
|
|
this.module.Error("不能转让给自己", log.Field{Key: "uid", Value: uid})
|
|
return
|
|
}
|
|
|
|
sociaty := this.module.modelSociaty.getUserSociaty(uid)
|
|
if sociaty == nil {
|
|
code = pb.ErrorCode_SociatyNoFound
|
|
this.module.Error("当前玩家所在的公会未找到", log.Field{Key: "uid", Value: uid})
|
|
return
|
|
}
|
|
|
|
// 校验权限
|
|
if !this.module.modelSociaty.isRight(uid, sociaty, pb.SociatyJob_PRESIDENT) {
|
|
code = pb.ErrorCode_SociatyNoRight
|
|
return
|
|
}
|
|
|
|
// 校验目标是否公会成员
|
|
if !this.module.modelSociaty.isMember(req.TargetId, sociaty) {
|
|
code = pb.ErrorCode_SociatyNoMember
|
|
return
|
|
}
|
|
|
|
// 公会转让
|
|
if err := this.module.modelSociaty.assign(uid, req.TargetId, sociaty); err != nil {
|
|
errdata = &pb.ErrorData{
|
|
Code: pb.ErrorCode_DBError,
|
|
Title: pb.ErrorCode_DBError.ToString(),
|
|
Message: err.Error(),
|
|
}
|
|
this.module.Error("公会转让",
|
|
log.Field{Key: "uid", Value: uid},
|
|
log.Field{Key: "sociatyId", Value: sociaty.Id},
|
|
log.Field{Key: "targetId", Value: req.TargetId},
|
|
log.Field{Key: "uid", Value: err.Error()},
|
|
)
|
|
return
|
|
}
|
|
|
|
// 添加日志(成员职位变动)
|
|
if err := this.module.modelSociatyLog.addLog(Log_Job, sociaty.Id,
|
|
uid, req.TargetId, pb.SociatyJob_PRESIDENT.String()); err != nil {
|
|
var customErr = new(comm.CustomError)
|
|
if errors.As(err, &customErr) {
|
|
code = customErr.Code
|
|
} else {
|
|
errdata = &pb.ErrorData{
|
|
Code: pb.ErrorCode_DBError,
|
|
Title: pb.ErrorCode_DBError.ToString(),
|
|
Message: err.Error(),
|
|
}
|
|
}
|
|
this.module.Error("公会转让日志",
|
|
log.Field{Key: "uid", Value: uid},
|
|
log.Field{Key: "sociatyId", Value: sociaty.Id},
|
|
log.Field{Key: "targetId", Value: req.TargetId},
|
|
log.Field{Key: "日志模板", Value: Log_Job},
|
|
log.Field{Key: "err", Value: err.Error()},
|
|
)
|
|
}
|
|
|
|
rsp := &pb.SociatyAssignResp{
|
|
TargetId: req.TargetId,
|
|
SociatyId: sociaty.Id,
|
|
}
|
|
|
|
if err := session.SendMsg(string(this.module.GetType()), SociatySubTypeAssign, rsp); err != nil {
|
|
code = pb.ErrorCode_SystemError
|
|
}
|
|
return
|
|
}
|