add: some user api and all api desc
This commit is contained in:
@@ -2,6 +2,10 @@ package logic
|
||||
|
||||
import (
|
||||
"context"
|
||||
"encoding/json"
|
||||
"errors"
|
||||
"juwan-backend/app/snowflake/rpc/snowflake"
|
||||
"juwan-backend/app/user_verifications/rpc/internal/models/schema"
|
||||
|
||||
"juwan-backend/app/user_verifications/rpc/internal/svc"
|
||||
"juwan-backend/app/user_verifications/rpc/pb"
|
||||
@@ -25,7 +29,28 @@ func NewAddUserVerificationsLogic(ctx context.Context, svcCtx *svc.ServiceContex
|
||||
|
||||
// -----------------------userVerifications-----------------------
|
||||
func (l *AddUserVerificationsLogic) AddUserVerifications(in *pb.AddUserVerificationsReq) (*pb.AddUserVerificationsResp, error) {
|
||||
// todo: add your logic here and delete this line
|
||||
nextIdResp, err := l.svcCtx.SnowflakeRpc.NextId(l.ctx, &snowflake.NextIdReq{})
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
materials := schema.MaterialStruct{}
|
||||
err = json.Unmarshal([]byte(in.Materials), &materials)
|
||||
if err != nil {
|
||||
logx.Errorf("Unmarshal %v materials failed: %s", in.Materials, err)
|
||||
return nil, errors.New("bad input materials")
|
||||
}
|
||||
|
||||
err = l.svcCtx.UserVeriModelRW.Create().
|
||||
SetID(nextIdResp.Id).
|
||||
SetUserID(in.UserId).
|
||||
SetRole(in.Role).
|
||||
SetStatus("padding").
|
||||
SetMaterials(materials).
|
||||
Exec(l.ctx)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
return &pb.AddUserVerificationsResp{}, nil
|
||||
}
|
||||
|
||||
@@ -25,6 +25,9 @@ func NewDelUserVerificationsLogic(ctx context.Context, svcCtx *svc.ServiceContex
|
||||
|
||||
func (l *DelUserVerificationsLogic) DelUserVerifications(in *pb.DelUserVerificationsReq) (*pb.DelUserVerificationsResp, error) {
|
||||
// todo: add your logic here and delete this line
|
||||
|
||||
err := l.svcCtx.UserVeriModelRW.DeleteOneID(in.Id).Exec(l.ctx)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return &pb.DelUserVerificationsResp{}, nil
|
||||
}
|
||||
|
||||
@@ -2,10 +2,12 @@ package logic
|
||||
|
||||
import (
|
||||
"context"
|
||||
"errors"
|
||||
|
||||
"juwan-backend/app/user_verifications/rpc/internal/svc"
|
||||
"juwan-backend/app/user_verifications/rpc/pb"
|
||||
|
||||
"github.com/jinzhu/copier"
|
||||
"github.com/zeromicro/go-zero/core/logx"
|
||||
)
|
||||
|
||||
@@ -24,7 +26,23 @@ func NewGetUserVerificationsByIdLogic(ctx context.Context, svcCtx *svc.ServiceCo
|
||||
}
|
||||
|
||||
func (l *GetUserVerificationsByIdLogic) GetUserVerificationsById(in *pb.GetUserVerificationsByIdReq) (*pb.GetUserVerificationsByIdResp, error) {
|
||||
// todo: add your logic here and delete this line
|
||||
userVerification, err := l.svcCtx.UserVeriModelRO.Get(l.ctx, in.Id)
|
||||
if err != nil {
|
||||
logx.Errorf("GetUserVerificationsById err: %v", err)
|
||||
return nil, errors.New("get VerificationsById err")
|
||||
}
|
||||
pbVerification := pb.UserVerifications{}
|
||||
err = copier.Copy(&pbVerification, userVerification)
|
||||
if err != nil {
|
||||
logx.Errorf("copier copy err: %v", err)
|
||||
return nil, errors.New("copy Verification err")
|
||||
}
|
||||
createAt := userVerification.CreatedAt.Unix()
|
||||
updateAt := userVerification.UpdatedAt.Unix()
|
||||
pbVerification.CreatedAt = createAt
|
||||
pbVerification.UpdatedAt = updateAt
|
||||
|
||||
return &pb.GetUserVerificationsByIdResp{}, nil
|
||||
return &pb.GetUserVerificationsByIdResp{
|
||||
UserVerifications: &pbVerification,
|
||||
}, nil
|
||||
}
|
||||
|
||||
@@ -2,10 +2,13 @@ package logic
|
||||
|
||||
import (
|
||||
"context"
|
||||
|
||||
"errors"
|
||||
"juwan-backend/app/user_verifications/rpc/internal/models"
|
||||
"juwan-backend/app/user_verifications/rpc/internal/models/userverifications"
|
||||
"juwan-backend/app/user_verifications/rpc/internal/svc"
|
||||
"juwan-backend/app/user_verifications/rpc/pb"
|
||||
|
||||
"github.com/jinzhu/copier"
|
||||
"github.com/zeromicro/go-zero/core/logx"
|
||||
)
|
||||
|
||||
@@ -24,7 +27,50 @@ func NewSearchUserVerificationsLogic(ctx context.Context, svcCtx *svc.ServiceCon
|
||||
}
|
||||
|
||||
func (l *SearchUserVerificationsLogic) SearchUserVerifications(in *pb.SearchUserVerificationsReq) (*pb.SearchUserVerificationsResp, error) {
|
||||
// todo: add your logic here and delete this line
|
||||
|
||||
return &pb.SearchUserVerificationsResp{}, nil
|
||||
if in.Limit > 1000 {
|
||||
logx.Errorf("Limit exceeds max limit: %d", in.Limit)
|
||||
return nil, errors.New("limit exceeds max limit")
|
||||
}
|
||||
verifications, err := l.svcCtx.UserVeriModelRO.Query().Where(userverifications.Or(
|
||||
userverifications.UserIDEQ(in.UserId),
|
||||
userverifications.StatusEQ(in.Status),
|
||||
userverifications.Role(in.Role),
|
||||
)).
|
||||
Offset(int(in.Page * in.Limit)).
|
||||
Limit(int(in.Limit)).
|
||||
All(l.ctx)
|
||||
if err != nil {
|
||||
logx.Errorf("Get all verifications err: %s", err.Error())
|
||||
return nil, errors.New("get all verifications err")
|
||||
}
|
||||
return &pb.SearchUserVerificationsResp{
|
||||
UserVerifications: convertModelUserVerificationsToProto(verifications),
|
||||
}, nil
|
||||
}
|
||||
|
||||
func convertModelUserVerificationToProto(modelUserVerification *models.UserVerifications) *pb.UserVerifications {
|
||||
|
||||
if modelUserVerification == nil {
|
||||
return nil
|
||||
}
|
||||
out := &pb.UserVerifications{}
|
||||
err := copier.Copy(out, modelUserVerification)
|
||||
if err != nil {
|
||||
logx.Errorf("copy modelUserVerification err: %s", err.Error())
|
||||
return out
|
||||
}
|
||||
|
||||
out.CreatedAt = modelUserVerification.CreatedAt.Unix()
|
||||
out.UpdatedAt = modelUserVerification.UpdatedAt.Unix()
|
||||
return out
|
||||
}
|
||||
|
||||
func convertModelUserVerificationsToProto(modelUserVerifications []*models.UserVerifications) []*pb.UserVerifications {
|
||||
|
||||
out := make([]*pb.UserVerifications, 0, len(modelUserVerifications))
|
||||
for _, modelUserVerification := range modelUserVerifications {
|
||||
out = append(out, convertModelUserVerificationToProto(modelUserVerification))
|
||||
}
|
||||
|
||||
return out
|
||||
}
|
||||
|
||||
@@ -2,6 +2,9 @@ package logic
|
||||
|
||||
import (
|
||||
"context"
|
||||
"encoding/json"
|
||||
"errors"
|
||||
"juwan-backend/app/user_verifications/rpc/internal/models/schema"
|
||||
|
||||
"juwan-backend/app/user_verifications/rpc/internal/svc"
|
||||
"juwan-backend/app/user_verifications/rpc/pb"
|
||||
@@ -24,7 +27,31 @@ func NewUpdateUserVerificationsLogic(ctx context.Context, svcCtx *svc.ServiceCon
|
||||
}
|
||||
|
||||
func (l *UpdateUserVerificationsLogic) UpdateUserVerifications(in *pb.UpdateUserVerificationsReq) (*pb.UpdateUserVerificationsResp, error) {
|
||||
// todo: add your logic here and delete this line
|
||||
var materials *schema.MaterialStruct
|
||||
materials = nil
|
||||
if in.Materials != nil {
|
||||
err := json.Unmarshal([]byte(*in.Materials), &materials)
|
||||
if err != nil {
|
||||
logx.Errorf("Unmarshal materials failed, err:%v.", err)
|
||||
return nil, errors.New("bad input materials")
|
||||
}
|
||||
if len(materials.GameScreenshots) > 20 {
|
||||
logx.Errorf("User %v upload oo many game screenshots: %d", in.UserId, len(materials.GameScreenshots))
|
||||
return nil, errors.New("too many game screenshots")
|
||||
}
|
||||
}
|
||||
|
||||
_, err := l.svcCtx.UserVeriModelRW.UpdateOneID(in.Id).
|
||||
SetNillableRejectReason(in.RejectReason).
|
||||
SetNillableMaterials(materials).
|
||||
SetNillableRole(in.Role).
|
||||
SetNillableStatus(in.Status).
|
||||
SetReviewedBy(in.ReviewedBy).
|
||||
Save(l.ctx)
|
||||
if err != nil {
|
||||
logx.Errorf("save user verifications failed, err:%v.", err)
|
||||
return nil, errors.New("save user verifications failed")
|
||||
}
|
||||
|
||||
return &pb.UpdateUserVerificationsResp{}, nil
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user