2021-05-08 18:00:33 +08:00
|
|
|
package persistence
|
|
|
|
|
|
|
|
|
|
import (
|
2023-07-01 14:34:42 +08:00
|
|
|
"mayfly-go/internal/machine/api/vo"
|
2022-09-09 18:26:08 +08:00
|
|
|
"mayfly-go/internal/machine/domain/entity"
|
|
|
|
|
"mayfly-go/internal/machine/domain/repository"
|
2022-07-23 16:41:04 +08:00
|
|
|
"mayfly-go/pkg/biz"
|
2023-07-01 14:34:42 +08:00
|
|
|
"mayfly-go/pkg/gormx"
|
2022-06-02 17:41:11 +08:00
|
|
|
"mayfly-go/pkg/model"
|
2021-05-08 18:00:33 +08:00
|
|
|
)
|
|
|
|
|
|
2022-09-09 18:26:08 +08:00
|
|
|
type machineRepoImpl struct{}
|
2021-05-08 18:00:33 +08:00
|
|
|
|
2022-09-09 18:26:08 +08:00
|
|
|
func newMachineRepo() repository.Machine {
|
|
|
|
|
return new(machineRepoImpl)
|
|
|
|
|
}
|
2021-05-08 18:00:33 +08:00
|
|
|
|
|
|
|
|
// 分页获取机器信息列表
|
2023-07-01 21:24:07 +08:00
|
|
|
func (m *machineRepoImpl) GetMachineList(condition *entity.MachineQuery, pageParam *model.PageParam, toEntity *[]*vo.MachineVO, orderBy ...string) *model.PageResult[*[]*vo.MachineVO] {
|
2023-07-01 14:34:42 +08:00
|
|
|
qd := gormx.NewQuery(new(entity.Machine)).
|
|
|
|
|
Like("ip", condition.Ip).
|
|
|
|
|
Like("name", condition.Name).
|
|
|
|
|
In("tag_id", condition.TagIds).
|
|
|
|
|
RLike("tag_path", condition.TagPathLike).
|
|
|
|
|
OrderByAsc("tag_path")
|
|
|
|
|
return gormx.PageQuery(qd, pageParam, toEntity)
|
2021-05-08 18:00:33 +08:00
|
|
|
}
|
|
|
|
|
|
2022-10-26 20:49:29 +08:00
|
|
|
func (m *machineRepoImpl) Count(condition *entity.MachineQuery) int64 {
|
2023-06-01 12:31:32 +08:00
|
|
|
where := make(map[string]any)
|
2022-10-26 20:49:29 +08:00
|
|
|
if len(condition.TagIds) > 0 {
|
|
|
|
|
where["tag_id"] = condition.TagIds
|
|
|
|
|
}
|
|
|
|
|
if condition.TagId != 0 {
|
|
|
|
|
where["tag_id"] = condition.TagId
|
|
|
|
|
}
|
|
|
|
|
|
2023-07-01 14:34:42 +08:00
|
|
|
return gormx.CountByCond(new(entity.Machine), where)
|
2021-09-11 14:04:09 +08:00
|
|
|
}
|
|
|
|
|
|
2021-05-08 18:00:33 +08:00
|
|
|
// 根据条件获取账号信息
|
2022-09-09 18:26:08 +08:00
|
|
|
func (m *machineRepoImpl) GetMachine(condition *entity.Machine, cols ...string) error {
|
2023-07-01 14:34:42 +08:00
|
|
|
return gormx.GetBy(condition, cols...)
|
2021-05-08 18:00:33 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 根据id获取
|
2022-09-09 18:26:08 +08:00
|
|
|
func (m *machineRepoImpl) GetById(id uint64, cols ...string) *entity.Machine {
|
2021-05-08 18:00:33 +08:00
|
|
|
machine := new(entity.Machine)
|
2023-07-01 14:34:42 +08:00
|
|
|
if err := gormx.GetById(machine, id, cols...); err != nil {
|
2021-05-08 18:00:33 +08:00
|
|
|
return nil
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
return machine
|
|
|
|
|
}
|
|
|
|
|
|
2022-09-09 18:26:08 +08:00
|
|
|
func (m *machineRepoImpl) Create(entity *entity.Machine) {
|
2023-07-01 14:34:42 +08:00
|
|
|
biz.ErrIsNilAppendErr(gormx.Insert(entity), "创建机器信息失败: %s")
|
2021-05-08 18:00:33 +08:00
|
|
|
}
|
|
|
|
|
|
2022-09-09 18:26:08 +08:00
|
|
|
func (m *machineRepoImpl) UpdateById(entity *entity.Machine) {
|
2023-07-01 14:34:42 +08:00
|
|
|
biz.ErrIsNilAppendErr(gormx.UpdateById(entity), "更新机器信息失败: %s")
|
2021-05-08 18:00:33 +08:00
|
|
|
}
|