forked from baron/baron-sso
114 lines
3.5 KiB
Go
114 lines
3.5 KiB
Go
package repository
|
|
|
|
import (
|
|
"baron-sso-backend/internal/domain"
|
|
"context"
|
|
|
|
"gorm.io/gorm"
|
|
)
|
|
|
|
type TenantRepository interface {
|
|
Create(ctx context.Context, tenant *domain.Tenant) error
|
|
Update(ctx context.Context, tenant *domain.Tenant) error
|
|
FindByID(ctx context.Context, id string) (*domain.Tenant, error)
|
|
FindBySlug(ctx context.Context, slug string) (*domain.Tenant, error)
|
|
FindByName(ctx context.Context, name string) (*domain.Tenant, error)
|
|
FindByDomain(ctx context.Context, domainName string) (*domain.Tenant, error)
|
|
FindByIDs(ctx context.Context, ids []string) ([]domain.Tenant, error)
|
|
AddDomain(ctx context.Context, tenantID string, domainName string, verified bool) error
|
|
List(ctx context.Context, limit, offset int, parentID string) ([]domain.Tenant, int64, error)
|
|
}
|
|
|
|
type tenantRepository struct {
|
|
db *gorm.DB
|
|
}
|
|
|
|
func NewTenantRepository(db *gorm.DB) TenantRepository {
|
|
return &tenantRepository{db: db}
|
|
}
|
|
|
|
func (r *tenantRepository) Create(ctx context.Context, tenant *domain.Tenant) error {
|
|
return r.db.WithContext(ctx).Create(tenant).Error
|
|
}
|
|
|
|
func (r *tenantRepository) Update(ctx context.Context, tenant *domain.Tenant) error {
|
|
return r.db.WithContext(ctx).Save(tenant).Error
|
|
}
|
|
|
|
func (r *tenantRepository) FindByID(ctx context.Context, id string) (*domain.Tenant, error) {
|
|
var tenant domain.Tenant
|
|
if err := r.db.WithContext(ctx).Preload("Domains").First(&tenant, "id = ?", id).Error; err != nil {
|
|
return nil, err
|
|
}
|
|
return &tenant, nil
|
|
}
|
|
|
|
func (r *tenantRepository) FindBySlug(ctx context.Context, slug string) (*domain.Tenant, error) {
|
|
var tenant domain.Tenant
|
|
if err := r.db.WithContext(ctx).Preload("Domains").Where("slug = ?", slug).First(&tenant).Error; err != nil {
|
|
return nil, err
|
|
}
|
|
return &tenant, nil
|
|
}
|
|
|
|
func (r *tenantRepository) FindByName(ctx context.Context, name string) (*domain.Tenant, error) {
|
|
var tenant domain.Tenant
|
|
if err := r.db.WithContext(ctx).Preload("Domains").Where("name = ?", name).First(&tenant).Error; err != nil {
|
|
return nil, err
|
|
}
|
|
return &tenant, nil
|
|
}
|
|
|
|
func (r *tenantRepository) FindByDomain(ctx context.Context, domainName string) (*domain.Tenant, error) {
|
|
var tenantDomain domain.TenantDomain
|
|
if err := r.db.WithContext(ctx).Where("domain = ?", domainName).First(&tenantDomain).Error; err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
var tenant domain.Tenant
|
|
if err := r.db.WithContext(ctx).Preload("Domains").First(&tenant, "id = ?", tenantDomain.TenantID).Error; err != nil {
|
|
return nil, err
|
|
}
|
|
return &tenant, nil
|
|
}
|
|
|
|
func (r *tenantRepository) FindByIDs(ctx context.Context, ids []string) ([]domain.Tenant, error) {
|
|
var tenants []domain.Tenant
|
|
if len(ids) == 0 {
|
|
return tenants, nil
|
|
}
|
|
if err := r.db.WithContext(ctx).Preload("Domains").Where("id IN ?", ids).Find(&tenants).Error; err != nil {
|
|
return nil, err
|
|
}
|
|
return tenants, nil
|
|
}
|
|
|
|
func (r *tenantRepository) AddDomain(ctx context.Context, tenantID string, domainName string, verified bool) error {
|
|
td := domain.TenantDomain{
|
|
TenantID: tenantID,
|
|
Domain: domainName,
|
|
Verified: verified,
|
|
}
|
|
return r.db.WithContext(ctx).Create(&td).Error
|
|
}
|
|
|
|
func (r *tenantRepository) List(ctx context.Context, limit, offset int, parentID string) ([]domain.Tenant, int64, error) {
|
|
var tenants []domain.Tenant
|
|
var total int64
|
|
db := r.db.WithContext(ctx).Model(&domain.Tenant{})
|
|
|
|
if parentID != "" {
|
|
db = db.Where("parent_id = ?", parentID)
|
|
}
|
|
|
|
if err := db.Count(&total).Error; err != nil {
|
|
return nil, 0, err
|
|
}
|
|
|
|
if err := db.Order("created_at desc").Limit(limit).Offset(offset).Preload("Domains").Find(&tenants).Error; err != nil {
|
|
return nil, 0, err
|
|
}
|
|
|
|
return tenants, total, nil
|
|
}
|