https://github.com/concordnow/ember-casl
Ember addon for CASL which makes it easy to add permissions in any Ember application
https://github.com/concordnow/ember-casl
authorization casl ember ember-addon hacktoberfest
Last synced: 4 months ago
JSON representation
Ember addon for CASL which makes it easy to add permissions in any Ember application
- Host: GitHub
- URL: https://github.com/concordnow/ember-casl
- Owner: concordnow
- License: mit
- Created: 2021-07-06T09:20:46.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-09-11T01:20:15.000Z (about 2 years ago)
- Last Synced: 2025-07-07T08:11:38.102Z (4 months ago)
- Topics: authorization, casl, ember, ember-addon, hacktoberfest
- Language: JavaScript
- Homepage:
- Size: 5.7 MB
- Stars: 0
- Watchers: 4
- Forks: 0
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.md
- Codeowners: CODEOWNERS
Awesome Lists containing this project
README
ember-casl
==============================================================================[](https://github.com/concordnow/ember-casl/actions/workflows/main.yml)
[](https://emberobserver.com/addons/ember-casl)Ember addon for [CASL](https://github.com/stalniy/casl) which makes it easy to add permissions in any Ember application.
This package allows to integrate `@casl/ability` with [Ember](https://emberjs.com/) application.
It provides:
- Ability service that allows you to define CASL ability compatible with Ember tracked properties.
- Can/Cannot component that allow to hide or show UI elements based on user ability to see them.Compatibility
------------------------------------------------------------------------------* Ember.js v3.20 or above
* Ember CLI v3.20 or above
* Node.js v12 or above
* ember-auto-import v2.0 or aboveInstallation
------------------------------------------------------------------------------```
ember install ember-casl
```Usage
------------------------------------------------------------------------------### Ability Service
Define ability like regular Ember services by extending AbilityService.
```js
// services/post-ability.js
import { tracked } from '@glimmer/tracking';
import AbilityService from 'ember-casl/services/ability';export default class PostAbility extends AbilityService {
@tracked isWriter = false;get definition() {
return ({ can, cannot }) => {
can('read', 'post');
if (this.isWriter) {
can('write', 'post');
} else {
cannot('write', 'post').because("You're not a writer");
}
};
}
}
```The `definition` getter should return a function taking destructured [AbilityBuilder](https://casl.js.org/v5/en/api/casl-ability#ability-builder) as argument ([build](https://casl.js.org/v5/en/api/casl-ability#build) excluded).
It allows you to define very complex reactive ability (eg. Ability based on tracked property or another service).
Your newly created Ability service expose some fields
| Name | Type | Description |
| ----------------- | ------------ | -------------------------------------------------------------------------------------------------------------- |
| `ability` | CASL Ability | Original [CASL Ability](https://casl.js.org/v5/en/api/casl-ability#ability) |
| `can` | Method | Wrapper on [CASL Ability method can](https://casl.js.org/v5/en/api/casl-ability#can-of-pure-ability) |
| `cannot` | Method | Wrapper on [CASL Ability method cannot](https://casl.js.org/v5/en/api/casl-ability#cannot-of-pure-ability) |
| `relevantRuleFor` | Method | Wrapper on [CASL Ability method relevantRuleFor](https://casl.js.org/v5/en/api/casl-ability#relevant-rule-for) |Then you can use those abilities as regular services in your Ember application.
```js
// components/dummy.js
import Component from '@glimmer/component';
import { inject as service } from '@ember/service';export default class DummyComponent extends Component {
@service postAbility;get canRead() {
return this.postAbility.can('read', 'post');
}get cannotWriteReason() {
return this.postAbility.relevantRuleFor('write', 'post').reason;
}
}
```### Can / Cannot Helpers
You can use `can` & `cannot` helpers in your templates.
```hbs
{{#if (can 'read' 'post' service='post-ability')}}
You're a reader
{{/if}}
{{#if (cannot 'write' 'post' service='post-ability')}}
You're not a writer
{{/if}}
```Positional params are CASL Ability [can](https://casl.js.org/v5/en/api/casl-ability#can-of-pure-ability) / [cannot](https://casl.js.org/v5/en/api/casl-ability#cannot-of-pure-ability) arguments.
`service` is the name of the Ember service.Contributing
------------------------------------------------------------------------------See the [Contributing](CONTRIBUTING.md) guide for details.
License
------------------------------------------------------------------------------This project is licensed under the [MIT License](LICENSE.md).