美文网首页
casbin 应用实例

casbin 应用实例

作者: 吴宪峰 | 来源:发表于2019-07-17 22:32 被阅读0次

USER

package model

import (
    "fmt"
    "time"

    "github.com/insionng/zenpress/helper"

    "github.com/casbin/casbin"
)

// User 用户基本信息表。存放系统所有用户基本信息。
type User struct {
    ID                uint64    `gorm:"primary_key"`
    Token             string    //`orm:"unique"`
    UserLogin         string    `gorm:"not null default '' index VARCHAR(60)"`
    UserPass          string    `gorm:"not null default '' VARCHAR(255)"`
    UserNicename      string    `gorm:"not null default '' index VARCHAR(50)"`
    UserEmail         string    `gorm:"not null default '' index VARCHAR(100)"`
    UserURL           string    `gorm:"not null default '' VARCHAR(100)"`
    UserRegistered    time.Time `gorm:"not null default '0000-00-00 00:00:00' DATETIME"`
    UserActivationKey string    `gorm:"not null default '' VARCHAR(255)"`
    UserStatus        int       `gorm:"not null default 0 INT(11)"`
    DisplayName       string    `gorm:"not null default '' VARCHAR(250)"`
    Spam              int       `gorm:"not null default 0 TINYINT(2)"`
    Deleted           int       `gorm:"not null default 0 TINYINT(2)"`
    Roles             []Role    `gorm:"many2many:user_roles;"`
}

var Enforcer *casbin.Enforcer = nil

func getAttr(name string, attr string) string {
    if attr != "url" {
        return ""
    }

    permissions := FindPermissions()
    for _, permission := range permissions {
        if name == fmt.Sprintf("%v", permission.ID) {
            return permission.URL
        }
    }
    return ""
}

func getAttrFunc(args ...interface{}) (interface{}, error) {
    name := args[0].(string)
    attr := args[1].(string)

    return (string)(getAttr(name, attr)), nil
}

func Init() {
    Enforcer = &casbin.Enforcer{}
    Enforcer.InitWithFile("content/config/rbac_model.conf", "")
    Enforcer.AddActionAttributeFunction(getAttrFunc)

    type UserRoleResult struct {
        UserID uint64
        RoleID uint64
    }
    var res []UserRoleResult
    Database.Raw("select user_id, role_id from user_roles").Scan(&res)
    for _, param := range res {
        Enforcer.AddRoleForUser(fmt.Sprintf("%v", param.UserID), fmt.Sprintf("%v", param.RoleID))
    }

    type RolePermissionResult struct {
        RoleID       uint64
        PermissionID uint64
    }
    var rez []RolePermissionResult
    Database.Raw("select role_id, permission_id from role_permissions").Scan(&rez)
    for _, param := range rez {
        Enforcer.AddPermissionForUser(fmt.Sprintf("%v", param.RoleID), fmt.Sprintf("%v", param.PermissionID))
    }
}

func FindUserById(id int) (bool, User) {

    var user User
    db := Database.Where("id = ?", id).First(&user)
    return db.Error == nil, user
}

func FindUserByToken(token string) (bool, User) {

    var user User
    db := Database.Where("token = ?", token).First(&user)

    return db.Error == nil, user
}

func Login(username string, password string) (bool, User) {
    var user User
    db := Database.Where("username = ? and password = ?", username, password).First(&user)
    return db.Error == nil, user
}

func FindUserByUserName(username string) (bool, User) {

    var user User
    db := Database.Where("username = ?", username).First(&user)
    return db.Error == nil, user
}

func SaveUser(user *User) uint64 {
    Database.Create(user)
    return user.ID
}

func UpdateUser(user *User) {
    Database.Update(user)
}

func PageUser(p int, size int) helper.Page {

    var user User
    var list []User
    qs := Database.Find(&user)
    var count int
    qs.Count(count)
    qs.Related(&user).Order("user_registered").Limit(size).Offset((p - 1) * size).Find(&list)
    //c, _ := strconv.Atoi(strconv.FormatInt(count, 10))
    return helper.PageUtil(count, p, size, list)
}

func FindPermissionByUserIdAndPermissionName(userId int, name string) bool {
    permissions := FindPermissions()
    for _, permission := range permissions {
        if name == permission.Name {
            return Enforcer.Enforce(fmt.Sprintf("%v", userId), permission.URL)
        }
    }

    return false
}

func DeleteUser(user *User) {
    Enforcer.DeleteUser(fmt.Sprintf("%v", user.ID))
    Database.Delete(user)
}

func DeleteUserRolesByUserId(user_id int) {
    Enforcer.DeleteRolesForUser(fmt.Sprintf("%v", user_id))
    Database.Exec("delete from user_roles where user_id = ?", user_id)
}

func SaveUserRole(user_id int, role_id int) {
    Enforcer.AddRoleForUser(fmt.Sprintf("%v", user_id), fmt.Sprintf("%v", role_id))
    Database.Exec("insert into user_roles (user_id, role_id) values (?, ?)", user_id, role_id)
}

type UserRoleResult struct {
    ID     uint64
    UserID uint64
    RoleID uint64
}

func FindUserRolesByUserId(user_id int) []UserRoleResult {

    var res []UserRoleResult
    Database.Raw("select id, user_id, role_id from user_roles where user_id = ?", user_id).Scan(&res)
    return res
}

permission

package model

import (
    "fmt"
)

type Permission struct {
    ID               uint64 `gorm:"primary_key"`
    Pid              uint64
    URL              string
    Name             string
    Description      string
    Roles            []*Role
    ChildPermissions []*Permission `gorm:"-"`
}

func FindPermissionById(id int) Permission {
    var permission Permission
    Database.Where("id = ?", id).First(&permission)
    return permission
}

func FindPermissions() []*Permission {

    var permissions []*Permission
    Database.Find(&permissions)
    return permissions
}

func FindPermissionsByPid(pid int) []*Permission {
    var permissions []*Permission
    Database.Where("pid = ?", pid).Find(&permissions)
    return permissions
}

func SavePermission(permission *Permission) uint64 {
    Database.Create(permission)
    return permission.ID
}

func UpdatePermission(permission *Permission) uint64 {
    Database.Update(permission)
    return permission.ID
}

func DeletePermission(permission *Permission) {
    Enforcer.DeletePermission(fmt.Sprintf("%v", permission.ID))
    Database.Delete(permission)
}

func DeleteRolePermissionByPermissionId(permission_id int) {
    Enforcer.DeletePermission(fmt.Sprintf("%v", permission_id))
    Database.Exec("delete from role_permissions where permission_id = ?", permission_id)
}

roles

package model

import (
    "fmt"
    "strconv"
)

type Role struct {
    ID          uint64 `gorm:"primary_key"`
    Name        string // `orm:"unique"`
    Users       []*User
    Permissions []*Permission `gorm:"many2many:role_permissions;"`
}

func FindRoleById(id int) Role {
    var role Role
    Database.Where("id = ?", id).First(&role)
    return role
}

func FindRoles() []*Role {
    var roles []*Role
    Database.Find(&roles)
    return roles
}

func SaveRole(role *Role) uint64 {
    Database.Create(role)
    return role.ID
}

func UpdateRole(role *Role) {
    Database.Update(role, "name")
}

func DeleteRole(role *Role) {
    Enforcer.DeleteRole(fmt.Sprintf("%v", role.ID))
    Database.Delete(role)
}

func DeleteRolePermissionByRoleId(role_id int) {
    Enforcer.DeletePermissionsForUser(strconv.Itoa(role_id))
    Database.Exec("delete from role_permissions where role_id = ?", role_id)
}

func SaveRolePermission(role_id int, permission_id int) {
    Enforcer.AddPermissionForUser(fmt.Sprintf("%v", role_id), fmt.Sprintf("%v", permission_id))
    Database.Exec("insert into role_permissions (role_id, permission_id) values (?, ?)", role_id, permission_id)
}

type Result struct {
    ID           uint64
    RoleID       uint64
    PermissionID uint64
}

func FindRolePermissionByRoleId(role_id int) []Result {
    var res []Result
    Database.Raw("select id, role_id, permission_id from role_permissions where role_id = ?", role_id).Scan(&res)
    return res
}

相关文章

  • casbin 应用实例

    USER permission roles

  • iris集成Casbin-RBAC权限控制

    casbin手册请看官网:https://github.com/casbin/casbin[https://git...

  • Casbin在Web中的实例

    最近的项目需要设计一个比较复杂的权限系统,用到了casbin,简单做个使用说明。 1. 设计理念 casbin是一...

  • ThinkPHP5.1权限控制之Think-Casbin和状态管

    ThinkPHP5.1权限控制之Think-Casbin和状态管理PHP-JWT 简介 PHP-Casbin 是一...

  • Casbin

    Casbin是一个强大的、高效的开源访问控制框架,其权限管理机制支持多种访问控制模型 github: https:...

  • Casbin中ABAC的实现

    最近同事在研究Casbin的权限设计,我们主要是考虑使用ABAC基于属性的访问控制,Casbin给的示例不多,于是...

  • PHP-Casbin

    PHP-Casbin 基础知识 概述 Casbin是一个强大的、高效的开源访问控制框架,其权限管理机制支持多种访问...

  • Go语言 gin框架集成Casbin访问权限控制

    1. Casbin是什么? Casbin是一个强大的、高效的开源访问控制框架,其权限管理机制支持多种访问控制模型。...

  • 初学Basemap

    Basemap应用实例 —— Plotting data on a map(一) Basemap应用实例 —— P...

  • GO 权限管理之 Casbin

    GO 权限管理之 Casbin 我们来回顾一下上次分享的 GO中 gjson 库的应用和分享,它主要是提供了一种非...

网友评论

      本文标题:casbin 应用实例

      本文链接:https://www.haomeiwen.com/subject/tidhlctx.html