155 lines
4.0 KiB
Go
155 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) {
|
|
var (
|
|
sociaty *pb.DBSociaty
|
|
err error
|
|
)
|
|
|
|
if errdata = this.ApplyCheck(session, req); errdata != nil {
|
|
return
|
|
}
|
|
|
|
uid := session.GetUserId()
|
|
|
|
if sociaty, err = this.module.modelSociaty.getSociaty(req.SociatyId); err != nil {
|
|
errdata = &pb.ErrorData{
|
|
Code: pb.ErrorCode_SociatyNoFound,
|
|
Title: pb.ErrorCode_SociatyNoFound.ToString(),
|
|
Message: err.Error(),
|
|
}
|
|
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.Clone(), comm.GetBuriedParam(comm.Rtype109, 1))
|
|
}
|
|
rsp := &pb.SociatyApplyResp{
|
|
Uid: uid,
|
|
ScoiatyId: req.SociatyId,
|
|
}
|
|
session.SendMsg(string(this.module.GetType()), SociatySubTypeApply, rsp)
|
|
return
|
|
}
|