广告平台(站长使用)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

hdl_role.go 24 KiB

4 maanden geleden
2 maanden geleden
4 maanden geleden
4 maanden geleden
4 maanden geleden
4 maanden geleden
4 maanden geleden
3 maanden geleden
3 maanden geleden
4 maanden geleden
4 maanden geleden
4 maanden geleden
3 maanden geleden
3 maanden geleden
4 maanden geleden
4 maanden geleden
4 maanden geleden
4 maanden geleden
4 maanden geleden
4 maanden geleden
4 maanden geleden
4 maanden geleden
4 maanden geleden
2 maanden geleden
4 maanden geleden
4 maanden geleden
4 maanden geleden
4 maanden geleden
4 maanden geleden
2 maanden geleden
4 maanden geleden
4 maanden geleden
4 maanden geleden
2 maanden geleden
4 maanden geleden
4 maanden geleden
4 maanden geleden
4 maanden geleden
4 maanden geleden
4 maanden geleden
4 maanden geleden
2 maanden geleden
2 maanden geleden
2 maanden geleden
2 maanden geleden
2 maanden geleden
2 maanden geleden
2 maanden geleden
2 maanden geleden
2 maanden geleden
2 maanden geleden
2 maanden geleden
2 maanden geleden
2 maanden geleden
2 maanden geleden
2 maanden geleden
2 maanden geleden
2 maanden geleden
2 maanden geleden
2 maanden geleden
2 maanden geleden
2 maanden geleden
2 maanden geleden
2 maanden geleden
2 maanden geleden
2 maanden geleden
2 maanden geleden
2 maanden geleden
2 maanden geleden
2 maanden geleden
2 maanden geleden
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829
  1. package hdl
  2. import (
  3. "applet/app/e"
  4. "applet/app/enum"
  5. "applet/app/lib/validate"
  6. "applet/app/md"
  7. "applet/app/svc"
  8. "applet/app/utils"
  9. db "code.fnuoos.com/zhimeng/model.git/src"
  10. "code.fnuoos.com/zhimeng/model.git/src/implement"
  11. "code.fnuoos.com/zhimeng/model.git/src/model"
  12. implement2 "code.fnuoos.com/zhimeng/model.git/src/super/implement"
  13. "github.com/gin-gonic/gin"
  14. "time"
  15. )
  16. // PermissionGroupList
  17. // @Summary 权限组列表
  18. // @Tags 权限管理
  19. // @Description 权限管理-权限组列表
  20. // @param Authorization header string true "验证参数Bearer和token空格拼接"
  21. // @Accept json
  22. // @Produce json
  23. // @param adm_id query string true "管理员id"
  24. // @Success 200 {string} "具体看返回内容"
  25. // @Failure 400 {object} md.Response "具体错误"
  26. // @Router /role/permissionGroupList [GET]
  27. func PermissionGroupList(c *gin.Context) {
  28. roleId := c.DefaultQuery("role_id", "")
  29. engine := db.DBs[svc.GetMasterId(c)]
  30. qrcodeWithBatchRecordsDb := implement.NewPermissionGroupDb(engine)
  31. groupList, err := qrcodeWithBatchRecordsDb.FindPermissionGroup()
  32. if err != nil {
  33. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  34. return
  35. }
  36. roleDb := implement.NewRoleDb(engine, utils.StrToInt(roleId))
  37. list, _, err := roleDb.FindPermissionGroupByRole(utils.StrToInt(roleId))
  38. if err != nil {
  39. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  40. return
  41. }
  42. var isHasPermissionGroupId []string
  43. for _, v := range list {
  44. isHasPermissionGroupId = append(isHasPermissionGroupId, utils.IntToStr(v.PermissionGroup.Id))
  45. }
  46. var tempRespMap = map[string]*md.PermissionGroupListResp{}
  47. var tempRespMapKeys []string
  48. for _, v := range *groupList {
  49. isCheck := false
  50. if utils.InArr(utils.IntToStr(v.Id), isHasPermissionGroupId) {
  51. isCheck = true
  52. }
  53. tempRespMap[utils.IntToStr(v.Id)] = &md.PermissionGroupListResp{
  54. Id: v.Id,
  55. Name: v.Name,
  56. Key: v.Key,
  57. State: v.State,
  58. ParentId: v.ParentId,
  59. CreateAt: v.CreateAt,
  60. UpdateAt: v.UpdateAt,
  61. IsCheck: isCheck,
  62. }
  63. tempRespMapKeys = append(tempRespMapKeys, utils.IntToStr(v.Id))
  64. }
  65. for _, v := range tempRespMap {
  66. if v.ParentId != 0 && tempRespMap[utils.IntToStr(v.ParentId)].ParentId != 0 {
  67. tempRespMap[utils.IntToStr(v.ParentId)].SubPermissionGroupList = append(tempRespMap[utils.IntToStr(v.ParentId)].SubPermissionGroupList, *v)
  68. }
  69. }
  70. for _, v := range tempRespMap {
  71. if v.ParentId != 0 && tempRespMap[utils.IntToStr(v.ParentId)].ParentId == 0 {
  72. tempRespMap[utils.IntToStr(v.ParentId)].SubPermissionGroupList = append(tempRespMap[utils.IntToStr(v.ParentId)].SubPermissionGroupList, *v)
  73. }
  74. }
  75. var resp []*md.PermissionGroupListResp
  76. for _, v := range tempRespMapKeys {
  77. if tempRespMap[v].ParentId == 0 {
  78. resp = append(resp, tempRespMap[v])
  79. }
  80. }
  81. e.OutSuc(c, map[string]interface{}{
  82. "list": resp,
  83. "state": []map[string]interface{}{
  84. {
  85. "name": enum.PermissionGroupState(enum.PermissionGroupStateForNormal).String(),
  86. "value": enum.PermissionGroupStateForNormal,
  87. },
  88. {
  89. "name": enum.PermissionGroupState(enum.PermissionGroupStateForDiscard).String(),
  90. "value": enum.PermissionGroupStateForDiscard,
  91. },
  92. },
  93. }, nil)
  94. return
  95. }
  96. // RoleList
  97. // @Summary 角色列表
  98. // @Tags 权限管理
  99. // @Description 权限管理-角色列表
  100. // @param Authorization header string true "验证参数Bearer和token空格拼接"
  101. // @Accept json
  102. // @Produce json
  103. // @Success 200 {string} "具体看返回内容"
  104. // @Failure 400 {object} md.Response "具体错误"
  105. // @Router /api/role/roleList [GET]
  106. func RoleList(c *gin.Context) {
  107. engine := db.DBs[svc.GetMasterId(c)]
  108. roleDb := implement.NewRoleDb(engine, 0)
  109. roleList, err := roleDb.FindRole()
  110. if err != nil {
  111. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  112. return
  113. }
  114. adminRoleDb := implement.NewAdminRoleDb(engine)
  115. adminDb := implement.NewAdminDb(engine)
  116. var result []*md.RoleListResp
  117. for _, v := range *roleList {
  118. var temp md.RoleListResp
  119. temp.Data = v
  120. adminRoles, err1 := adminRoleDb.FindAdminRoleByRoleId(v.Id)
  121. if err1 != nil {
  122. e.OutErr(c, e.ERR_DB_ORM, err1.Error())
  123. return
  124. }
  125. for _, adminRole := range *adminRoles {
  126. admin, err2 := adminDb.GetAdmin(adminRole.AdmId)
  127. if err2 != nil {
  128. e.OutErr(c, e.ERR_DB_ORM, err2.Error())
  129. return
  130. }
  131. temp.AdminList = append(temp.AdminList, struct {
  132. Name string `json:"name"`
  133. }{
  134. Name: admin.Username,
  135. })
  136. }
  137. result = append(result, &temp)
  138. }
  139. e.OutSuc(c, map[string]interface{}{
  140. "list": result,
  141. "state": []map[string]interface{}{
  142. {
  143. "name": enum.RoleState(enum.RoleStateForNormal).String(),
  144. "value": enum.RoleStateForNormal,
  145. },
  146. {
  147. "name": enum.RoleState(enum.RoleStateForFreeze).String(),
  148. "value": enum.RoleStateForFreeze,
  149. },
  150. },
  151. }, nil)
  152. return
  153. }
  154. // AddRole
  155. // @Summary 添加角色
  156. // @Tags 权限管理
  157. // @Description 权限管理-添加角色
  158. // @param Authorization header string true "验证参数Bearer和token空格拼接"
  159. // @Accept json
  160. // @Produce json
  161. // @Param args body md.AddRoleReq true "请求参数"
  162. // @Success 200 {string} "success"
  163. // @Failure 400 {object} md.Response "具体错误"
  164. // @Router /api/role/addRole [POST]
  165. func AddRole(c *gin.Context) {
  166. var req md.AddRoleReq
  167. err := c.ShouldBindJSON(&req)
  168. if err != nil {
  169. err = validate.HandleValidateErr(err)
  170. err1 := err.(e.E)
  171. e.OutErr(c, err1.Code, err1.Error())
  172. return
  173. }
  174. engine := db.DBs[svc.GetMasterId(c)]
  175. roleDb := implement.NewRoleDb(engine, 0)
  176. now := time.Now()
  177. _, err = roleDb.RoleInsert(&model.Role{
  178. Name: req.Name,
  179. State: enum.RoleStateForNormal,
  180. Memo: req.Memo,
  181. Logo: req.Logo,
  182. Label: req.Label,
  183. SeoLogo: req.SeoLogo,
  184. SeoTitle: req.SeoTitle,
  185. CreateAt: now.Format("2006-01-02 15:04:05"),
  186. UpdateAt: now.Format("2006-01-02 15:04:05"),
  187. })
  188. if err != nil {
  189. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  190. return
  191. }
  192. e.OutSuc(c, "success", nil)
  193. return
  194. }
  195. // UpdateRole
  196. // @Summary 修改角色
  197. // @Tags 权限管理
  198. // @Description 权限管理-修改角色
  199. // @param Authorization header string true "验证参数Bearer和token空格拼接"
  200. // @Accept json
  201. // @Produce json
  202. // @Param args body md.UpdateRoleReq true "请求参数"
  203. // @Success 200 {string} "success"
  204. // @Failure 400 {object} md.Response "具体错误"
  205. // @Router /api/role/updateRole [POST]
  206. func UpdateRole(c *gin.Context) {
  207. var req md.UpdateRoleReq
  208. err := c.ShouldBindJSON(&req)
  209. if err != nil {
  210. err = validate.HandleValidateErr(err)
  211. err1 := err.(e.E)
  212. e.OutErr(c, err1.Code, err1.Error())
  213. return
  214. }
  215. engine := db.DBs[svc.GetMasterId(c)]
  216. roleDb := implement.NewRoleDb(engine, req.RoleId)
  217. role, err := roleDb.GetRole()
  218. if err != nil {
  219. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  220. return
  221. }
  222. if role == nil {
  223. e.OutErr(c, e.ERR_NO_DATA, "未查询到相应记录")
  224. return
  225. }
  226. role.Name = req.Name
  227. role.Memo = req.Memo
  228. role.Logo = req.Logo
  229. role.Label = req.Label
  230. role.SeoLogo = req.SeoLogo
  231. role.SeoTitle = req.SeoTitle
  232. _, err = roleDb.UpdateRole(role, "name", "memo", "logo", "label", "seo_logo", "seo_title")
  233. if err != nil {
  234. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  235. return
  236. }
  237. e.OutSuc(c, "success", nil)
  238. return
  239. }
  240. // RoleBindPermissionGroup
  241. // @Summary 角色绑定权限组
  242. // @Tags 权限管理
  243. // @Description 权限管理-角色绑定权限组
  244. // @param Authorization header string true "验证参数Bearer和token空格拼接"
  245. // @Accept json
  246. // @Produce json
  247. // @Param args body md.RoleBindPermissionGroupReq true "请求参数"
  248. // @Success 200 {string} "success"
  249. // @Failure 400 {object} md.Response "具体错误"
  250. // @Router /api/role/roleBindPermissionGroup [POST]
  251. func RoleBindPermissionGroup(c *gin.Context) {
  252. var req md.RoleBindPermissionGroupReq
  253. err := c.ShouldBindJSON(&req)
  254. if err != nil {
  255. err = validate.HandleValidateErr(err)
  256. err1 := err.(e.E)
  257. e.OutErr(c, err1.Code, err1.Error())
  258. return
  259. }
  260. err = svc.RoleBindPermissionGroup(c, req)
  261. if err != nil {
  262. e.OutErr(c, e.ERR, err.Error())
  263. return
  264. }
  265. e.OutSuc(c, "success", nil)
  266. return
  267. }
  268. // UpdateRoleState
  269. // @Summary 修改角色状态
  270. // @Tags 权限管理
  271. // @Description 权限管理-修改角色状态
  272. // @param Authorization header string true "验证参数Bearer和token空格拼接"
  273. // @Accept json
  274. // @Produce json
  275. // @Param args body md.UpdateRoleStateReq true "请求参数"
  276. // @Success 200 {string} "success"
  277. // @Failure 400 {object} md.Response "具体错误"
  278. // @Router /api/role/updateRoleState [POST]
  279. func UpdateRoleState(c *gin.Context) {
  280. var req md.UpdateRoleStateReq
  281. err := c.ShouldBindJSON(&req)
  282. if err != nil {
  283. err = validate.HandleValidateErr(err)
  284. err1 := err.(e.E)
  285. e.OutErr(c, err1.Code, err1.Error())
  286. return
  287. }
  288. engine := db.DBs[svc.GetMasterId(c)]
  289. roleDb := implement.NewRoleDb(engine, req.RoleId)
  290. role, err := roleDb.GetRole()
  291. if err != nil {
  292. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  293. return
  294. }
  295. if role == nil {
  296. e.OutErr(c, e.ERR_NO_DATA, "未查询到相应记录")
  297. return
  298. }
  299. role.State = req.State
  300. _, err = roleDb.UpdateRole(role, "state")
  301. if err != nil {
  302. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  303. return
  304. }
  305. e.OutSuc(c, "success", nil)
  306. return
  307. }
  308. // DeleteRole
  309. // @Summary 删除角色
  310. // @Tags 权限管理
  311. // @Description 权限管理-删除角色
  312. // @param Authorization header string true "验证参数Bearer和token空格拼接"
  313. // @Accept json
  314. // @Produce json
  315. // @Param args body md.UpdateRoleStateReq true "请求参数"
  316. // @Success 200 {string} "success"
  317. // @Failure 400 {object} md.Response "具体错误"
  318. // @Router /api/role/deleteRole/{$id} [DELETE]
  319. func DeleteRole(c *gin.Context) {
  320. id := c.Param("id")
  321. engine := db.DBs[svc.GetMasterId(c)]
  322. roleDb := implement.NewRoleDb(engine, utils.StrToInt(id))
  323. role, err := roleDb.GetRole()
  324. if err != nil {
  325. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  326. return
  327. }
  328. if role == nil {
  329. e.OutErr(c, e.ERR_NO_DATA, "未查询到相应记录")
  330. return
  331. }
  332. err = svc.DeleteRole(c, utils.StrToInt(id))
  333. if err != nil {
  334. e.OutErr(c, e.ERR, err.Error())
  335. return
  336. }
  337. e.OutSuc(c, "success", nil)
  338. return
  339. }
  340. // AdminList
  341. // @Summary 管理员列表
  342. // @Tags 权限管理
  343. // @Description 权限管理-管理员列表
  344. // @param Authorization header string true "验证参数Bearer和token空格拼接"
  345. // @Accept json
  346. // @Produce json
  347. // @Param args body md.AdminListReq true "请求参数"
  348. // @Success 200 {string} "具体看返回内容"
  349. // @Failure 400 {object} md.Response "具体错误"
  350. // @Router /api/role/adminList [POST]
  351. func AdminList(c *gin.Context) {
  352. var req md.AdminListReq
  353. err := c.ShouldBindJSON(&req)
  354. if err != nil {
  355. err = validate.HandleValidateErr(err)
  356. err1 := err.(e.E)
  357. e.OutErr(c, err1.Code, err1.Error())
  358. return
  359. }
  360. if req.Limit == 0 {
  361. req.Limit = 10
  362. }
  363. if req.Page == 0 {
  364. req.Page = 10
  365. }
  366. engine := db.DBs[svc.GetMasterId(c)]
  367. adminDb := implement.NewAdminDb(engine)
  368. adminList, total, err := adminDb.FindAdmin(req.UserName, req.State, req.Page, req.Limit)
  369. if err != nil {
  370. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  371. return
  372. }
  373. var result []md.AdminListResp
  374. for _, v := range adminList {
  375. permissionGroupList, _, err1 := adminDb.FindAdminRolePermissionGroup(v.AdmId)
  376. if err1 != nil {
  377. e.OutErr(c, e.ERR_DB_ORM, err1.Error())
  378. return
  379. }
  380. var roleList []string
  381. for _, v1 := range permissionGroupList {
  382. roleList = append(roleList, v1.Role.Name)
  383. }
  384. result = append(result, md.AdminListResp{
  385. AdmId: v.AdmId,
  386. ShowTime: v.ShowTime,
  387. Username: v.Username,
  388. State: v.State,
  389. IsSuperAdministrator: v.IsSuperAdministrator,
  390. Memo: v.Memo,
  391. CreateAt: v.CreateAt,
  392. UpdateAt: v.UpdateAt,
  393. RoleList: roleList,
  394. })
  395. }
  396. e.OutSuc(c, map[string]interface{}{
  397. "list": result,
  398. "total": total,
  399. "state": []map[string]interface{}{
  400. {
  401. "name": enum.RoleState(enum.RoleStateForNormal).String(),
  402. "value": enum.RoleStateForNormal,
  403. },
  404. {
  405. "name": enum.RoleState(enum.RoleStateForFreeze).String(),
  406. "value": enum.RoleStateForFreeze,
  407. },
  408. },
  409. }, nil)
  410. return
  411. }
  412. // UpdateAdminState
  413. // @Summary 修改管理员状态
  414. // @Tags 权限管理
  415. // @Description 权限管理-修改管理员状态
  416. // @param Authorization header string true "验证参数Bearer和token空格拼接"
  417. // @Accept json
  418. // @Produce json
  419. // @Param args body md.UpdateAdminStateReq true "请求参数"
  420. // @Success 200 {string} "success"
  421. // @Failure 400 {object} md.Response "具体错误"
  422. // @Router /api/role/updateAdminState [POST]
  423. func UpdateAdminState(c *gin.Context) {
  424. var req md.UpdateAdminStateReq
  425. err := c.ShouldBindJSON(&req)
  426. if err != nil {
  427. err = validate.HandleValidateErr(err)
  428. err1 := err.(e.E)
  429. e.OutErr(c, err1.Code, err1.Error())
  430. return
  431. }
  432. engine := db.DBs[svc.GetMasterId(c)]
  433. admDb := implement.NewAdminDb(engine)
  434. admin, err := admDb.GetAdmin(req.AdmId)
  435. if err != nil {
  436. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  437. return
  438. }
  439. if admin == nil {
  440. e.OutErr(c, e.ERR_NO_DATA, "未查询到相应记录")
  441. return
  442. }
  443. admin.State = req.State
  444. _, err = admDb.UpdateAdmin(admin, "state")
  445. if err != nil {
  446. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  447. return
  448. }
  449. e.OutSuc(c, "success", nil)
  450. return
  451. }
  452. // UpdateAdmin
  453. // @Summary 修改管理员信息
  454. // @Tags 权限管理
  455. // @Description 权限管理-修改管理员信息
  456. // @param Authorization header string true "验证参数Bearer和token空格拼接"
  457. // @Accept json
  458. // @Produce json
  459. // @Param args body md.UpdateAdminReq true "请求参数"
  460. // @Success 200 {string} "success"
  461. // @Failure 400 {object} md.Response "具体错误"
  462. // @Router /api/role/updateAdmin [POST]
  463. func UpdateAdmin(c *gin.Context) {
  464. var req md.UpdateAdminReq
  465. err := c.ShouldBindJSON(&req)
  466. if err != nil {
  467. err = validate.HandleValidateErr(err)
  468. err1 := err.(e.E)
  469. e.OutErr(c, err1.Code, err1.Error())
  470. return
  471. }
  472. engine := db.DBs[svc.GetMasterId(c)]
  473. admDb := implement.NewAdminDb(engine)
  474. admin, err := admDb.GetAdmin(req.AdmId)
  475. if err != nil {
  476. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  477. return
  478. }
  479. if admin == nil {
  480. e.OutErr(c, e.ERR_NO_DATA, "未查询到相应记录")
  481. return
  482. }
  483. admin.Username = req.Username
  484. admin.Memo = req.Memo
  485. admin.ShowTime = req.ShowTime
  486. if req.Password != "" {
  487. admin.Password = utils.Md5(req.Password)
  488. }
  489. _, err = admDb.UpdateAdmin(admin, "username", "memo", "password", "show_time")
  490. if err != nil {
  491. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  492. return
  493. }
  494. e.OutSuc(c, "success", nil)
  495. return
  496. }
  497. // AddAdmin
  498. // @Summary 新增管理员
  499. // @Tags 权限管理
  500. // @Description 权限管理-新增管理员
  501. // @param Authorization header string true "验证参数Bearer和token空格拼接"
  502. // @Accept json
  503. // @Produce json
  504. // @Param args body md.AddAdminReq true "请求参数"
  505. // @Success 200 {string} "success"
  506. // @Failure 400 {object} md.Response "具体错误"
  507. // @Router /api/role/addAdmin [POST]
  508. func AddAdmin(c *gin.Context) {
  509. var req md.AddAdminReq
  510. err := c.ShouldBindJSON(&req)
  511. if err != nil {
  512. err = validate.HandleValidateErr(err)
  513. err1 := err.(e.E)
  514. e.OutErr(c, err1.Code, err1.Error())
  515. return
  516. }
  517. engine := db.DBs[svc.GetMasterId(c)]
  518. admDb := implement.NewAdminDb(engine)
  519. isHasAdmin, err := admDb.GetAdminByUserName(req.Username)
  520. if err != nil {
  521. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  522. return
  523. }
  524. if isHasAdmin != nil {
  525. e.OutErr(c, e.ERR, "当前用户名已存在,请勿重复添加")
  526. return
  527. }
  528. admId, err := admDb.CreateAdminId()
  529. if err != nil {
  530. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  531. return
  532. }
  533. admin := model.Admin{
  534. ShowTime: req.ShowTime,
  535. AdmId: admId,
  536. Username: req.Username,
  537. Password: utils.Md5(req.Password),
  538. State: enum.AdminStateForNormal,
  539. IsSuperAdministrator: 0,
  540. Memo: req.Memo,
  541. CreateAt: time.Now().Format("2006-01-02 15:04:05"),
  542. UpdateAt: time.Now().Format("2006-01-02 15:04:05"),
  543. }
  544. _, err = admDb.AdminInsert(&admin)
  545. if err != nil {
  546. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  547. return
  548. }
  549. e.OutSuc(c, "success", nil)
  550. return
  551. }
  552. // DeleteAdmin
  553. // @Summary 删除管理员
  554. // @Tags 权限管理
  555. // @Description 权限管理-删除管理员
  556. // @param Authorization header string true "验证参数Bearer和token空格拼接"
  557. // @Accept json
  558. // @Produce json
  559. // @Success 200 {string} "success"
  560. // @Failure 400 {object} md.Response "具体错误"
  561. // @Router /api/role/deleteAdmin/{$adm_id} [DELETE]
  562. func DeleteAdmin(c *gin.Context) {
  563. admId := c.Param("adm_id")
  564. err := svc.AdminDelete(c, []int{utils.StrToInt(admId)})
  565. if err != nil {
  566. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  567. return
  568. }
  569. e.OutSuc(c, "success", nil)
  570. return
  571. }
  572. // BindAdminRole
  573. // @Summary 管理员绑定角色
  574. // @Tags 权限管理
  575. // @Description 权限管理-管理员绑定角色
  576. // @param Authorization header string true "验证参数Bearer和token空格拼接"
  577. // @Accept json
  578. // @Produce json
  579. // @Param args body md.BindAdminRoleReq true "请求参数"
  580. // @Success 200 {string} "success"
  581. // @Failure 400 {object} md.Response "具体错误"
  582. // @Router /api/role/bindAdminRole/ [POST]
  583. func BindAdminRole(c *gin.Context) {
  584. var req md.BindAdminRoleReq
  585. err := c.ShouldBindJSON(&req)
  586. if err != nil {
  587. err = validate.HandleValidateErr(err)
  588. err1 := err.(e.E)
  589. e.OutErr(c, err1.Code, err1.Error())
  590. return
  591. }
  592. err = svc.BindAdminRole(c, req)
  593. if err != nil {
  594. e.OutErr(c, e.ERR, err.Error())
  595. return
  596. }
  597. e.OutSuc(c, "success", nil)
  598. return
  599. }
  600. // AdminInfo
  601. // @Summary 管理员信息
  602. // @Tags 权限管理
  603. // @Description 权限管理-管理员信息
  604. // @param Authorization header string true "验证参数Bearer和token空格拼接"
  605. // @Accept json
  606. // @Produce json
  607. // @param adm_id query string true "管理员id"
  608. // @Success 200 {string} "具体看返回内容"
  609. // @Failure 400 {object} md.Response "具体错误"
  610. // @Router /api/role/adminInfo [GET]
  611. func AdminInfo(c *gin.Context) {
  612. admId := c.DefaultQuery("adm_id", "")
  613. engine := db.DBs[svc.GetMasterId(c)]
  614. admDb := implement.NewAdminDb(engine)
  615. admin, err := admDb.GetAdmin(utils.StrToInt(admId))
  616. if err != nil {
  617. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  618. return
  619. }
  620. admin.Password = ""
  621. e.OutSuc(c, map[string]interface{}{
  622. "info": admin,
  623. "state": []map[string]interface{}{
  624. {
  625. "name": enum.RoleState(enum.RoleStateForNormal).String(),
  626. "value": enum.RoleStateForNormal,
  627. },
  628. {
  629. "name": enum.RoleState(enum.RoleStateForFreeze).String(),
  630. "value": enum.RoleStateForFreeze,
  631. },
  632. },
  633. }, nil)
  634. return
  635. }
  636. func RoleMediumList(c *gin.Context) {
  637. var req md.AdminBindMediumListReq
  638. err := c.ShouldBindJSON(&req)
  639. if err != nil {
  640. err = validate.HandleValidateErr(err)
  641. err1 := err.(e.E)
  642. e.OutErr(c, err1.Code, err1.Error())
  643. return
  644. }
  645. engine := svc.MasterDb(c)
  646. NewMediumDb := implement.NewMediumDb(engine)
  647. appId := svc.GetMediumIdStr(c, 0, req.Name, req.Account)
  648. list, total, _ := NewMediumDb.FindSuperAdminByMediumId(appId, utils.StrToInt(req.Page), utils.StrToInt(req.Limit))
  649. data := make([]md.AdminBindMediumListData, 0)
  650. if len(list) > 0 {
  651. for _, v := range list {
  652. var tmp = md.AdminBindMediumListData{
  653. MediumId: utils.IntToStr(v.MediumId),
  654. Name: v.Memo,
  655. IsBind: "0",
  656. Account: v.Username,
  657. }
  658. NewMediumListDb := implement2.NewMediumListDb(db.Db)
  659. GetMediumList, _ := NewMediumListDb.GetMediumList(v.MediumId)
  660. if GetMediumList != nil {
  661. tmp.Name = GetMediumList.CompanyName
  662. if GetMediumList.CompanyAbbreviation != "" {
  663. tmp.Name = GetMediumList.CompanyAbbreviation
  664. }
  665. }
  666. count, _ := engine.Where("medium_id=? and admin_id=?", v.MediumId, req.AdminId).Count(&model.AdminBindMedium{})
  667. if count > 0 {
  668. tmp.IsBind = "1"
  669. }
  670. data = append(data, tmp)
  671. }
  672. }
  673. res := md.AdminBindMediumListRes{
  674. List: data,
  675. Total: total,
  676. }
  677. e.OutSuc(c, res, nil)
  678. return
  679. }
  680. func RoleBindMedium(c *gin.Context) {
  681. var req md.AdminBindMediumListSaveReq
  682. err := c.ShouldBindJSON(&req)
  683. if err != nil {
  684. err = validate.HandleValidateErr(err)
  685. err1 := err.(e.E)
  686. e.OutErr(c, err1.Code, err1.Error())
  687. return
  688. }
  689. NewAdminBindMediumDb := implement.NewAdminBindMediumDb(svc.MasterDb(c))
  690. data := NewAdminBindMediumDb.GetAdminByMediumId(utils.StrToInt(req.AdminId), utils.StrToInt(req.MediumId))
  691. if data != nil {
  692. e.OutErr(c, 400, e.NewErr(400, "已绑定该媒体"))
  693. return
  694. }
  695. tmp := model.AdminBindMedium{
  696. AdminId: utils.StrToInt(req.AdminId),
  697. MediumId: utils.StrToInt(req.MediumId),
  698. CreateAt: time.Now(),
  699. UpdateAt: time.Now(),
  700. }
  701. svc.MasterDb(c).Insert(&tmp)
  702. e.OutSuc(c, "success", nil)
  703. return
  704. }
  705. func RoleDelMedium(c *gin.Context) {
  706. var req md.AdminBindMediumListSaveReq
  707. err := c.ShouldBindJSON(&req)
  708. if err != nil {
  709. err = validate.HandleValidateErr(err)
  710. err1 := err.(e.E)
  711. e.OutErr(c, err1.Code, err1.Error())
  712. return
  713. }
  714. svc.MasterDb(c).Where("medium_id=? and admin_id=?", req.MediumId, req.AdminId).Delete(&model.AdminBindMedium{})
  715. e.OutSuc(c, "success", nil)
  716. return
  717. }
  718. func RoleAgentList(c *gin.Context) {
  719. var req md.AdminBindMediumListReq
  720. err := c.ShouldBindJSON(&req)
  721. if err != nil {
  722. err = validate.HandleValidateErr(err)
  723. err1 := err.(e.E)
  724. e.OutErr(c, err1.Code, err1.Error())
  725. return
  726. }
  727. engine := svc.MasterDb(c)
  728. NewAgentDb := implement.NewAgentDb(engine)
  729. appId := svc.GetAgentIdStr(c, 0, req.Name, req.Account)
  730. list, total, _ := NewAgentDb.FindSuperAdminByAgentId(appId, utils.StrToInt(req.Page), utils.StrToInt(req.Limit))
  731. data := make([]md.AdminBindMediumListData, 0)
  732. if len(list) > 0 {
  733. for _, v := range list {
  734. var tmp = md.AdminBindMediumListData{
  735. MediumId: utils.IntToStr(v.AgentId),
  736. Name: v.Memo,
  737. IsBind: "0",
  738. Account: v.Username,
  739. }
  740. NewAgentListDb := implement2.NewAgentListDb(db.Db)
  741. GetAgentList, _ := NewAgentListDb.GetAgentList(v.AgentId)
  742. if GetAgentList != nil {
  743. tmp.Name = GetAgentList.CompanyName
  744. if GetAgentList.CompanyAbbreviation != "" {
  745. tmp.Name = GetAgentList.CompanyAbbreviation
  746. }
  747. }
  748. count, _ := engine.Where("agent_id=? and admin_id=?", v.AgentId, req.AdminId).Count(&model.AdminBindAgent{})
  749. if count > 0 {
  750. tmp.IsBind = "1"
  751. }
  752. data = append(data, tmp)
  753. }
  754. }
  755. res := md.AdminBindMediumListRes{
  756. List: data,
  757. Total: total,
  758. }
  759. e.OutSuc(c, res, nil)
  760. return
  761. }
  762. func RoleBindAgent(c *gin.Context) {
  763. var req md.AdminBindMediumListSaveReq
  764. err := c.ShouldBindJSON(&req)
  765. if err != nil {
  766. err = validate.HandleValidateErr(err)
  767. err1 := err.(e.E)
  768. e.OutErr(c, err1.Code, err1.Error())
  769. return
  770. }
  771. NewAdminBindAgentDb := implement.NewAdminBindAgentDb(svc.MasterDb(c))
  772. data := NewAdminBindAgentDb.GetAdminByAgentId(utils.StrToInt(req.AdminId), utils.StrToInt(req.MediumId))
  773. if data != nil {
  774. e.OutErr(c, 400, e.NewErr(400, "已绑定该媒体"))
  775. return
  776. }
  777. tmp := model.AdminBindAgent{
  778. AdminId: utils.StrToInt(req.AdminId),
  779. AgentId: utils.StrToInt(req.MediumId),
  780. CreateAt: time.Now(),
  781. UpdateAt: time.Now(),
  782. }
  783. svc.MasterDb(c).Insert(&tmp)
  784. e.OutSuc(c, "success", nil)
  785. return
  786. }
  787. func RoleDelAgent(c *gin.Context) {
  788. var req md.AdminBindMediumListSaveReq
  789. err := c.ShouldBindJSON(&req)
  790. if err != nil {
  791. err = validate.HandleValidateErr(err)
  792. err1 := err.(e.E)
  793. e.OutErr(c, err1.Code, err1.Error())
  794. return
  795. }
  796. svc.MasterDb(c).Where("agent_id=? and admin_id=?", req.MediumId, req.AdminId).Delete(&model.AdminBindAgent{})
  797. e.OutSuc(c, "success", nil)
  798. return
  799. }