feat(auth): 添加设备绑定和解绑的日志记录和缓存清理
Some checks failed
Build docker and publish / build (20.15.1) (push) Has been cancelled

在设备绑定和解绑逻辑中添加详细的日志记录,包括用户ID、设备标识符和限制检查
解绑时增加设备管理器的踢出操作,确保设备状态同步
This commit is contained in:
shanshanzhong 2025-12-02 01:38:32 -08:00
parent 6b65ffb728
commit d546ea6502
2 changed files with 65 additions and 42 deletions

View File

@ -92,7 +92,18 @@ func (l *BindDeviceLogic) createDeviceForUser(identifier, ip, userAgent string,
if limit := l.svcCtx.SessionLimit(); limit > 0 {
if _, count, err := l.svcCtx.UserModel.QueryDeviceList(l.ctx, userId); err == nil {
if count >= limit {
l.Infow("device bind blocked by limit",
logger.Field("user_id", userId),
logger.Field("identifier", identifier),
logger.Field("count", count),
logger.Field("limit", limit))
return xerr.NewErrCodeMsg(xerr.DeviceBindLimitExceeded, "账户绑定设备数已达上限,请移除其他设备后再登录,您也可以再注册一个新账户使用,点击帮助中心查看更多详情。")
} else {
l.Infow("device bind limit check",
logger.Field("user_id", userId),
logger.Field("identifier", identifier),
logger.Field("count", count),
logger.Field("limit", limit))
}
}
}
@ -158,7 +169,18 @@ func (l *BindDeviceLogic) rebindDeviceToNewUser(deviceInfo *user.Device, ip, use
if limit := l.svcCtx.SessionLimit(); limit > 0 {
if _, count, err := l.svcCtx.UserModel.QueryDeviceList(l.ctx, newUserId); err == nil {
if count >= limit {
l.Infow("device rebind blocked by limit",
logger.Field("new_user_id", newUserId),
logger.Field("identifier", deviceInfo.Identifier),
logger.Field("count", count),
logger.Field("limit", limit))
return xerr.NewErrCodeMsg(xerr.DeviceBindLimitExceeded, "账户绑定设备数已达上限,请移除其他设备后再登录,您也可以再注册一个新账户使用,点击帮助中心查看更多详情。")
} else {
l.Infow("device rebind limit check",
logger.Field("new_user_id", newUserId),
logger.Field("identifier", deviceInfo.Identifier),
logger.Field("count", count),
logger.Field("limit", limit))
}
}
}

View File

@ -149,6 +149,7 @@ func (l *UnbindDeviceLogic) UnbindDevice(req *types.UnbindDeviceRequest) error {
sessionIdCacheKey := fmt.Sprintf("%v:%v", config.SessionIdKey, sessionId)
_ = l.svcCtx.Redis.Del(ctx, sessionIdCacheKey).Err()
}
l.svcCtx.DeviceManager.KickDevice(u.Id, identifier)
l.Infow("设备解绑完成",
logger.Field("device_identifier", identifier),
logger.Field("elapsed_ms", duration.Milliseconds()))