add: some user api and all api desc

This commit is contained in:
wwweww
2026-02-27 19:17:01 +08:00
parent a0c720eb2f
commit 5930fb0dde
156 changed files with 9457 additions and 1086 deletions
@@ -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
}