sys_role_admin.go 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. package system
  2. import (
  3. "eta_gn/eta_api/global"
  4. "eta_gn/eta_api/utils"
  5. "time"
  6. )
  7. type SysRoleAdmin struct {
  8. Id int `gorm:"primaryKey" description:"自增ID"`
  9. AdminId int `orm:"column(admin_id);" description:"系统用户id"`
  10. RoleId int `orm:"column(role_id);" description:"角色ID"`
  11. CreateTime time.Time `orm:"column(create_time);" description:"创建时间"`
  12. }
  13. type RoleAdminItem struct {
  14. SysRoleAdminId int `description:"管理员账号和角色映射表id"`
  15. AdminId int `description:"系统用户id"`
  16. AdminName string `description:"系统用户名称"`
  17. RealName string `description:"系统用户姓名"`
  18. Enabled int `description:"1:有效,0:禁用"`
  19. Mobile string `description:"手机号"`
  20. RoleId int `description:"角色Id"`
  21. RoleTypeCode string `description:"角色编码"`
  22. DepartmentId int `description:"部门id"`
  23. DepartmentName string `description:"部门名称"`
  24. DepartmentGroup string `description:"部门分组"`
  25. TeamId int `description:"小组id"`
  26. GroupId int `description:"分组id"`
  27. GroupName string `description:"分组名称"`
  28. Authority int `description:"管理权限,0:无,1:部门负责人,2:小组负责人,或者ficc销售主管,4:ficc销售组长"`
  29. LabelVal int `description:"标签:1:超级管理员,2:管理员,3:部门经理,4:组长,5:ficc销售主管"`
  30. }
  31. func (sa *SysRoleAdmin) TableName() string {
  32. return "sys_role_admin"
  33. }
  34. func GetRoleIdsByAdminId(adminId int) (items []*SysRoleAdmin, err error) {
  35. sql := `SELECT * from sys_role_admin where admin_id = ?`
  36. err = global.DEFAULT_DmSQL.Raw(sql, adminId).Find(&items).Error
  37. return
  38. }
  39. func GetRoleAdminList(condition string, pars []interface{}, startSize, pageSize int) (list []*RoleAdminItem, err error) {
  40. sql := `SELECT
  41. s.id as sys_role_admin_id,
  42. a.admin_id,
  43. a.admin_name,
  44. a.real_name,
  45. a.mobile,
  46. a.department_id,
  47. a.department_name,
  48. a.enabled,
  49. a.role_id,
  50. a.role_type_code ,
  51. a.group_id,
  52. a.authority,
  53. a.group_name
  54. FROM
  55. sys_role_admin s
  56. INNER JOIN "admin" a ON s.admin_id = a.admin_id
  57. where 1=1`
  58. if condition != "" {
  59. sql += condition
  60. }
  61. sql += ` ORDER BY s.id DESC limit ?, ?`
  62. pars = append(pars, startSize)
  63. pars = append(pars, pageSize)
  64. err = global.DEFAULT_DmSQL.Raw(sql, pars...).Find(&list).Error
  65. return
  66. }
  67. func GetRoleAdminListTotal(condition string, pars []interface{}) (total int64, err error) {
  68. sql := `SELECT
  69. count(*)
  70. FROM
  71. sys_role_admin s
  72. INNER JOIN "admin" a ON s.admin_id = a.admin_id
  73. where 1=1`
  74. if condition != "" {
  75. sql += condition
  76. }
  77. err = global.DEFAULT_DmSQL.Raw(sql, pars...).Scan(&total).Error
  78. return
  79. }
  80. func CheckRoleAdminByAdminIds(adminIds string, roleId int) (list []*SysRoleAdmin, err error) {
  81. sql := `SELECT
  82. s.*
  83. FROM
  84. sys_role_admin s
  85. LEFT JOIN "admin" a ON s.admin_id = a.admin_id
  86. where s.role_id=? and s.admin_id in (` + adminIds + `)`
  87. err = global.DEFAULT_DmSQL.Raw(sql, roleId).Find(&list).Error
  88. return
  89. }
  90. func AddRoleAdminBatch(admins []*SysRoleAdmin) (err error) {
  91. err = global.DEFAULT_DmSQL.CreateInBatches(admins, utils.MultiAddNum).Error
  92. return
  93. }
  94. func DeleteRoleAdmin(SysRoleAdminId int) (err error) {
  95. sql := `DELETE FROM sys_role_admin WHERE id=? `
  96. err = global.DEFAULT_DmSQL.Exec(sql, SysRoleAdminId).Error
  97. return
  98. }