feat:增加用户资产和会员状态

This commit is contained in:
henry
2021-12-10 11:34:19 +08:00
parent 626f30a2bd
commit 2ee564d540
13 changed files with 188 additions and 31 deletions

View File

@ -7,6 +7,7 @@ import (
"SciencesServer/config"
"SciencesServer/utils"
"fmt"
"time"
)
type Instance struct{}
@ -19,6 +20,9 @@ type (
InstanceLoginParams struct {
UID uint64
Avatar, Name, Mobile string
Vip bool
VipDeadline time.Time
Currency float64
Identity, SelectIdentity int
Status model.AccountStatusKind
}
@ -39,6 +43,9 @@ func (c *Instance) Login() InstanceLoginCallback {
_session.Avatar = params.Avatar
_session.Name = params.Name
_session.Mobile = params.Mobile
_session.Vip = params.Vip
_session.VipDeadline = params.VipDeadline
_session.Currency = params.Currency
_session.Identity = params.Identity
_session.SelectIdentity = params.SelectIdentity

View File

@ -1,12 +1,14 @@
package account
import (
model3 "SciencesServer/app/api/enterprise/model"
"SciencesServer/app/api/enterprise/model"
model2 "SciencesServer/app/common/model"
"SciencesServer/app/handle"
"SciencesServer/config"
"SciencesServer/serve/orm"
"SciencesServer/utils"
"errors"
"gorm.io/gorm"
)
type Login struct{ local string }
@ -58,32 +60,47 @@ func loginForSmsCaptcha(params *LoginParams, local string) (*InstanceLoginParams
}
var isExist bool
// 查询账号信息
mUserInstance := model3.NewUserInstance()
mUserInstance := model.NewUserInstance()
if isExist, err = model2.FirstField(mUserInstance.UserInstance, []string{"id", "uuid", "avatar", "name", "mobile", "status"},
if isExist, err = model2.FirstField(mUserInstance.UserInstance, []string{"id", "uuid", "avatar", "name", "mobile",
"is_vip", "vip_deadline", "status"},
model2.NewWhere("mobile", params.Captcha.Mobile)); err != nil {
return nil, err
}
mUserIdentity := model3.NewUserIdentity()
mUserIdentity := model.NewUserIdentity()
// 用户资产信息
mUserAssets := new(model.UserAssets)
if isExist {
// 查询该区域下最后一次选中的信息
if err = mUserIdentity.LastChooseInfo(mUserInstance.UUID); err != nil {
return nil, err
}
if mUserAssets, err = model.NewUserAssets().Assets(mUserInstance.UUID); err != nil {
return nil, err
}
goto RETURNS
}
mUserInstance.Name = params.Captcha.Mobile
mUserInstance.Mobile = params.Captcha.Mobile
mUserInstance.Password = utils.GetRandomString(12)
if err = orm.GetDB().Transaction(func(tx *gorm.DB) error {
mUserInstance.Name = params.Captcha.Mobile
mUserInstance.Mobile = params.Captcha.Mobile
mUserInstance.Password = utils.GetRandomString(12)
if err = model2.Create(mUserInstance.UserInstance); err != nil {
if err = model2.Create(mUserInstance.UserInstance, tx); err != nil {
return err
}
mUserAssets.UID = mUserInstance.UUID
return model2.Create(mUserAssets.UserAssets, tx)
}); err != nil {
return nil, err
}
RETURNS:
return &InstanceLoginParams{
UID: mUserInstance.UUID,
Avatar: mUserInstance.GetAvatarAttribute(config.SettingInfo.Domain), Name: mUserInstance.Name, Mobile: mUserInstance.Mobile,
Vip: mUserInstance.VipStatus(), VipDeadline: mUserInstance.VipDeadline, Currency: mUserAssets.Currency,
Identity: mUserInstance.Identity, SelectIdentity: mUserIdentity.Identity,
Status: mUserInstance.Status,
}, nil
@ -94,9 +111,10 @@ func loginForPassword(params *LoginParams, local string) (*InstanceLoginParams,
if !utils.ValidateMobile(params.Password.Account) {
return nil, errors.New("操作错误,手机号码格式异常")
}
mUserInstance := model3.NewUserInstance()
mUserInstance := model.NewUserInstance()
isExist, err := model2.FirstField(mUserInstance.UserInstance, []string{"id", "uuid", "name", "avatar", "mobile", "password", "salt", "status"},
isExist, err := model2.FirstField(mUserInstance.UserInstance, []string{"id", "uuid", "name", "avatar", "mobile",
"is_vip", "vip_deadline", "password", "salt", "status"},
model2.NewWhere("mobile", params.Password.Account))
if err != nil {
@ -107,8 +125,14 @@ func loginForPassword(params *LoginParams, local string) (*InstanceLoginParams,
if !mUserInstance.ValidatePassword(params.Password.Password) {
return nil, errors.New("操作错误,账户或密码错误")
}
// 用户资产信息
mUserAssets := new(model.UserAssets)
if mUserAssets, err = model.NewUserAssets().Assets(mUserInstance.UUID); err != nil {
return nil, err
}
// 最后一次选中的身份信息
mUserIdentity := model3.NewUserIdentity()
mUserIdentity := model.NewUserIdentity()
if err = mUserIdentity.LastChooseInfo(mUserInstance.UUID); err != nil {
return nil, err
@ -116,6 +140,7 @@ func loginForPassword(params *LoginParams, local string) (*InstanceLoginParams,
return &InstanceLoginParams{
UID: mUserInstance.UUID,
Avatar: mUserInstance.GetAvatarAttribute(config.SettingInfo.Domain), Name: mUserInstance.Name, Mobile: mUserInstance.Mobile,
Vip: mUserInstance.VipStatus(), VipDeadline: mUserInstance.VipDeadline, Currency: mUserAssets.Currency,
Identity: mUserInstance.Identity, SelectIdentity: mUserIdentity.Identity,
Status: mUserInstance.Status,
}, nil

View File

@ -0,0 +1,24 @@
package home
import "SciencesServer/app/session"
type Instance struct {
*session.Enterprise
local string
}
type InstanceHandle func(session *session.Enterprise, local string) *Instance
type InstanceInfo struct {
Currency float64 `json:"currency"`
}
func (c *Instance) Instance() (*InstanceInfo, error) {
return &InstanceInfo{Currency: c.Currency}, nil
}
func NewInstance() InstanceHandle {
return func(session *session.Enterprise, local string) *Instance {
return &Instance{Enterprise: session, local: local}
}
}

View File

@ -0,0 +1,15 @@
package user
import "SciencesServer/app/session"
type Assets struct {
*session.Enterprise
}
type AssetsHandle func(session *session.Enterprise) *Assets
func NewAssets() AssetsHandle {
return func(session *session.Enterprise) *Assets {
return &Assets{Enterprise: session}
}
}

View File

@ -17,10 +17,13 @@ type InstanceHandle func(session *session.Enterprise) *Instance
type (
// InstanceInfo 基本信息
InstanceInfo struct {
Avatar string `json:"avatar"` // 头像
Name string `json:"name"` // 名称
Identity int `json:"identity"` // 具体身份
SelectIdentity int `json:"select_identity"` // 最后一次选中的身份信息
Avatar string `json:"avatar"` // 头像
Name string `json:"name"` // 名称
Currency float64 `json:"currency"` // 创新币
Vip bool `json:"vip"` // Vip状态
VipDays int `json:"vip_days"` // Vip剩余天数
Identity int `json:"identity"` // 具体身份
SelectIdentity int `json:"select_identity"` // 最后一次选中的身份信息
}
// InstanceDetailInfo 详细信息
InstanceDetailInfo struct {
@ -33,7 +36,16 @@ type (
// Info 基本信息
func (c *Instance) Info() *InstanceInfo {
return &InstanceInfo{Avatar: c.Avatar, Name: c.Name, Identity: c.Identity, SelectIdentity: c.SelectIdentity}
out := &InstanceInfo{Avatar: c.Avatar, Name: c.Name,
Currency: c.Currency,
Vip: c.VipStatus(),
Identity: c.Identity,
SelectIdentity: c.SelectIdentity}
if out.Vip {
out.VipDays = utils.DiffTimeDays(time.Now(), c.VipDeadline)
}
return out
}
// BindMobile 绑定手机号码