...
|
...
|
@@ -229,3 +229,119 @@ func (service *AuthService) MeInfo(param *command.GetMeInfo) (map[string]interfa |
|
|
"user": info,
|
|
|
}, nil
|
|
|
}
|
|
|
|
|
|
// Authorize 移动端授权登录
|
|
|
func (srv *AuthService) Authorize(param *command.MobileLoginCommand) (map[string]interface{}, error) {
|
|
|
transactionContext, err := factory.CreateTransactionContext(nil)
|
|
|
if err != nil {
|
|
|
return nil, application.ThrowError(application.TRANSACTION_ERROR, err.Error())
|
|
|
}
|
|
|
if errStart := transactionContext.StartTransaction(); errStart != nil {
|
|
|
return nil, application.ThrowError(application.TRANSACTION_ERROR, errStart.Error())
|
|
|
}
|
|
|
defer func() {
|
|
|
_ = transactionContext.RollbackTransaction()
|
|
|
}()
|
|
|
// 统一用户中心登录
|
|
|
authCodeReply, err := factory.UCenterApi().AppAuthCode(param.Credentials, param.Cuid, param.Cid)
|
|
|
if err != nil || !authCodeReply.IsOk() {
|
|
|
return nil, application.ThrowError(application.INTERNAL_SERVER_ERROR, "统一用户中心认证失败")
|
|
|
}
|
|
|
// 用户权限校验
|
|
|
// 登录平台ID, 29-员工绩效
|
|
|
userAuthReply, err := factory.BusinessAdminApi().GetUserAuth(int64(param.Muid), constant.PLATFORM_FONT_ID)
|
|
|
if err != nil {
|
|
|
return nil, application.ThrowError(application.INTERNAL_SERVER_ERROR, "用户鉴权失败")
|
|
|
}
|
|
|
if !userAuthReply.IsOk() {
|
|
|
return nil, application.ThrowError(application.INTERNAL_SERVER_ERROR, userAuthReply.Message())
|
|
|
}
|
|
|
//获取公司数据
|
|
|
companyRepository := factory.CreateCompanyRepository(map[string]interface{}{
|
|
|
"transactionContext": transactionContext,
|
|
|
})
|
|
|
company, err := companyRepository.FindOne(map[string]interface{}{
|
|
|
"id": param.Cid,
|
|
|
})
|
|
|
if err != nil {
|
|
|
return nil, application.ThrowError(application.INTERNAL_SERVER_ERROR, "获取公司数据失败")
|
|
|
}
|
|
|
userRepository := factory.CreateUserRepository(map[string]interface{}{
|
|
|
"transactionContext": transactionContext,
|
|
|
})
|
|
|
user, err := userRepository.FindOne(map[string]interface{}{
|
|
|
"id": param.Muid,
|
|
|
"companyId": company.Id,
|
|
|
})
|
|
|
if err != nil {
|
|
|
return nil, application.ThrowError(application.INTERNAL_SERVER_ERROR, "获取用户数据失败")
|
|
|
}
|
|
|
if user.Status != domain.UserStatusEnable {
|
|
|
return nil, application.ThrowError(application.INTERNAL_SERVER_ERROR, "用户被禁用")
|
|
|
}
|
|
|
if err := transactionContext.CommitTransaction(); err != nil {
|
|
|
return nil, application.ThrowError(application.TRANSACTION_ERROR, err.Error())
|
|
|
}
|
|
|
userAuth := &domain.UserAuth{
|
|
|
UserId: user.Id,
|
|
|
CompanyId: user.CompanyId,
|
|
|
CompanyName: company.Name,
|
|
|
Phone: user.Account,
|
|
|
PlatformId: constant.PLATFORM_FONT_ID,
|
|
|
Name: user.Name,
|
|
|
AdminType: user.AdminType,
|
|
|
}
|
|
|
accessToken, err := userAuth.CreateAccessToken()
|
|
|
if err != nil {
|
|
|
return nil, application.ThrowError(application.INTERNAL_SERVER_ERROR, err.Error())
|
|
|
}
|
|
|
respData := map[string]interface{}{
|
|
|
"authCode": accessToken,
|
|
|
}
|
|
|
return respData, nil
|
|
|
}
|
|
|
|
|
|
func (srv *AuthService) AccessToken(param *command.AccessTokenCommand) (map[string]interface{}, error) {
|
|
|
userAuth := domain.UserAuth{}
|
|
|
_, err := userAuth.ParseAccessToken(param.AuthCode)
|
|
|
if err != nil {
|
|
|
return nil, application.ThrowError(application.INTERNAL_SERVER_ERROR, "authcode 失效")
|
|
|
}
|
|
|
|
|
|
accessToken, err := userAuth.CreateAccessToken()
|
|
|
if err != nil {
|
|
|
return nil, application.ThrowError(application.INTERNAL_SERVER_ERROR, "生成 accessToken 失败")
|
|
|
}
|
|
|
refreshToken, err := userAuth.CreateRefreshToken()
|
|
|
if err != nil {
|
|
|
return nil, application.ThrowError(application.INTERNAL_SERVER_ERROR, "生成 refreshToken 解析失败")
|
|
|
}
|
|
|
respData := map[string]interface{}{
|
|
|
"refreshToken": refreshToken,
|
|
|
"accessToken": accessToken,
|
|
|
"expiresIn": domain.JWTExpiresSecond,
|
|
|
}
|
|
|
return respData, nil
|
|
|
}
|
|
|
|
|
|
func (srv *AuthService) RefreshToken(param *command.RefreshTokenCommand) (map[string]interface{}, error) {
|
|
|
userAuth := domain.UserAuth{}
|
|
|
_, err := userAuth.ParseAccessToken(param.RefreshToken)
|
|
|
if err != nil {
|
|
|
return nil, application.ThrowError(application.INTERNAL_SERVER_ERROR, "refresh_token 失效")
|
|
|
}
|
|
|
accessToken, err := userAuth.CreateAccessToken()
|
|
|
if err != nil {
|
|
|
return nil, application.ThrowError(application.INTERNAL_SERVER_ERROR, "生成 accessToken 失败")
|
|
|
}
|
|
|
refreshToken, err := userAuth.CreateRefreshToken()
|
|
|
if err != nil {
|
|
|
return nil, application.ThrowError(application.INTERNAL_SERVER_ERROR, "生成 refreshToken 解析失败")
|
|
|
}
|
|
|
respData := map[string]interface{}{
|
|
|
"refreshToken": refreshToken,
|
|
|
"accessToken": accessToken,
|
|
|
"expiresIn": domain.JWTExpiresSecond,
|
|
|
}
|
|
|
return respData, nil
|
|
|
} |
...
|
...
|
|