-
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
1 changed file
with
67 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,68 @@ | ||
# Authorizone | ||
Authorizone is an isomorphic authorization library for restricting resources by action, subjct and fields | ||
|
||
Authorizone is an isomorphic authorization library for restricting resources by action, subjct and fields. | ||
It's designed to be incrementally adoptable and can easily scale between a simple claim based and fully featured | ||
subject and action based authorization. It makes it easy to manage and share permissions across UI components, | ||
API services, and database queries. | ||
|
||
Inspired by [CASL](https://github.com/stalniy/casl) | ||
|
||
[data:image/s3,"s3://crabby-images/6c04b/6c04b90ed0a72317f115bdee567bae5054be5578" alt="Build Project"](https://github.com/loresoft/Authorizone/actions/workflows/dotnet.yml) | ||
|
||
[data:image/s3,"s3://crabby-images/3aaac/3aaacd328eeea2c7023bef658538bdd21e727d90" alt="Coverage Status"](https://coveralls.io/github/loresoft/Authorizone?branch=main) | ||
|
||
[data:image/s3,"s3://crabby-images/10abf/10abf0afbdefa3c3800541da65320ac7cb1e0ffe" alt="Authorizone"](https://www.nuget.org/packages/Authorizone/) | ||
|
||
## Features | ||
|
||
* **Versatile** An incrementally adoptable and can easily scale between a simple claim based and fully featured subject and attribute based authorization. | ||
* **Isomorphic** Can be used on frontend and backend and complementary packages make integration with Frontend and Backend effortless | ||
* **Declarative** Thanks to declarative rules, you can serialize and share permissions between UI and API or microservices | ||
|
||
## General | ||
|
||
Authorizone operates on rules for what a user can actually do in the application. A rule itself depends on the 3 parameters: | ||
|
||
1. **Action** Describes what user can actually do in the app. User action is a word (usually a verb) which depends on the business logic (e.g., `update`, `read`). Very often it will be a list of words from CRUD - `create`, `read`, `update` and `delete`. | ||
2. **Subject** The subject which you want to check user action on. Usually this is a business (or domain) entity name (e.g., `Subscription`, `Post`, `User`). | ||
3. **Fields** Can be used to restrict user action only to matched subject's fields (e.g., to allow moderator to update `published` field of `Post` but not update `description` or `title`) | ||
|
||
## Examples | ||
|
||
Using builder to create rules | ||
|
||
```c# | ||
var context = new AuthorizationBuilder() | ||
.Allow("test", AuthorizationSubjects.All) | ||
.Allow(AuthorizationActions.All, "Post") | ||
.Forbid("publish", "Post") | ||
.Build(); | ||
|
||
Assert.True(context.Authorized("read", "Post")); | ||
Assert.True(context.Authorized("update", "Post")); | ||
Assert.True(context.Authorized("archive", "Post")); | ||
Assert.False(context.Authorized(null, "Post")); | ||
Assert.False(context.Authorized("archive", null)); | ||
Assert.False(context.Authorized("read", "User")); | ||
Assert.True(context.Authorized("delete", "Post")); | ||
Assert.False(context.Authorized("publish", "Post")); | ||
Assert.True(context.Authorized("test", "User")); | ||
Assert.True(context.Authorized("test", "Post")); | ||
``` | ||
|
||
Using fields | ||
|
||
```c# | ||
var context = new AuthorizationBuilder() | ||
.Allow("read", "Post", ["title", "id"]) | ||
.Allow("read", "User") | ||
.Build(); | ||
|
||
Assert.True(context.Authorized("read", "Post")); | ||
Assert.True(context.Authorized("read", "Post", "id")); | ||
Assert.True(context.Authorized("read", "Post", "title")); | ||
Assert.False(context.Authorized("read", "Post", "ssn")); | ||
|
||
Assert.True(context.Authorized("read", "User")); | ||
Assert.True(context.Authorized("read", "User", "id")); | ||
``` |