Files
EdgeAPI/internal/rpc/services/service_acme_user.go

297 lines
8.0 KiB
Go
Raw Permalink Normal View History

2020-11-24 15:02:44 +08:00
package services
import (
"context"
2024-07-27 14:15:25 +08:00
2021-10-03 13:09:29 +08:00
"github.com/TeaOSLab/EdgeAPI/internal/acme"
acmemodels "github.com/TeaOSLab/EdgeAPI/internal/db/models/acme"
2020-11-24 15:02:44 +08:00
"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
)
2021-10-03 13:09:29 +08:00
// ACMEUserService 用户服务
2020-11-24 15:02:44 +08:00
type ACMEUserService struct {
BaseService
}
2021-10-03 13:09:29 +08:00
// CreateACMEUser 创建用户
2020-11-24 15:02:44 +08:00
func (this *ACMEUserService) CreateACMEUser(ctx context.Context, req *pb.CreateACMEUserRequest) (*pb.CreateACMEUserResponse, error) {
// 校验请求
2022-09-17 16:07:37 +08:00
adminId, userId, err := this.ValidateAdminAndUser(ctx, false)
2020-11-24 15:02:44 +08:00
if err != nil {
return nil, err
}
2022-07-22 15:05:30 +08:00
var tx = this.NullTx()
if adminId > 0 {
if req.UserId > 0 {
userId = req.UserId
}
}
2021-10-03 13:09:29 +08:00
acmeUserId, err := acmemodels.SharedACMEUserDAO.CreateACMEUser(tx, adminId, userId, req.AcmeProviderCode, req.AcmeProviderAccountId, req.Email, req.Description)
2020-11-24 15:02:44 +08:00
if err != nil {
return nil, err
}
return &pb.CreateACMEUserResponse{AcmeUserId: acmeUserId}, nil
}
2021-10-03 13:09:29 +08:00
// UpdateACMEUser 修改用户
2020-11-24 15:02:44 +08:00
func (this *ACMEUserService) UpdateACMEUser(ctx context.Context, req *pb.UpdateACMEUserRequest) (*pb.RPCSuccess, error) {
// 校验请求
2022-09-17 16:07:37 +08:00
adminId, userId, err := this.ValidateAdminAndUser(ctx, false)
2020-11-24 15:02:44 +08:00
if err != nil {
return nil, err
}
2022-07-22 15:05:30 +08:00
var tx = this.NullTx()
2020-11-24 15:02:44 +08:00
// 检查是否有权限
b, err := acmemodels.SharedACMEUserDAO.CheckACMEUser(tx, req.AcmeUserId, adminId, userId)
2020-11-24 15:02:44 +08:00
if err != nil {
return nil, err
}
if !b {
return nil, this.PermissionError()
}
err = acmemodels.SharedACMEUserDAO.UpdateACMEUser(tx, req.AcmeUserId, req.Description)
2020-11-24 15:02:44 +08:00
if err != nil {
return nil, err
}
return this.Success()
}
2021-10-03 13:09:29 +08:00
// DeleteACMEUser 删除用户
2020-11-24 15:02:44 +08:00
func (this *ACMEUserService) DeleteACMEUser(ctx context.Context, req *pb.DeleteACMEUserRequest) (*pb.RPCSuccess, error) {
// 校验请求
2022-09-17 16:07:37 +08:00
adminId, userId, err := this.ValidateAdminAndUser(ctx, false)
2020-11-24 15:02:44 +08:00
if err != nil {
return nil, err
}
2022-07-22 15:05:30 +08:00
var tx = this.NullTx()
2020-11-24 15:02:44 +08:00
// 检查是否有权限
b, err := acmemodels.SharedACMEUserDAO.CheckACMEUser(tx, req.AcmeUserId, adminId, userId)
2020-11-24 15:02:44 +08:00
if err != nil {
return nil, err
}
if !b {
return nil, this.PermissionError()
}
err = acmemodels.SharedACMEUserDAO.DisableACMEUser(tx, req.AcmeUserId)
2020-11-24 15:02:44 +08:00
if err != nil {
return nil, err
}
return this.Success()
}
2021-10-03 13:09:29 +08:00
// CountACMEUsers 计算用户数量
2020-11-24 15:02:44 +08:00
func (this *ACMEUserService) CountACMEUsers(ctx context.Context, req *pb.CountAcmeUsersRequest) (*pb.RPCCountResponse, error) {
// 校验请求
2022-09-17 16:07:37 +08:00
adminId, userId, err := this.ValidateAdminAndUser(ctx, false)
2020-11-24 15:02:44 +08:00
if err != nil {
return nil, err
}
2022-07-22 15:05:30 +08:00
var tx = this.NullTx()
if userId > 0 {
req.UserId = userId
}
2022-07-22 15:05:30 +08:00
count, err := acmemodels.SharedACMEUserDAO.CountACMEUsersWithAdminId(tx, adminId, req.UserId, req.AcmeProviderAccountId)
2020-11-24 15:02:44 +08:00
if err != nil {
return nil, err
}
2020-11-24 17:36:47 +08:00
return this.SuccessCount(count)
2020-11-24 15:02:44 +08:00
}
2021-10-03 13:09:29 +08:00
// ListACMEUsers 列出单页用户
2020-11-24 15:02:44 +08:00
func (this *ACMEUserService) ListACMEUsers(ctx context.Context, req *pb.ListACMEUsersRequest) (*pb.ListACMEUsersResponse, error) {
// 校验请求
2022-09-17 16:07:37 +08:00
adminId, userId, err := this.ValidateAdminAndUser(ctx, false)
2020-11-24 15:02:44 +08:00
if err != nil {
return nil, err
}
2022-07-22 15:05:30 +08:00
var tx = this.NullTx()
if userId > 0 {
req.UserId = userId
}
2022-07-22 15:05:30 +08:00
acmeUsers, err := acmemodels.SharedACMEUserDAO.ListACMEUsers(tx, adminId, req.UserId, req.Offset, req.Size)
2020-11-24 15:02:44 +08:00
if err != nil {
return nil, err
}
2022-07-22 15:05:30 +08:00
var result = []*pb.ACMEUser{}
2020-11-24 15:02:44 +08:00
for _, user := range acmeUsers {
2021-10-03 13:09:29 +08:00
var pbUser = &pb.ACMEUser{
Id: int64(user.Id),
Email: user.Email,
Description: user.Description,
CreatedAt: int64(user.CreatedAt),
AcmeProviderCode: user.ProviderCode,
}
// 服务商
if len(user.ProviderCode) == 0 {
user.ProviderCode = acme.DefaultProviderCode
}
var provider = acme.FindProviderWithCode(user.ProviderCode)
if provider != nil {
pbUser.AcmeProvider = &pb.ACMEProvider{
Name: provider.Name,
Code: provider.Code,
Description: provider.Description,
RequireEAB: provider.RequireEAB,
EabDescription: provider.EABDescription,
}
}
// 账号
if user.AccountId > 0 {
account, err := acmemodels.SharedACMEProviderAccountDAO.FindEnabledACMEProviderAccount(tx, int64(user.AccountId))
if err != nil {
return nil, err
}
if account != nil {
pbUser.AcmeProviderAccount = &pb.ACMEProviderAccount{
Id: int64(account.Id),
Name: account.Name,
2022-03-22 21:45:07 +08:00
IsOn: account.IsOn,
2021-10-03 13:09:29 +08:00
ProviderCode: account.ProviderCode,
AcmeProvider: nil,
}
var provider = acme.FindProviderWithCode(account.ProviderCode)
if provider != nil {
pbUser.AcmeProviderAccount.AcmeProvider = &pb.ACMEProvider{
Name: provider.Name,
Code: provider.Code,
Description: provider.Description,
RequireEAB: provider.RequireEAB,
EabDescription: provider.EABDescription,
}
}
}
}
result = append(result, pbUser)
2020-11-24 15:02:44 +08:00
}
return &pb.ListACMEUsersResponse{AcmeUsers: result}, nil
}
2021-10-03 13:09:29 +08:00
// FindEnabledACMEUser 查找单个用户
2020-11-24 15:02:44 +08:00
func (this *ACMEUserService) FindEnabledACMEUser(ctx context.Context, req *pb.FindEnabledACMEUserRequest) (*pb.FindEnabledACMEUserResponse, error) {
// 校验请求
2022-09-17 16:07:37 +08:00
adminId, userId, err := this.ValidateAdminAndUser(ctx, false)
2020-11-24 15:02:44 +08:00
if err != nil {
return nil, err
}
2022-07-22 15:05:30 +08:00
var tx = this.NullTx()
2020-11-24 15:02:44 +08:00
// 检查是否有权限
b, err := acmemodels.SharedACMEUserDAO.CheckACMEUser(tx, req.AcmeUserId, adminId, userId)
2020-11-24 15:02:44 +08:00
if err != nil {
return nil, err
}
if !b {
return nil, this.PermissionError()
}
acmeUser, err := acmemodels.SharedACMEUserDAO.FindEnabledACMEUser(tx, req.AcmeUserId)
2020-11-24 15:02:44 +08:00
if err != nil {
return nil, err
}
if acmeUser == nil {
return &pb.FindEnabledACMEUserResponse{AcmeUser: nil}, nil
}
2021-10-03 13:09:29 +08:00
// 服务商
var pbACMEUser = &pb.ACMEUser{
Id: int64(acmeUser.Id),
Email: acmeUser.Email,
Description: acmeUser.Description,
CreatedAt: int64(acmeUser.CreatedAt),
AcmeProviderCode: acmeUser.ProviderCode,
}
if len(acmeUser.ProviderCode) == 0 {
acmeUser.ProviderCode = acme.DefaultProviderCode
}
var provider = acme.FindProviderWithCode(acmeUser.ProviderCode)
if provider != nil {
pbACMEUser.AcmeProvider = &pb.ACMEProvider{
Name: provider.Name,
Code: provider.Code,
Description: provider.Description,
RequireEAB: provider.RequireEAB,
EabDescription: provider.EABDescription,
}
}
// 账号
if acmeUser.AccountId > 0 {
account, err := acmemodels.SharedACMEProviderAccountDAO.FindEnabledACMEProviderAccount(tx, int64(acmeUser.AccountId))
if err != nil {
return nil, err
}
if account != nil {
pbACMEUser.AcmeProviderAccount = &pb.ACMEProviderAccount{
Id: int64(account.Id),
Name: account.Name,
2022-03-22 21:45:07 +08:00
IsOn: account.IsOn,
2021-10-03 13:09:29 +08:00
ProviderCode: account.ProviderCode,
AcmeProvider: nil,
}
var provider = acme.FindProviderWithCode(account.ProviderCode)
if provider != nil {
pbACMEUser.AcmeProviderAccount.AcmeProvider = &pb.ACMEProvider{
Name: provider.Name,
Code: provider.Code,
Description: provider.Description,
RequireEAB: provider.RequireEAB,
EabDescription: provider.EABDescription,
}
}
}
}
return &pb.FindEnabledACMEUserResponse{AcmeUser: pbACMEUser}, nil
2020-11-24 15:02:44 +08:00
}
2021-10-03 13:09:29 +08:00
// FindAllACMEUsers 查找所有用户
func (this *ACMEUserService) FindAllACMEUsers(ctx context.Context, req *pb.FindAllACMEUsersRequest) (*pb.FindAllACMEUsersResponse, error) {
// 校验请求
2022-09-17 16:07:37 +08:00
adminId, userId, err := this.ValidateAdminAndUser(ctx, false)
if err != nil {
return nil, err
}
2022-07-22 15:05:30 +08:00
var tx = this.NullTx()
if userId > 0 {
req.UserId = userId
}
2022-07-22 15:05:30 +08:00
acmeUsers, err := acmemodels.SharedACMEUserDAO.FindAllACMEUsers(tx, adminId, req.UserId, req.AcmeProviderCode)
if err != nil {
return nil, err
}
2022-07-22 15:05:30 +08:00
var result = []*pb.ACMEUser{}
for _, user := range acmeUsers {
result = append(result, &pb.ACMEUser{
2021-10-03 13:09:29 +08:00
Id: int64(user.Id),
Email: user.Email,
Description: user.Description,
CreatedAt: int64(user.CreatedAt),
AcmeProviderCode: user.ProviderCode,
})
}
return &pb.FindAllACMEUsersResponse{AcmeUsers: result}, nil
}