Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/casbin/auth0-role-manager
Auth0 role manager for Casbin
https://github.com/casbin/auth0-role-manager
access-control auth auth0 auth0-api auth0-extend authorization casbin role-manager
Last synced: 3 months ago
JSON representation
Auth0 role manager for Casbin
- Host: GitHub
- URL: https://github.com/casbin/auth0-role-manager
- Owner: casbin
- License: apache-2.0
- Created: 2018-02-11T03:24:35.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2023-08-06T14:07:28.000Z (over 1 year ago)
- Last Synced: 2024-05-29T01:35:48.696Z (8 months ago)
- Topics: access-control, auth, auth0, auth0-api, auth0-extend, authorization, casbin, role-manager
- Language: Go
- Homepage: https://github.com/casbin/casbin
- Size: 10.7 KB
- Stars: 15
- Watchers: 4
- Forks: 9
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
Auth0 Role Manager [![Build Status](https://travis-ci.org/casbin/auth0-role-manager.svg?branch=master)](https://travis-ci.org/casbin/auth0-role-manager) [![Coverage Status](https://coveralls.io/repos/github/casbin/auth0-role-manager/badge.svg?branch=master)](https://coveralls.io/github/casbin/auth0-role-manager?branch=master) [![Godoc](https://godoc.org/github.com/casbin/auth0-role-manager?status.svg)](https://godoc.org/github.com/casbin/auth0-role-manager)
====Auth0 Role Manager is the [Auth0](https://auth0.com/) role manager for [Casbin](https://github.com/casbin/casbin). With this library, Casbin can load role hierarchy (user-role mapping) from [Auth0 Authorization Extension](https://auth0.com/docs/extensions/authorization-extension/v2) or save role hierarchy to it (NOT Implemented).
## Installation
go get github.com/casbin/auth0-role-manager
## Simple Example
```go
package mainimport (
"github.com/casbin/auth0-role-manager"
"github.com/casbin/casbin"
)func main() {
// This role manager dose not rely on Casbin policy. So we should not
// specify grouping policy ("g" policy rules) in the .csv file.
e := casbin.NewEnforcer("examples/rbac_model.conf", "examples/rbac_policy.csv")// Use our role manager.
// clientID is the Client ID.
// clientSecret is the Client Secret.
// tenant is your tenant name. If your domain is: abc.auth0.com, then abc is your tenant name.
// apiEndpoint is the base URL for your Auth0 Authorization Extension, it should
// be something like: "https://abc.us.webtask.io/adf6e2f2b84784b57522e3b19dfc9201", there is
// no "/admins", "/admins/login", "/users" or "/api" in the end.
rm := auth0rolemanager.NewRoleManager(
"your_client_id",
"your_client_secret",
"your_tenant_name",
"your_base_url_for_auth0_authorization_extension")
e.SetRoleManager(rm)// If our role manager relies on Casbin policy (like reading "g"
// policy rules), then we have to set the role manager before loading
// policy.
//
// Otherwise, we can set the role manager at any time, because role
// manager has nothing to do with the adapter.
e.LoadPolicy()
// Check the permission.
// Casbin's subject (user) name uses the Auth0 user's Email field (like "[email protected]").
// Casbin's role name uses the Auth0 group's Name field (like "Group1", "Group2").
e.Enforce("[email protected]", "data1", "read")
}
```## Getting Help
- [Casbin](https://github.com/casbin/casbin)
## License
This project is under Apache 2.0 License. See the [LICENSE](LICENSE) file for the full license text.