广告平台(站长使用)
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 21 KiB

4 months ago
2 months ago
4 months ago
4 months ago
4 months ago
4 months ago
4 months ago
3 months ago
3 months ago
4 months ago
4 months ago
4 months ago
3 months ago
3 months ago
4 months ago
4 months ago
4 months ago
4 months ago
4 months ago
4 months ago
4 months ago
4 months ago
4 months ago
4 months ago
4 months ago
4 months ago
4 months ago
4 months ago
4 months ago
4 months ago
4 months ago
4 months ago
4 months ago
4 months ago
4 months ago
2 months ago
2 months ago
2 months ago
2 months ago
2 months ago
2 months ago
2 months ago
2 months ago
2 months ago
2 months ago
2 months ago
2 months ago
2 months ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740
  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. Username: v.Username,
  387. State: v.State,
  388. IsSuperAdministrator: v.IsSuperAdministrator,
  389. Memo: v.Memo,
  390. CreateAt: v.CreateAt,
  391. UpdateAt: v.UpdateAt,
  392. RoleList: roleList,
  393. })
  394. }
  395. e.OutSuc(c, map[string]interface{}{
  396. "list": result,
  397. "total": total,
  398. "state": []map[string]interface{}{
  399. {
  400. "name": enum.RoleState(enum.RoleStateForNormal).String(),
  401. "value": enum.RoleStateForNormal,
  402. },
  403. {
  404. "name": enum.RoleState(enum.RoleStateForFreeze).String(),
  405. "value": enum.RoleStateForFreeze,
  406. },
  407. },
  408. }, nil)
  409. return
  410. }
  411. // UpdateAdminState
  412. // @Summary 修改管理员状态
  413. // @Tags 权限管理
  414. // @Description 权限管理-修改管理员状态
  415. // @param Authorization header string true "验证参数Bearer和token空格拼接"
  416. // @Accept json
  417. // @Produce json
  418. // @Param args body md.UpdateAdminStateReq true "请求参数"
  419. // @Success 200 {string} "success"
  420. // @Failure 400 {object} md.Response "具体错误"
  421. // @Router /api/role/updateAdminState [POST]
  422. func UpdateAdminState(c *gin.Context) {
  423. var req md.UpdateAdminStateReq
  424. err := c.ShouldBindJSON(&req)
  425. if err != nil {
  426. err = validate.HandleValidateErr(err)
  427. err1 := err.(e.E)
  428. e.OutErr(c, err1.Code, err1.Error())
  429. return
  430. }
  431. engine := db.DBs[svc.GetMasterId(c)]
  432. admDb := implement.NewAdminDb(engine)
  433. admin, err := admDb.GetAdmin(req.AdmId)
  434. if err != nil {
  435. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  436. return
  437. }
  438. if admin == nil {
  439. e.OutErr(c, e.ERR_NO_DATA, "未查询到相应记录")
  440. return
  441. }
  442. admin.State = req.State
  443. _, err = admDb.UpdateAdmin(admin, "state")
  444. if err != nil {
  445. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  446. return
  447. }
  448. e.OutSuc(c, "success", nil)
  449. return
  450. }
  451. // UpdateAdmin
  452. // @Summary 修改管理员信息
  453. // @Tags 权限管理
  454. // @Description 权限管理-修改管理员信息
  455. // @param Authorization header string true "验证参数Bearer和token空格拼接"
  456. // @Accept json
  457. // @Produce json
  458. // @Param args body md.UpdateAdminReq true "请求参数"
  459. // @Success 200 {string} "success"
  460. // @Failure 400 {object} md.Response "具体错误"
  461. // @Router /api/role/updateAdmin [POST]
  462. func UpdateAdmin(c *gin.Context) {
  463. var req md.UpdateAdminReq
  464. err := c.ShouldBindJSON(&req)
  465. if err != nil {
  466. err = validate.HandleValidateErr(err)
  467. err1 := err.(e.E)
  468. e.OutErr(c, err1.Code, err1.Error())
  469. return
  470. }
  471. engine := db.DBs[svc.GetMasterId(c)]
  472. admDb := implement.NewAdminDb(engine)
  473. admin, err := admDb.GetAdmin(req.AdmId)
  474. if err != nil {
  475. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  476. return
  477. }
  478. if admin == nil {
  479. e.OutErr(c, e.ERR_NO_DATA, "未查询到相应记录")
  480. return
  481. }
  482. admin.Username = req.Username
  483. admin.Memo = req.Memo
  484. admin.Password = utils.Md5(req.Password)
  485. _, err = admDb.UpdateAdmin(admin, "username", "memo", "password")
  486. if err != nil {
  487. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  488. return
  489. }
  490. e.OutSuc(c, "success", nil)
  491. return
  492. }
  493. // AddAdmin
  494. // @Summary 新增管理员
  495. // @Tags 权限管理
  496. // @Description 权限管理-新增管理员
  497. // @param Authorization header string true "验证参数Bearer和token空格拼接"
  498. // @Accept json
  499. // @Produce json
  500. // @Param args body md.AddAdminReq true "请求参数"
  501. // @Success 200 {string} "success"
  502. // @Failure 400 {object} md.Response "具体错误"
  503. // @Router /api/role/addAdmin [POST]
  504. func AddAdmin(c *gin.Context) {
  505. var req md.AddAdminReq
  506. err := c.ShouldBindJSON(&req)
  507. if err != nil {
  508. err = validate.HandleValidateErr(err)
  509. err1 := err.(e.E)
  510. e.OutErr(c, err1.Code, err1.Error())
  511. return
  512. }
  513. engine := db.DBs[svc.GetMasterId(c)]
  514. admDb := implement.NewAdminDb(engine)
  515. isHasAdmin, err := admDb.GetAdminByUserName(req.Username)
  516. if err != nil {
  517. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  518. return
  519. }
  520. if isHasAdmin != nil {
  521. e.OutErr(c, e.ERR, "当前用户名已存在,请勿重复添加")
  522. return
  523. }
  524. admId, err := admDb.CreateAdminId()
  525. if err != nil {
  526. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  527. return
  528. }
  529. admin := model.Admin{
  530. AdmId: admId,
  531. Username: req.Username,
  532. Password: utils.Md5(req.Password),
  533. State: enum.AdminStateForNormal,
  534. IsSuperAdministrator: 0,
  535. Memo: req.Memo,
  536. CreateAt: time.Now().Format("2006-01-02 15:04:05"),
  537. UpdateAt: time.Now().Format("2006-01-02 15:04:05"),
  538. }
  539. _, err = admDb.AdminInsert(&admin)
  540. if err != nil {
  541. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  542. return
  543. }
  544. e.OutSuc(c, "success", nil)
  545. return
  546. }
  547. // DeleteAdmin
  548. // @Summary 删除管理员
  549. // @Tags 权限管理
  550. // @Description 权限管理-删除管理员
  551. // @param Authorization header string true "验证参数Bearer和token空格拼接"
  552. // @Accept json
  553. // @Produce json
  554. // @Success 200 {string} "success"
  555. // @Failure 400 {object} md.Response "具体错误"
  556. // @Router /api/role/deleteAdmin/{$adm_id} [DELETE]
  557. func DeleteAdmin(c *gin.Context) {
  558. admId := c.Param("adm_id")
  559. err := svc.AdminDelete(c, []int{utils.StrToInt(admId)})
  560. if err != nil {
  561. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  562. return
  563. }
  564. e.OutSuc(c, "success", nil)
  565. return
  566. }
  567. // BindAdminRole
  568. // @Summary 管理员绑定角色
  569. // @Tags 权限管理
  570. // @Description 权限管理-管理员绑定角色
  571. // @param Authorization header string true "验证参数Bearer和token空格拼接"
  572. // @Accept json
  573. // @Produce json
  574. // @Param args body md.BindAdminRoleReq true "请求参数"
  575. // @Success 200 {string} "success"
  576. // @Failure 400 {object} md.Response "具体错误"
  577. // @Router /api/role/bindAdminRole/ [POST]
  578. func BindAdminRole(c *gin.Context) {
  579. var req md.BindAdminRoleReq
  580. err := c.ShouldBindJSON(&req)
  581. if err != nil {
  582. err = validate.HandleValidateErr(err)
  583. err1 := err.(e.E)
  584. e.OutErr(c, err1.Code, err1.Error())
  585. return
  586. }
  587. err = svc.BindAdminRole(c, req)
  588. if err != nil {
  589. e.OutErr(c, e.ERR, err.Error())
  590. return
  591. }
  592. e.OutSuc(c, "success", nil)
  593. return
  594. }
  595. // AdminInfo
  596. // @Summary 管理员信息
  597. // @Tags 权限管理
  598. // @Description 权限管理-管理员信息
  599. // @param Authorization header string true "验证参数Bearer和token空格拼接"
  600. // @Accept json
  601. // @Produce json
  602. // @param adm_id query string true "管理员id"
  603. // @Success 200 {string} "具体看返回内容"
  604. // @Failure 400 {object} md.Response "具体错误"
  605. // @Router /api/role/adminInfo [GET]
  606. func AdminInfo(c *gin.Context) {
  607. admId := c.DefaultQuery("adm_id", "")
  608. engine := db.DBs[svc.GetMasterId(c)]
  609. admDb := implement.NewAdminDb(engine)
  610. admin, err := admDb.GetAdmin(utils.StrToInt(admId))
  611. if err != nil {
  612. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  613. return
  614. }
  615. admin.Password = ""
  616. e.OutSuc(c, map[string]interface{}{
  617. "info": admin,
  618. "state": []map[string]interface{}{
  619. {
  620. "name": enum.RoleState(enum.RoleStateForNormal).String(),
  621. "value": enum.RoleStateForNormal,
  622. },
  623. {
  624. "name": enum.RoleState(enum.RoleStateForFreeze).String(),
  625. "value": enum.RoleStateForFreeze,
  626. },
  627. },
  628. }, nil)
  629. return
  630. }
  631. func RoleMediumList(c *gin.Context) {
  632. var req md.AdminBindMediumListReq
  633. err := c.ShouldBindJSON(&req)
  634. if err != nil {
  635. err = validate.HandleValidateErr(err)
  636. err1 := err.(e.E)
  637. e.OutErr(c, err1.Code, err1.Error())
  638. return
  639. }
  640. engine := svc.MasterDb(c)
  641. NewMediumDb := implement.NewMediumDb(engine)
  642. appId := svc.GetMediumIdStr(c, 0, req.Name, req.Account)
  643. list, total, _ := NewMediumDb.FindSuperAdminByMediumId(appId, utils.StrToInt(req.Page), utils.StrToInt(req.Limit))
  644. data := make([]md.AdminBindMediumListData, 0)
  645. if len(list) > 0 {
  646. for _, v := range list {
  647. var tmp = md.AdminBindMediumListData{
  648. MediumId: utils.IntToStr(v.MediumId),
  649. Name: v.Memo,
  650. IsBind: "0",
  651. Account: v.Username,
  652. }
  653. NewMediumListDb := implement2.NewMediumListDb(db.Db)
  654. GetMediumList, _ := NewMediumListDb.GetMediumList(v.MediumId)
  655. if GetMediumList != nil {
  656. tmp.Name = GetMediumList.CompanyName
  657. if GetMediumList.CompanyAbbreviation != "" {
  658. tmp.Name = GetMediumList.CompanyAbbreviation
  659. }
  660. }
  661. count, _ := engine.Where("medium_id=? and admin_id=?", v.MediumId, req.AdminId).Count(&model.AdminBindMedium{})
  662. if count > 0 {
  663. tmp.IsBind = "1"
  664. }
  665. data = append(data, tmp)
  666. }
  667. }
  668. res := md.AdminBindMediumListRes{
  669. List: data,
  670. Total: total,
  671. }
  672. e.OutSuc(c, res, nil)
  673. return
  674. }
  675. func RoleBindMedium(c *gin.Context) {
  676. var req md.AdminBindMediumListSaveReq
  677. err := c.ShouldBindJSON(&req)
  678. if err != nil {
  679. err = validate.HandleValidateErr(err)
  680. err1 := err.(e.E)
  681. e.OutErr(c, err1.Code, err1.Error())
  682. return
  683. }
  684. NewAdminBindMediumDb := implement.NewAdminBindMediumDb(svc.MasterDb(c))
  685. data := NewAdminBindMediumDb.GetAdminByMediumId(utils.StrToInt(req.AdminId), utils.StrToInt(req.MediumId))
  686. if data != nil {
  687. e.OutErr(c, 400, e.NewErr(400, "已绑定该媒体"))
  688. return
  689. }
  690. tmp := model.AdminBindMedium{
  691. AdminId: utils.StrToInt(req.AdminId),
  692. MediumId: utils.StrToInt(req.MediumId),
  693. CreateAt: time.Now(),
  694. UpdateAt: time.Now(),
  695. }
  696. svc.MasterDb(c).Insert(&tmp)
  697. e.OutSuc(c, "success", nil)
  698. return
  699. }
  700. func RoleDelMedium(c *gin.Context) {
  701. var req md.AdminBindMediumListSaveReq
  702. err := c.ShouldBindJSON(&req)
  703. if err != nil {
  704. err = validate.HandleValidateErr(err)
  705. err1 := err.(e.E)
  706. e.OutErr(c, err1.Code, err1.Error())
  707. return
  708. }
  709. svc.MasterDb(c).Where("medium_id=? and admin_id=?", req.MediumId, req.AdminId).Delete(&model.AdminBindMedium{})
  710. e.OutSuc(c, "success", nil)
  711. return
  712. }