|
- package service
-
- import (
- "context"
- "gim/internal/business/domain/user/model"
- "gim/internal/business/domain/user/repo"
- "gim/pkg/gerrors"
- "gim/pkg/pb"
- "gim/pkg/rpc"
- "time"
- )
-
- type authService struct{}
-
- var AuthService = new(authService)
-
- // SignIn 登录
- func (*authService) SignIn(ctx context.Context, phoneNumber, code string, deviceId int64) (bool, int64, string, error) {
- if !Verify(phoneNumber, code) {
- return false, 0, "", gerrors.ErrBadCode
- }
-
- user, err := repo.UserRepo.GetByPhoneNumber(phoneNumber)
- if err != nil {
- return false, 0, "", err
- }
-
- var isNew = false
- if user == nil {
- user = &model.User{
- PhoneNumber: phoneNumber,
- CreateTime: time.Now(),
- UpdateTime: time.Now(),
- }
- err := repo.UserRepo.Save(user)
- if err != nil {
- return false, 0, "", err
- }
- isNew = true
- }
-
- resp, err := rpc.GetLogicIntClient().GetDevice(ctx, &pb.GetDeviceReq{DeviceId: deviceId})
- if err != nil {
- return false, 0, "", err
- }
-
- // 方便测试
- token := "0"
- //token := util.RandString(40)
- err = repo.AuthRepo.Set(user.Id, resp.Device.DeviceId, model.Device{
- Type: resp.Device.Type,
- Token: token,
- Expire: time.Now().AddDate(0, 3, 0).Unix(),
- })
- if err != nil {
- return false, 0, "", err
- }
-
- return isNew, user.Id, token, nil
- }
-
- func Verify(phoneNumber, code string) bool {
- // 假装他成功了
- return true
- }
-
- // Auth 验证用户是否登录
- func (*authService) Auth(ctx context.Context, userId, deviceId int64, token string) error {
- device, err := repo.AuthRepo.Get(userId, deviceId)
- if err != nil {
- return err
- }
-
- if device == nil {
- return gerrors.ErrUnauthorized
- }
-
- if device.Expire < time.Now().Unix() {
- return gerrors.ErrUnauthorized
- }
-
- if device.Token != token {
- return gerrors.ErrUnauthorized
- }
- return nil
- }
|