mirror of
				https://github.com/TeaOSLab/EdgeAPI.git
				synced 2025-11-04 16:00:24 +08:00 
			
		
		
		
	
		
			
	
	
		
			208 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
		
		
			
		
	
	
			208 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| 
								 | 
							
								package models
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								import (
							 | 
						|||
| 
								 | 
							
									"encoding/json"
							 | 
						|||
| 
								 | 
							
									dbutils "github.com/TeaOSLab/EdgeAPI/internal/db/utils"
							 | 
						|||
| 
								 | 
							
									"github.com/TeaOSLab/EdgeAPI/internal/errors"
							 | 
						|||
| 
								 | 
							
									"github.com/TeaOSLab/EdgeAPI/internal/utils/ttlcache"
							 | 
						|||
| 
								 | 
							
									_ "github.com/go-sql-driver/mysql"
							 | 
						|||
| 
								 | 
							
									"github.com/iwind/TeaGo/Tea"
							 | 
						|||
| 
								 | 
							
									"github.com/iwind/TeaGo/dbs"
							 | 
						|||
| 
								 | 
							
									"github.com/iwind/TeaGo/types"
							 | 
						|||
| 
								 | 
							
									"strconv"
							 | 
						|||
| 
								 | 
							
									"strings"
							 | 
						|||
| 
								 | 
							
									"time"
							 | 
						|||
| 
								 | 
							
								)
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								const (
							 | 
						|||
| 
								 | 
							
									FormalClientSystemStateEnabled  = 1 // 已启用
							 | 
						|||
| 
								 | 
							
									FormalClientSystemStateDisabled = 0 // 已禁用
							 | 
						|||
| 
								 | 
							
								)
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								type FormalClientSystemDAO dbs.DAO
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								func NewFormalClientSystemDAO() *FormalClientSystemDAO {
							 | 
						|||
| 
								 | 
							
									return dbs.NewDAO(&FormalClientSystemDAO{
							 | 
						|||
| 
								 | 
							
										DAOObject: dbs.DAOObject{
							 | 
						|||
| 
								 | 
							
											DB:     Tea.Env,
							 | 
						|||
| 
								 | 
							
											Table:  "edgeFormalClientSystems",
							 | 
						|||
| 
								 | 
							
											Model:  new(FormalClientSystem),
							 | 
						|||
| 
								 | 
							
											PkName: "id",
							 | 
						|||
| 
								 | 
							
										},
							 | 
						|||
| 
								 | 
							
									}).(*FormalClientSystemDAO)
							 | 
						|||
| 
								 | 
							
								}
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								var SharedFormalClientSystemDAO *FormalClientSystemDAO
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								func init() {
							 | 
						|||
| 
								 | 
							
									dbs.OnReady(func() {
							 | 
						|||
| 
								 | 
							
										SharedFormalClientSystemDAO = NewFormalClientSystemDAO()
							 | 
						|||
| 
								 | 
							
									})
							 | 
						|||
| 
								 | 
							
								}
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								// EnableFormalClientSystem 启用条目
							 | 
						|||
| 
								 | 
							
								func (this *FormalClientSystemDAO) EnableFormalClientSystem(tx *dbs.Tx, id uint32) error {
							 | 
						|||
| 
								 | 
							
									_, err := this.Query(tx).
							 | 
						|||
| 
								 | 
							
										Pk(id).
							 | 
						|||
| 
								 | 
							
										Set("state", FormalClientSystemStateEnabled).
							 | 
						|||
| 
								 | 
							
										Update()
							 | 
						|||
| 
								 | 
							
									return err
							 | 
						|||
| 
								 | 
							
								}
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								// DisableFormalClientSystem 禁用条目
							 | 
						|||
| 
								 | 
							
								func (this *FormalClientSystemDAO) DisableFormalClientSystem(tx *dbs.Tx, id uint32) error {
							 | 
						|||
| 
								 | 
							
									_, err := this.Query(tx).
							 | 
						|||
| 
								 | 
							
										Pk(id).
							 | 
						|||
| 
								 | 
							
										Set("state", FormalClientSystemStateDisabled).
							 | 
						|||
| 
								 | 
							
										Update()
							 | 
						|||
| 
								 | 
							
									return err
							 | 
						|||
| 
								 | 
							
								}
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								// FindEnabledFormalClientSystem 查找启用中的条目
							 | 
						|||
| 
								 | 
							
								func (this *FormalClientSystemDAO) FindEnabledFormalClientSystem(tx *dbs.Tx, id int64) (*FormalClientSystem, error) {
							 | 
						|||
| 
								 | 
							
									result, err := this.Query(tx).
							 | 
						|||
| 
								 | 
							
										Pk(id).
							 | 
						|||
| 
								 | 
							
										State(FormalClientSystemStateEnabled).
							 | 
						|||
| 
								 | 
							
										Find()
							 | 
						|||
| 
								 | 
							
									if result == nil {
							 | 
						|||
| 
								 | 
							
										return nil, err
							 | 
						|||
| 
								 | 
							
									}
							 | 
						|||
| 
								 | 
							
									return result.(*FormalClientSystem), err
							 | 
						|||
| 
								 | 
							
								}
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								// FindFormalClientSystemName 根据主键查找名称
							 | 
						|||
| 
								 | 
							
								func (this *FormalClientSystemDAO) FindFormalClientSystemName(tx *dbs.Tx, id uint32) (string, error) {
							 | 
						|||
| 
								 | 
							
									return this.Query(tx).
							 | 
						|||
| 
								 | 
							
										Pk(id).
							 | 
						|||
| 
								 | 
							
										Result("name").
							 | 
						|||
| 
								 | 
							
										FindStringCol("")
							 | 
						|||
| 
								 | 
							
								}
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								// FindSystemIdWithNameCacheable 根据操作系统名称查找系统ID
							 | 
						|||
| 
								 | 
							
								func (this *FormalClientSystemDAO) FindSystemIdWithNameCacheable(tx *dbs.Tx, systemName string) (int64, error) {
							 | 
						|||
| 
								 | 
							
									var cacheKey = "formalClientSystem:" + systemName
							 | 
						|||
| 
								 | 
							
									var cacheItem = ttlcache.SharedCache.Read(cacheKey)
							 | 
						|||
| 
								 | 
							
									if cacheItem != nil {
							 | 
						|||
| 
								 | 
							
										return types.Int64(cacheItem.Value), nil
							 | 
						|||
| 
								 | 
							
									}
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
									// 先使用 name 查找,因为有索引,所以会快一些
							 | 
						|||
| 
								 | 
							
									systemId, err := this.Query(tx).
							 | 
						|||
| 
								 | 
							
										Attr("name", systemName).
							 | 
						|||
| 
								 | 
							
										ResultPk().
							 | 
						|||
| 
								 | 
							
										FindInt64Col(0)
							 | 
						|||
| 
								 | 
							
									if err != nil {
							 | 
						|||
| 
								 | 
							
										return 0, err
							 | 
						|||
| 
								 | 
							
									}
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
									if systemId == 0 {
							 | 
						|||
| 
								 | 
							
										systemId, err = this.Query(tx).
							 | 
						|||
| 
								 | 
							
											Where("JSON_CONTAINS(codes, :systemName)").
							 | 
						|||
| 
								 | 
							
											Param("systemName", strconv.Quote(systemName)). // 查询的需要是个JSON字符串,所以这里加双引号
							 | 
						|||
| 
								 | 
							
											ResultPk().
							 | 
						|||
| 
								 | 
							
											FindInt64Col(0)
							 | 
						|||
| 
								 | 
							
										if err != nil {
							 | 
						|||
| 
								 | 
							
											return 0, err
							 | 
						|||
| 
								 | 
							
										}
							 | 
						|||
| 
								 | 
							
									}
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
									// 即使找不到也要放入到缓存中
							 | 
						|||
| 
								 | 
							
									ttlcache.SharedCache.Write(cacheKey, systemId, time.Now().Unix()+3600)
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
									return systemId, nil
							 | 
						|||
| 
								 | 
							
								}
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								// CreateSystem 创建操作系统信息
							 | 
						|||
| 
								 | 
							
								func (this *FormalClientSystemDAO) CreateSystem(tx *dbs.Tx, name string, codes []string, dataId string) (int64, error) {
							 | 
						|||
| 
								 | 
							
									if len(dataId) == 0 {
							 | 
						|||
| 
								 | 
							
										return 0, errors.New("invalid dataId")
							 | 
						|||
| 
								 | 
							
									}
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
									// 检查 dataId 是否已经存在
							 | 
						|||
| 
								 | 
							
									exists, err := this.Query(tx).
							 | 
						|||
| 
								 | 
							
										Attr("dataId", dataId).
							 | 
						|||
| 
								 | 
							
										Exist()
							 | 
						|||
| 
								 | 
							
									if err != nil {
							 | 
						|||
| 
								 | 
							
										return 0, err
							 | 
						|||
| 
								 | 
							
									}
							 | 
						|||
| 
								 | 
							
									if exists {
							 | 
						|||
| 
								 | 
							
										return 0, errors.New("dataId '" + dataId + "' already exists")
							 | 
						|||
| 
								 | 
							
									}
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
									var op = NewFormalClientSystemOperator()
							 | 
						|||
| 
								 | 
							
									op.Name = name
							 | 
						|||
| 
								 | 
							
									if len(codes) == 0 {
							 | 
						|||
| 
								 | 
							
										op.Codes = "[]"
							 | 
						|||
| 
								 | 
							
									} else {
							 | 
						|||
| 
								 | 
							
										codesJSON, err := json.Marshal(codes)
							 | 
						|||
| 
								 | 
							
										if err != nil {
							 | 
						|||
| 
								 | 
							
											return 0, err
							 | 
						|||
| 
								 | 
							
										}
							 | 
						|||
| 
								 | 
							
										op.Codes = codesJSON
							 | 
						|||
| 
								 | 
							
									}
							 | 
						|||
| 
								 | 
							
									op.DataId = dataId
							 | 
						|||
| 
								 | 
							
									op.State = FormalClientSystemStateEnabled
							 | 
						|||
| 
								 | 
							
									return this.SaveInt64(tx, op)
							 | 
						|||
| 
								 | 
							
								}
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								// UpdateSystem 修改操作系统信息
							 | 
						|||
| 
								 | 
							
								func (this *FormalClientSystemDAO) UpdateSystem(tx *dbs.Tx, systemId int64, name string, codes []string, dataId string) error {
							 | 
						|||
| 
								 | 
							
									if systemId <= 0 {
							 | 
						|||
| 
								 | 
							
										return errors.New("invalid systemId '" + types.String(systemId) + "'")
							 | 
						|||
| 
								 | 
							
									}
							 | 
						|||
| 
								 | 
							
									if len(dataId) == 0 {
							 | 
						|||
| 
								 | 
							
										return errors.New("invalid dataId")
							 | 
						|||
| 
								 | 
							
									}
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
									var op = NewFormalClientSystemOperator()
							 | 
						|||
| 
								 | 
							
									op.Id = systemId
							 | 
						|||
| 
								 | 
							
									op.Name = name
							 | 
						|||
| 
								 | 
							
									if len(codes) == 0 {
							 | 
						|||
| 
								 | 
							
										op.Codes = "[]"
							 | 
						|||
| 
								 | 
							
									} else {
							 | 
						|||
| 
								 | 
							
										codesJSON, err := json.Marshal(codes)
							 | 
						|||
| 
								 | 
							
										if err != nil {
							 | 
						|||
| 
								 | 
							
											return err
							 | 
						|||
| 
								 | 
							
										}
							 | 
						|||
| 
								 | 
							
										op.Codes = codesJSON
							 | 
						|||
| 
								 | 
							
									}
							 | 
						|||
| 
								 | 
							
									op.DataId = dataId
							 | 
						|||
| 
								 | 
							
									return this.Save(tx, op)
							 | 
						|||
| 
								 | 
							
								}
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								// CountSystems 计算操作系统数量
							 | 
						|||
| 
								 | 
							
								func (this *FormalClientSystemDAO) CountSystems(tx *dbs.Tx, keyword string) (int64, error) {
							 | 
						|||
| 
								 | 
							
									var query = this.Query(tx)
							 | 
						|||
| 
								 | 
							
									if len(keyword) > 0 {
							 | 
						|||
| 
								 | 
							
										query.Like("LOWER(codes)", dbutils.QuoteLikeKeyword(strings.ToLower(keyword)))
							 | 
						|||
| 
								 | 
							
									}
							 | 
						|||
| 
								 | 
							
									return query.Count()
							 | 
						|||
| 
								 | 
							
								}
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								// ListSystems 列出单页操作系统信息
							 | 
						|||
| 
								 | 
							
								func (this *FormalClientSystemDAO) ListSystems(tx *dbs.Tx, keyword string, offset int64, size int64) (result []*FormalClientSystem, err error) {
							 | 
						|||
| 
								 | 
							
									var query = this.Query(tx)
							 | 
						|||
| 
								 | 
							
									if len(keyword) > 0 {
							 | 
						|||
| 
								 | 
							
										query.Like("LOWER(codes)", dbutils.QuoteLikeKeyword(strings.ToLower(keyword)))
							 | 
						|||
| 
								 | 
							
									}
							 | 
						|||
| 
								 | 
							
									_, err = query.
							 | 
						|||
| 
								 | 
							
										Offset(offset).
							 | 
						|||
| 
								 | 
							
										Limit(size).
							 | 
						|||
| 
								 | 
							
										DescPk().
							 | 
						|||
| 
								 | 
							
										Slice(&result).
							 | 
						|||
| 
								 | 
							
										FindAll()
							 | 
						|||
| 
								 | 
							
									return
							 | 
						|||
| 
								 | 
							
								}
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								// FindSystemWithDataId 根据dataId查找操作系统信息
							 | 
						|||
| 
								 | 
							
								func (this *FormalClientSystemDAO) FindSystemWithDataId(tx *dbs.Tx, dataId string) (*FormalClientSystem, error) {
							 | 
						|||
| 
								 | 
							
									one, err := this.Query(tx).
							 | 
						|||
| 
								 | 
							
										Attr("dataId", dataId).
							 | 
						|||
| 
								 | 
							
										Find()
							 | 
						|||
| 
								 | 
							
									if err != nil || one == nil {
							 | 
						|||
| 
								 | 
							
										return nil, err
							 | 
						|||
| 
								 | 
							
									}
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
									return one.(*FormalClientSystem), nil
							 | 
						|||
| 
								 | 
							
								}
							 |