feat: 增加更新时候名称校验

This commit is contained in:
zhengkunwang223 2023-02-20 17:24:26 +08:00 committed by zhengkunwang223
parent 0dc38ec10c
commit 1ae02968e6
3 changed files with 27 additions and 2 deletions

View file

@ -25,6 +25,15 @@ func (w WebsiteDnsAccountRepo) GetFirst(opts ...DBOption) (*model.WebsiteDnsAcco
return &account, nil return &account, nil
} }
func (w WebsiteDnsAccountRepo) List(opts ...DBOption) ([]model.WebsiteDnsAccount, error) {
var accounts []model.WebsiteDnsAccount
db := getDb(opts...).Model(&model.WebsiteDnsAccount{})
if err := db.Find(&accounts).Error; err != nil {
return nil, err
}
return accounts, nil
}
func (w WebsiteDnsAccountRepo) Create(account model.WebsiteDnsAccount) error { func (w WebsiteDnsAccountRepo) Create(account model.WebsiteDnsAccount) error {
return getDb().Create(&account).Error return getDb().Create(&account).Error
} }

View file

@ -54,7 +54,12 @@ func (w WebsiteDnsAccountService) Update(update request.WebsiteDnsAccountUpdate)
if err != nil { if err != nil {
return request.WebsiteDnsAccountUpdate{}, err return request.WebsiteDnsAccountUpdate{}, err
} }
exists, _ := websiteDnsRepo.List(commonRepo.WithByName(update.Name))
for _, exist := range exists {
if exist.ID != update.ID {
return request.WebsiteDnsAccountUpdate{}, buserr.New(constant.ErrNameIsExist)
}
}
if err := websiteDnsRepo.Save(model.WebsiteDnsAccount{ if err := websiteDnsRepo.Save(model.WebsiteDnsAccount{
BaseModel: model.BaseModel{ BaseModel: model.BaseModel{
ID: update.ID, ID: update.ID,

View file

@ -3,12 +3,18 @@ package service
import ( import (
"github.com/1Panel-dev/1Panel/backend/app/dto/request" "github.com/1Panel-dev/1Panel/backend/app/dto/request"
"github.com/1Panel-dev/1Panel/backend/app/model" "github.com/1Panel-dev/1Panel/backend/app/model"
"github.com/1Panel-dev/1Panel/backend/buserr"
"github.com/1Panel-dev/1Panel/backend/constant"
) )
type WebsiteGroupService struct { type WebsiteGroupService struct {
} }
func (w WebsiteGroupService) CreateGroup(create request.WebsiteGroupCreate) error { func (w WebsiteGroupService) CreateGroup(create request.WebsiteGroupCreate) error {
groups, _ := websiteGroupRepo.GetBy(commonRepo.WithByName(create.Name))
if len(groups) > 0 {
return buserr.New(constant.ErrNameIsExist)
}
return websiteGroupRepo.Create(&model.WebsiteGroup{ return websiteGroupRepo.Create(&model.WebsiteGroup{
Name: create.Name, Name: create.Name,
}) })
@ -19,7 +25,6 @@ func (w WebsiteGroupService) GetGroups() ([]model.WebsiteGroup, error) {
} }
func (w WebsiteGroupService) UpdateGroup(update request.WebsiteGroupUpdate) error { func (w WebsiteGroupService) UpdateGroup(update request.WebsiteGroupUpdate) error {
if update.Default { if update.Default {
if err := websiteGroupRepo.CancelDefault(); err != nil { if err := websiteGroupRepo.CancelDefault(); err != nil {
return err return err
@ -32,6 +37,12 @@ func (w WebsiteGroupService) UpdateGroup(update request.WebsiteGroupUpdate) erro
Default: true, Default: true,
}) })
} else { } else {
exists, _ := websiteGroupRepo.GetBy(commonRepo.WithByName(update.Name))
for _, exist := range exists {
if exist.ID != update.ID {
return buserr.New(constant.ErrNameIsExist)
}
}
return websiteGroupRepo.Save(&model.WebsiteGroup{ return websiteGroupRepo.Save(&model.WebsiteGroup{
BaseModel: model.BaseModel{ BaseModel: model.BaseModel{
ID: update.ID, ID: update.ID,