bi_dashboard_grant.go 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. package bi_dashboard
  2. import (
  3. "eta/eta_api/global"
  4. "eta/eta_api/utils"
  5. "time"
  6. )
  7. type BiDashboardGrant struct {
  8. GrantId int `orm:"column(grant_id);pk" gorm:"primaryKey"` // 授权id
  9. BiDashboardId int `gorm:"column:bi_dashboard_id" ` // 看板id
  10. GrantAdminId int `gorm:"column:grant_admin_id"` // 授权的用户id
  11. CreateTime time.Time `gorm:"column:create_time"` // 授权时间
  12. }
  13. // tableName
  14. func (m *BiDashboardGrant) TableName() string {
  15. return "bi_dashboard_grant"
  16. }
  17. // GrantDashboardReq 分配看板权限
  18. type GrantDashboardReq struct {
  19. BiDashboardId int `description:"看板id" `
  20. AdminIdStr string `description:"指定成员id,多个成员用英文,隔开"`
  21. }
  22. // MultiAddDashboardGrant 批量添加授权记录
  23. func MultiAddDashboardGrant(boardId int, list []*BiDashboardGrant) (err error) {
  24. o := global.DbMap[utils.DbNameMaster]
  25. to := o.Begin()
  26. defer func() {
  27. if err != nil {
  28. _ = to.Rollback()
  29. } else {
  30. _ = to.Commit()
  31. }
  32. }()
  33. sql := "DELETE from bi_dashboard_grant where bi_dashboard_id=?"
  34. err = to.Exec(sql, boardId).Error
  35. if err != nil {
  36. return
  37. }
  38. // 新增授权记录
  39. if len(list) > 0 {
  40. tmpErr := to.CreateInBatches(list, utils.MultiAddNum).Error
  41. if tmpErr != nil {
  42. err = tmpErr
  43. return
  44. }
  45. }
  46. return
  47. }
  48. // PublicDashboardReq 设置公共看板权限
  49. type PublicDashboardReq struct {
  50. BiDashboardId int `description:"看板id" `
  51. }
  52. // del
  53. func DeleteDashboardGrant(biDashboardId int) (err error) {
  54. //return global.DEFAULT_DmSQL.Where("bi_dashboard_id=?", biDashboardId).Delete(&BiDashboardGrant{}).Error
  55. o := global.DbMap[utils.DbNameMaster]
  56. err = o.Exec("DELETE from bi_dashboard_grant where bi_dashboard_id=?", biDashboardId).Error
  57. return
  58. }
  59. // get
  60. func GetDashboardGrantInfo(biDashboardId int) (list []*BiDashboardGrant, err error) {
  61. //return list, global.DEFAULT_DmSQL.Where("bi_dashboard_id=?", biDashboardId).Find(&list).Error
  62. o := global.DbMap[utils.DbNameMaster]
  63. err = o.Raw("SELECT * FROM bi_dashboard_grant where bi_dashboard_id=?", biDashboardId).Find(&list).Error
  64. return
  65. }