| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337 |
- package auth_service
- import (
- "database/sql"
- "errors"
- "fmt"
- "gfast/app/model/auth_rule"
- "gfast/app/model/role"
- "gfast/app/model/user"
- "gfast/app/service/casbin_adapter_service"
- "gfast/library/utils"
- "github.com/gogf/gf/database/gdb"
- "github.com/gogf/gf/errors/gerror"
- "github.com/gogf/gf/frame/g"
- "github.com/gogf/gf/os/gtime"
- "github.com/gogf/gf/util/gconv"
- "github.com/gogf/gf/util/gvalid"
- )
- //菜单对象
- type MenuReq struct {
- IsMenu int `p:"ismenu" c:"ismenu" v:"min:0|max:1#菜单类型最小值为:min|菜单类型最大值为:max"`
- Pid int `p:"pid" c:"pid" v:"min:0"`
- Name string `p:"name" c:"name" v:"required#请填写规则名称"`
- Title string `p:"title" c:"title" v:"required|length:1,100#请填写标题|标题长度在:min到:max位"`
- Icon string `p:"icon" c:"icon"`
- Weigh int `p:"weigh" c:"weigh"`
- Condition string `p:"condition" c:"condition"`
- Remark string `p:"remark" c:"remark"`
- Status int `p:"status" c:"status"`
- }
- //获取菜单列表
- func GetMenuList(where string, params ...interface{}) (error, g.List) {
- var err error
- var list []*auth_rule.Entity
- if where != "" {
- list, err = auth_rule.Model.Where(where, params...).Order("weigh desc,id asc").FindAll()
- } else {
- list, err = auth_rule.Model.Order("weigh desc,id asc").FindAll()
- }
- if err != nil {
- g.Log().Error(err)
- return err, nil
- }
- var gList = make(g.List, len(list))
- for k, v := range list {
- tMap := gconv.Map(v)
- gList[k] = tMap
- }
- return nil, gList
- }
- // 添加菜单操作
- func AddMenu(req *MenuReq) (err error, insertId int64) {
- menuMap := gconv.Map(req)
- now := gtime.Timestamp()
- menuMap["createtime"] = now
- menuMap["updatetime"] = now
- res, e := auth_rule.Model.Insert(menuMap)
- err = e
- insertId, _ = res.LastInsertId()
- return
- }
- //修改菜单操作
- func EditMenu(req *MenuReq, id int) (err error, rows int64) {
- menuMap := gconv.Map(req)
- now := gtime.Timestamp()
- menuMap["updatetime"] = now
- res, e := auth_rule.Model.Where("id=?", id).Update(menuMap)
- err = e
- rows, _ = res.RowsAffected()
- return
- }
- //获取用户组列表
- func GetRoleList(where string, params ...interface{}) (err error, list g.List) {
- var rl []*role.Entity
- if where != "" {
- rl, err = role.Model.Where(where, params).OrderBy("list_order asc,id asc").All()
- } else {
- rl, err = role.Model.OrderBy("list_order asc,id asc").All()
- }
- if err != nil {
- g.Log().Error(err)
- return err, nil
- }
- list = make(g.List, len(rl))
- for k, v := range rl {
- tMap := gconv.Map(v)
- list[k] = tMap
- }
- return
- }
- //保存角色信息并返回插入的id
- func AddRole(tx *gdb.TX, data map[string]interface{}) (InsId int64, err error) {
- if e := checkRoleData(data); e != nil {
- err = gerror.New(e.(*gvalid.Error).FirstString())
- return
- }
- //保存角色信息
- now := gtime.Timestamp()
- roleMap := gdb.Map{
- "parent_id": data["parent_id"],
- "status": data["status"],
- "name": data["name"],
- "create_time": now,
- "update_time": now,
- "list_order": data["list_order"],
- "remark": data["remark"],
- }
- var res sql.Result
- res, err = tx.Table(role.Table).Data(roleMap).Save()
- if err != nil {
- return
- }
- InsId, _ = res.LastInsertId()
- return
- }
- //添加角色授权规则
- func AddRoleRule(iRule interface{}, roleId int64) (err error) {
- enforcer, e := casbin_adapter_service.GetEnforcer()
- if e != nil {
- err = e
- return
- }
- rule := iRule.([]interface{})
- for _, v := range rule {
- _, err = enforcer.AddPolicy(fmt.Sprintf("g_%d", roleId), fmt.Sprintf("r_%s", v), "All")
- if err != nil {
- return
- }
- }
- return
- }
- //修改角色信息操作
- func EditRole(tx *gdb.TX, data map[string]interface{}) (err error) {
- if _, k := data["id"]; !k {
- err = errors.New("缺少更新条件Id")
- return
- }
- if e := checkRoleData(data); e != nil {
- err = gerror.New(e.(*gvalid.Error).FirstString())
- return
- }
- //保存角色信息
- now := gtime.Timestamp()
- roleMap := gdb.Map{
- "id": data["id"],
- "parent_id": data["parent_id"],
- "status": data["status"],
- "name": data["name"],
- "update_time": now,
- "list_order": data["list_order"],
- "remark": data["remark"],
- }
- _, err = tx.Table(role.Table).Data(roleMap).Save()
- if err != nil {
- return
- }
- return
- }
- //修改角色的授权规则
- func EditRoleRule(iRule interface{}, roleId int64) (err error) {
- enforcer, e := casbin_adapter_service.GetEnforcer()
- if e != nil {
- err = e
- return
- }
- //查询当前权限
- gp := enforcer.GetFilteredNamedPolicy("p", 0, fmt.Sprintf("g_%d", roleId))
- //删除旧权限
- for _, v := range gp {
- _, e = enforcer.RemovePolicy(v)
- if e != nil {
- err = e
- return
- }
- }
- rule := iRule.([]interface{})
- for _, v := range rule {
- _, err = enforcer.AddPolicy(fmt.Sprintf("g_%d", roleId), fmt.Sprintf("r_%s", v), "All")
- if err != nil {
- return
- }
- }
- return
- }
- //删除角色权限操作
- func DeleteRoleRule(roleId int64) (err error) {
- enforcer, e := casbin_adapter_service.GetEnforcer()
- if e != nil {
- err = e
- return
- }
- //查询当前权限
- gp := enforcer.GetFilteredNamedPolicy("p", 0, fmt.Sprintf("g_%d", roleId))
- //删除旧权限
- for _, v := range gp {
- _, e = enforcer.RemovePolicy(v)
- if e != nil {
- err = e
- return
- }
- }
- return
- }
- func checkRoleData(params map[string]interface{}) error {
- rules := []string{
- "name@required|length:1,20#请填写角色名称|名称应在:min到:max个字符之间",
- "parent_id@integer|min:0#父级ID必须为整数|父级ID必须大于等于0",
- }
- e := gvalid.CheckMap(params, rules)
- if e != nil {
- return e
- }
- return nil
- }
- //添加管理员操作
- func AddUser(data map[string]interface{}) (InsertId int64, err error) {
- e := checkUserData(data, "add")
- if e != nil {
- err = gerror.New(e.(*gvalid.Error).FirstString())
- return
- }
- if i, _ := user.Model.Where("user_name=?", data["user_name"]).Count(); i != 0 {
- err = gerror.New("用户名已经存在")
- return
- }
- if i, _ := user.Model.Where("mobile=?", data["mobile"]).Count(); i != 0 {
- err = gerror.New("手机号已经存在")
- return
- }
- //保存管理员信息
- data["create_time"] = gtime.Timestamp()
- //密码加密
- data["user_password"] = utils.EncryptCBC(gconv.String(data["user_password"]), utils.AdminCbcPublicKey)
- res, err := user.Model.Filter().Data(data).Save()
- if err != nil {
- return
- }
- InsertId, _ = res.LastInsertId()
- return
- }
- //修改用户信息
- func EditUser(data map[string]interface{}) (err error) {
- e := checkUserData(data, "add")
- if e != nil {
- err = gerror.New(e.(*gvalid.Error).FirstString())
- return
- }
- if i, _ := user.Model.Where("id!=? and user_name=?", data["id"], data["user_name"]).Count(); i != 0 {
- err = gerror.New("用户名已经存在")
- return
- }
- if i, _ := user.Model.Where("id!=? and mobile=?", data["mobile"]).Count(); i != 0 {
- err = gerror.New("手机号已经存在")
- return
- }
- //保存管理员信息
- //提交了密码?密码加密
- if _, ok := data["user_password"]; ok {
- data["user_password"] = utils.EncryptCBC(gconv.String(data["user_password"]), utils.AdminCbcPublicKey)
- }
- _, err = user.Model.Filter().Data(data).Save()
- if err != nil {
- return
- }
- return
- }
- //添加用户角色信息
- func AddUserRole(roleIds interface{}, userId int64) (err error) {
- enforcer, e := casbin_adapter_service.GetEnforcer()
- if e != nil {
- err = e
- return
- }
- rule := roleIds.([]interface{})
- for _, v := range rule {
- _, err = enforcer.AddGroupingPolicy(fmt.Sprintf("u_%d", userId), fmt.Sprintf("g_%s", v))
- if err != nil {
- return
- }
- }
- return
- }
- //修改用户角色信息
- func EditUserRole(roleIds interface{}, userId int64) (err error) {
- enforcer, e := casbin_adapter_service.GetEnforcer()
- if e != nil {
- err = e
- return
- }
- rule := roleIds.([]interface{})
- //删除用户旧角色信息
- enforcer.RemoveFilteredGroupingPolicy(0, fmt.Sprintf("u_%d", userId))
- for _, v := range rule {
- _, err = enforcer.AddGroupingPolicy(fmt.Sprintf("u_%d", userId), fmt.Sprintf("g_%s", v))
- if err != nil {
- return
- }
- }
- return
- }
- //验证用户表单数据
- func checkUserData(params map[string]interface{}, t string) error {
- rules := []string{
- "id@integer|min:1#管理员id必须为整数|管理员Id必须大于0",
- "user_name@required|length:3,60#请填用户名|用户名应在:min到:max个字符之间",
- "mobile@telephone#手机号码格式不正确",
- "user_nickname@required|length:3,50#请填写姓名|姓名应在:min到:max个字符之间",
- "user_email@email#邮箱格式错误",
- }
- if t == "add" {
- rules = append(rules, "user_password@required|length:6,60#请填写密码|密码应在::min到:max个字符之间")
- } else {
- rules = append(rules, "user_password@length:6,60#密码应在::min到:max个字符之间")
- }
- e := gvalid.CheckMap(params, rules)
- if e != nil {
- return e
- }
- return nil
- }
|