go_dreamfactory/modules/sociaty/api_cross_apply.go
2023-06-06 17:43:22 +08:00

150 lines
4.0 KiB
Go

package sociaty
import (
"errors"
"fmt"
"go_dreamfactory/comm"
"go_dreamfactory/lego/sys/log"
"go_dreamfactory/pb"
"go_dreamfactory/utils"
)
// 公会申请
func (this *apiComp) ApplyCheck(session comm.IUserSession, req *pb.SociatyApplyReq) (errdata *pb.ErrorData) {
if req.SociatyId == "" {
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) Apply(session comm.IUserSession, req *pb.SociatyApplyReq) (errdata *pb.ErrorData) {
if errdata = this.ApplyCheck(session, req); errdata != nil {
return
}
uid := session.GetUserId()
sociaty := this.module.modelSociaty.getSociaty(req.SociatyId)
if sociaty == nil {
errdata = &pb.ErrorData{
Code: pb.ErrorCode_SociatyNoFound,
Title: pb.ErrorCode_SociatyNoFound.ToString(),
}
return
}
// userex
userEx, err := this.module.ModuleUser.GetUserExpand(uid)
if err != nil {
this.module.Error("GetRemoteUserExpand", log.Field{Key: "uid", Value: uid}, log.Field{Key: "err", Value: err.Error()})
errdata = &pb.ErrorData{
Code: pb.ErrorCode_UserNofound,
Title: pb.ErrorCode_UserNofound.ToString(),
}
return
}
if utils.IsInCDHour(userEx.SociatyCd) {
errdata = &pb.ErrorData{
Code: pb.ErrorCode_SociatyCDLimit,
Title: pb.ErrorCode_SociatyCDLimit.ToString(),
Message: fmt.Sprintf("CD内[%v]不允许申请", userEx.SociatyCd),
}
return
}
// 是否公会成员
if this.module.modelSociaty.isMember(uid, sociaty) {
errdata = &pb.ErrorData{
Code: pb.ErrorCode_SociatyBelongTo,
Title: pb.ErrorCode_SociatyBelongTo.ToString(),
Message: fmt.Sprintf("[%v]已经是公会[%v]成员", uid, sociaty.Name),
}
return
}
user := this.module.ModuleUser.GetUser(uid)
if user == nil {
errdata = &pb.ErrorData{
Code: pb.ErrorCode_UserNofound,
Title: pb.ErrorCode_UserNofound.ToString(),
Datastring: uid,
}
return
}
// 是否达到入会等级
if user.Lv < sociaty.ApplyLv {
errdata = &pb.ErrorData{
Code: pb.ErrorCode_SociatyAppyLvNoEnough,
Title: pb.ErrorCode_SociatyAppyLvNoEnough.ToString(),
Message: fmt.Sprintf("实际等级:%v 期望等级:%v", user.Lv, sociaty.ApplyLv),
}
return
}
// 是否已申请
if this.module.modelSociaty.isApplied(uid, sociaty) {
errdata = &pb.ErrorData{
Code: pb.ErrorCode_SociatyApplied,
Title: pb.ErrorCode_SociatyApplied.ToString(),
Message: fmt.Sprintf("[%v]已申请", sociaty.Name),
}
return
}
//判断申请人数是否超出最大允许申请数
if len(sociaty.ApplyRecord) >= int(this.module.globalConf.GuildAcceptApplyMax) {
errdata = &pb.ErrorData{
Code: pb.ErrorCode_SociatyApplyMax,
Title: pb.ErrorCode_SociatyApplyMax.ToString(),
Message: fmt.Sprintf("实际人数:%d 期望人数:%d", len(sociaty.ApplyRecord), int(this.module.globalConf.GuildAcceptApplyMax)),
}
return
}
// 申请
isCheck, err := this.module.modelSociaty.apply(uid, sociaty)
if err != nil {
var customError = new(comm.CustomError)
if errors.As(err, &customError) {
code := customError.Code
errdata = &pb.ErrorData{
Code: code,
Title: code.ToString(),
Message: err.Error(),
}
} 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: req.SociatyId},
log.Field{Key: "err", Value: err.Error()},
)
return
}
// 无需审核
if !isCheck {
// 触发任务条件
go this.module.ModuleBuried.TriggerBuried(session.GetUserId(), comm.GetBuriedParam(comm.Rtype109, 1))
}
rsp := &pb.SociatyApplyResp{
Uid: uid,
ScoiatyId: req.SociatyId,
}
session.SendMsg(string(this.module.GetType()), SociatySubTypeApply, rsp)
return
}