No description
Find a file
2025-05-10 21:10:52 +07:00
.github Create FUNDING.yml 2021-10-01 07:57:49 +07:00
src export ACL 2025-05-10 21:10:36 +07:00
tests first release 2019-07-25 22:30:13 +07:00
.gitignore Initial commit 2019-07-25 18:40:42 +07:00
LICENSE Initial commit 2019-07-25 18:40:42 +07:00
rbac.nimble Update rbac.nimble 2025-05-10 21:10:52 +07:00
README.md Update README.md 2019-07-25 22:31:20 +07:00

RBAC

Simple Role-based Access Control library

Usage

import rbac

type
  Role = enum
    Guest, User, Author, Editor, Administrator

  Subject = enum
    Posts, Users, Settings

  Permission = enum
    Read, Create, Edit, Delete, EditOthers, DeleteOthers, Manage


var acl = newAcl[Role, Subject, Permission]()
acl.addRoles(User, Guest)
acl.addRole(Author, @[User])
acl.addRole(Editor, @[Author])
acl.addRole(Administrator, @[Editor])

acl.addSubjects(Posts, Users, Settings)

acl.allow(User, Read, Posts)

acl.allow(Author, Create, Posts)
acl.allow(Author, Edit, Posts)
acl.allow(Author, Delete, Posts)

acl.allow(Editor, EditOthers, Posts)
acl.allow(Editor, DeleteOthers, Posts)

acl.allow(Administrator, Create, Users)
acl.allow(Administrator, Edit, Users)
acl.allow(Administrator, Delete, Users)

acl.allow(Administrator, Manage, Settings)

acl.deny(Guest, Read, Posts)

assert acl.isDenied(Guest, Read, Posts)

Please find in tests folder for more examples