You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

140 lines
3.5 KiB

2 years ago
package data
import (
"context"
"customer/internal/biz"
"database/sql"
"fmt"
"github.com/go-kratos/kratos/v2/errors"
"github.com/golang-jwt/jwt/v4"
"gorm.io/gorm"
"time"
)
// customer 中与数据操作相关的代码
type CustomerData struct {
data *Data
}
// New 方法
func NewCustomerData(data *Data) *CustomerData {
return &CustomerData{data: data}
}
// 设置验证码的方法
func (cd CustomerData) SetVerifyCode(telephone, code string, ex int64) error {
// 设置key, customer-verify-code
status := cd.data.Rdb.Set(context.Background(), "CVC:"+telephone, code, time.Duration(ex)*time.Second)
if _, err := status.Result(); err != nil {
return err
}
return nil
}
// 获取号码对应的验证码
func (cd CustomerData) GetVerifyCode(telephone string) string {
status := cd.data.Rdb.Get(context.Background(), "CVC:"+telephone)
code, _ := status.Result() // status.String()
return code
}
// 根据电话,获取顾客信息
func (cd CustomerData) GetCustomerByTelephone(telephone string) (*biz.Customer, error) {
// 查询基于电话
customer := &biz.Customer{}
result := cd.data.Mdb.Where("telephone=?", telephone).First(customer)
// query 执行成功,同时查询到记录
if result.Error == nil && customer.ID > 0 {
return customer, nil
}
// 有记录不存在的错误
if result.Error != nil && errors.Is(result.Error, gorm.ErrRecordNotFound) {
// 创建customer并返回
customer.Telephone = telephone
customer.Name = sql.NullString{Valid: false}
customer.Email = sql.NullString{Valid: false}
customer.Wechat = sql.NullString{Valid: false}
resultCreate := cd.data.Mdb.Create(customer)
// 插入成功
if resultCreate.Error != nil {
return nil, resultCreate.Error
} else {
return customer, nil
}
}
// 有错误,但是不是记录不存在的错误,不做业务逻辑处理
return nil, result.Error
}
// 生成Token和存储
func (cd CustomerData) GenerateTokenAndSave(c *biz.Customer, duration time.Duration, secret string) (string, error) {
// 一生成token
// 处理token中的数据
// 标准的 JWT 的 payload
claims := jwt.RegisteredClaims{
// 签发方,签发机构
Issuer: "LaoMaDJ",
// 说明
Subject: "customer-authentication",
// 签发给谁使用
Audience: []string{"customer", "other"},
// 有效期至
ExpiresAt: jwt.NewNumericDate(time.Now().Add(duration)),
// 何时启用
NotBefore: nil,
// 签发时间
IssuedAt: jwt.NewNumericDate(time.Now()),
// ID, 用户的ID
ID: fmt.Sprintf("%d", c.ID),
}
// 生成token
token := jwt.NewWithClaims(jwt.SigningMethodHS256, claims)
// 签名token
signedToken, err := token.SignedString([]byte(secret))
if err != nil {
return "", err
}
// 二,存储
c.Token = signedToken
c.TokenCreatedAt = sql.NullTime{
Time: time.Now(),
Valid: true,
}
if result := cd.data.Mdb.Save(c); result.Error != nil {
return "", result.Error
}
// 操作成功
return signedToken, nil
}
// 利用顾客ID获取对应的token
func (cd CustomerData) GetToken(id interface{}) (string, error) {
c := &biz.Customer{}
if result := cd.data.Mdb.First(c, id); result.Error != nil {
return "", result.Error
}
return c.Token, nil
}
// 利用顾客ID删除对应的token
func (cd CustomerData) DelToken(id interface{}) error {
c := &biz.Customer{}
// 找到customer
if result := cd.data.Mdb.First(c, id); result.Error != nil {
return result.Error
}
// 删除customer的token
c.Token = ""
c.TokenCreatedAt = sql.NullTime{Valid: false}
cd.data.Mdb.Save(c)
return nil
}