business_config.go 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. package gorm
  2. import (
  3. "context"
  4. "database/sql"
  5. "go-common/app/admin/main/aegis/model/business"
  6. "go-common/library/log"
  7. )
  8. // GetConfigs .
  9. func (d *Dao) GetConfigs(c context.Context, bizid int64) (cfgs []*business.BizCFG, err error) {
  10. if err = d.orm.Table("business_config").Where("business_id=? AND state=0", bizid).Scan(&cfgs).Error; err != nil {
  11. log.Error("GetURL error(%v)", err)
  12. }
  13. return
  14. }
  15. // GetConfig .
  16. func (d *Dao) GetConfig(c context.Context, bizid int64, tp int8) (config string, err error) {
  17. if err = d.orm.Table("business_config").Select("`config`").
  18. Where("business_id=? AND type=? AND state=0", bizid, tp).
  19. Order("mtime DESC").Limit(1).
  20. Row().Scan(&config); err != nil {
  21. if err == sql.ErrNoRows {
  22. err = nil
  23. return
  24. }
  25. log.Error("GetConfig error(%v)", err)
  26. return
  27. }
  28. return
  29. }
  30. // ActiveConfigs 所有任务配置
  31. func (d *Dao) ActiveConfigs(c context.Context) (configs []*business.BizCFG, err error) {
  32. configs = []*business.BizCFG{}
  33. if err = d.orm.Where("state=0").Find(&configs).Error; err != nil {
  34. log.Error("ActiveConfigs find error(%v)", err)
  35. }
  36. return
  37. }
  38. // AddBizConfig 每个业务每种配置只有一条
  39. func (d *Dao) AddBizConfig(c context.Context, cfg *business.BizCFG) (lastid int64, err error) {
  40. if err = d.orm.Table("business_config").Where("business_id=? AND `type`=?", cfg.BusinessID, cfg.TP).
  41. Assign(map[string]interface{}{
  42. "config": cfg.Config,
  43. "state": cfg.State,
  44. }).FirstOrCreate(cfg).Error; err != nil {
  45. log.Error("AddBizConfig error(%v)", err)
  46. }
  47. lastid = cfg.ID
  48. return
  49. }
  50. // EditBizConfig .
  51. func (d *Dao) EditBizConfig(c context.Context, cfg *business.BizCFG) (err error) {
  52. if err = d.orm.Table("business_config").Where("id=?", cfg.ID).
  53. Update(map[string]interface{}{
  54. "config": cfg.Config,
  55. "state": cfg.State,
  56. }).Error; err != nil {
  57. log.Error("EditBizConfig error(%v)", err)
  58. }
  59. return
  60. }