Skip to content

Commit fa5c25b

Browse files
author
emreakay
committedOct 26, 2022
abac bismillah
1 parent 6fe18f3 commit fa5c25b

37 files changed

+239
-200
lines changed
 

‎README-abac.md

+1
Original file line numberDiff line numberDiff line change
@@ -17,6 +17,7 @@ backlog
1717

1818
- config e aranacak model klasörü eklenecek ?? AStart a mı eklemek lazım?
1919
- abac rule'u eloquent'a - dönüştüren builder ?? şimdilik scope içinden yapıldı
20+
- model'in rule'larını alan servis veya util ?
2021

2122
-----
2223

‎README.md

+38-14
Original file line numberDiff line numberDiff line change
@@ -5,23 +5,25 @@
55
[![GitHub Code Style Action Status](https://img.shields.io/github/workflow/status/aurorawebsoftware/aauth/Check%20&%20fix%20styling?label=code%20style)](https://github.com/aurorawebsoftware/aauth/actions?query=workflow%3A"Check+%26+fix+styling"+branch%3Amain)
66
[![Total Downloads](https://img.shields.io/packagist/dt/aurorawebsoftware/aauth.svg?style=flat-square)](https://packagist.org/packages/aurora/aauth)
77

8-
Hierarchical Rol-Permission Based **Laravel Auth Package** with Limitless Hierarchical Level of Organizations
8+
Organization Based (OrBAC) , Attibute Based (ABAC) , Rol-Permission (RBAC) Based Authentication Methods Combined **Laravel Auth Package** with Limitless Hierarchical Level of Organizations and Limitless Attribute Conditions
99

1010
# Features
1111

1212
- Organization Based Access Controllable (OrBAC) Eloquent Models
13+
- Attribute Based Access Controllable (ABAC) Eloquent Models
1314
- Role Based Access Control (RoBAC)
1415
- Permissions Based Access Control
1516
- Lean & Non-Complex Architecture
1617
- PolyMorphic Relationships of Model & Organization Node
18+
- DB Row Level Filtering for the Role with ABAC
1719
- Built-in Blade Directives for permission control inside **Blade** files
1820
- Mysql, MariaDB, Postgres Support
1921
- Community Driven and Open Source Forever
2022

2123
---
2224

2325

24-
[<img src="https://banners.beyondco.de/AAuth%20for%20Laravel.png?theme=light&packageManager=composer+require&packageName=aurorawebsoftware%2Faauth&pattern=jigsaw&style=style_1&description=Hierarchical+Role-Permission+Based+Laravel+Auth+Package+with+Limitless+Hierarchical+Level+of+Organizations&md=1&showWatermark=0&fontSize=175px&images=shield-check&widths=auto" />](https://github.com/AuroraWebSoftware/AAuth)
26+
[<img src="https://banners.beyondco.de/AAuth%20for%20Laravel.png?theme=light&packageManager=composer+require&packageName=aurorawebsoftware%2Faauth&pattern=jigsaw&style=style_1&description=OrBAC, ABAC, RBAC Combined Laravel Auth Package&md=1&showWatermark=0&fontSize=175px&images=shield-check&widths=auto" />](https://github.com/AuroraWebSoftware/AAuth)
2527

2628
# Installation
2729

@@ -88,7 +90,7 @@ return [
8890
];
8991
```
9092

91-
# Main Philosophy
93+
# Main Philosophy of AAuth OrBAC
9294

9395
In computer system security, there are several approaches to restrict system access to authorized users.
9496

@@ -139,6 +141,12 @@ Principal dynamically *without writing one line of code?*
139141
- Canada
140142
- .....
141143

144+
# Main Philosophy of AAuth ABAC
145+
146+
// todo coming soon ....
147+
148+
149+
---
142150
**AAuth may be your first class assistant package.**
143151

144152
---
@@ -187,6 +195,9 @@ file's permission['system'] array.
187195
an Organization Role.
188196
Organization Permissions should be added inside `aauth.php` config file's permission['organization'] array.
189197

198+
## ABAC
199+
// todo coming soon
200+
190201
## Role
191202

192203
Roles are assigned to users. Each User can have multiple roles.
@@ -226,6 +237,10 @@ be an organization node and can be access controllable.
226237
It means that; Only Authorized User Role can be access the relating model, or in other words, Each role only can access
227238
the models which is on Authenticated Sub-Organization Tree of User's Role.
228239

240+
### Model - ABAC rules
241+
// todo coming soon
242+
243+
229244
# Usage
230245

231246
Before using this, please make sure that you published the config files.
@@ -283,10 +298,10 @@ $organizationService->createOrganizationScope($data);
283298
```
284299

285300
### Updating an Organization Scope
286-
the contributors' space
301+
// todo help wanted
287302

288303
### Deleting an Organization Scope
289-
the contributors' space
304+
// todo help wanted
290305

291306

292307
### Creating an Organization Node without Model Relationship
@@ -304,10 +319,10 @@ $organizationService->createOrganizationNode($data);
304319
```
305320

306321
### Updating an Organization Node
307-
the contributors' space
322+
// todo help wanted
308323

309324
### Deleting an Organization Node
310-
the contributors' space
325+
// todo help wanted
311326

312327
## Role Permission Service
313328

@@ -341,10 +356,10 @@ $createdRole = $rolePermissionService->createRole($data);
341356
```
342357

343358
### Updating a Role
344-
...
359+
// todo help wanted
345360

346361
### Deleting a Role
347-
....
362+
// todo help wanted
348363

349364
### Attaching a Role to a User
350365
```php
@@ -389,7 +404,7 @@ $rolePermissionService->attachOrganizationRoleToUser($organizationNode->id, $cre
389404
```
390405

391406
### Creating a System Role and Attaching to a User
392-
....
407+
// todo help wanted
393408

394409

395410
## Using AAuth Interface and Trait with Eloquent Models
@@ -411,7 +426,11 @@ class ExampleModel extends Model implements AAuthOrganizationNodeInterface
411426
}
412427
```
413428

429+
## Using ABAC Interface and Trait with Eloquent Models
430+
// todo
431+
414432
## AAuth Service and Facade Methods
433+
// todo
415434

416435
### Current Roles All Permissions
417436
current user's selected roles permissions with **AAuth Facade**
@@ -444,8 +463,7 @@ $organizationNodes = AAuth::organizationNodes();
444463
```
445464

446465
### Get one specified organization node
447-
.....
448-
466+
// todo help wanted
449467

450468
### Descendant nodes can be checked
451469
with this method you can check is a organization node is descendant of another organization node.
@@ -469,16 +487,22 @@ $exampleModel = ExampleModel::find(1);
469487
$relatedOrganizationModel = $exampleModel->relatedAAuthOrganizationNode()
470488
```
471489

472-
## Getting allowed Organization Nodes Only.
490+
## Getting authorized Models only. (OrBAC)
473491

474492
after adding `AAuthOrganizationNode` trait to your model, you are adding a global scope which filters the permitted data.
475493

476-
Thus you can simply use any eloquent model method without adding anything
494+
Thus, you can simply use any eloquent model method without adding anything
477495

478496
```php
479497
ExampleModel::all();
480498
```
481499

500+
## Creating Role - ABAC Rules
501+
// todo
502+
503+
## Getting authorized Models only. (ABAC)
504+
// todo
505+
482506
## Getting All Model Collection without any access control
483507
```php
484508
ExampleModel::withoutGlobalScopes()->all()

‎Readme-todo.md

+7-5
Original file line numberDiff line numberDiff line change
@@ -2,10 +2,10 @@
22
- Facade yerine sadece service provide kullanılabilir mi? aliass?
33
- singleton içinde facade yerine service class olabilir
44
- phpStan problemleri
5-
- pint
5+
- pint, github actions
66
- can fonkisyonlarında yetki 1 kez çekilebilir
77
- Readme contribution
8-
8+
- ABAC
99

1010

1111
## Done
@@ -35,17 +35,19 @@
3535
- role perm. service validation ve excepiton unit testleri, validation excepitonarlını testti
3636
- org. service validation ve excepiton unit testleri, validation excepitonarlını testti
3737
- test with coverage
38-
- ABAC
3938
- translations
4039
- request's ve validations
41-
- github pages ?
4240
- test'lerin publish edilmesi ve namespacelerin replace edilmesi
4341
- postgress testleri için github actions
4442
- laravel gates register policy
4543

4644

4745
## Dökümantasyon
48-
4946
- config'ler
5047
- migr. ve seeder'ların çalıştırılması
5148
- github pages docs
49+
- ABAC docs
50+
51+
52+
## backlog
53+
- github pages ?

‎composer.json

+1
Original file line numberDiff line numberDiff line change
@@ -18,6 +18,7 @@
1818
"require": {
1919
"php": "^8.1",
2020
"illuminate/contracts": "^9.0",
21+
"laravel/pint": "^1.2",
2122
"spatie/laravel-package-tools": "^1.9.2"
2223
},
2324
"require-dev": {

‎config/aauth.php

+12-11
Original file line numberDiff line numberDiff line change
@@ -1,17 +1,18 @@
11
<?php
2+
23
// config for AuroraWebSoftware/AAuth
34
return [
45
'permissions' => [
5-
'system' => [
6-
// example system permission
7-
// key => translation
8-
'edit_something_for_system' => 'aauth/system.edit_something_for_system',
9-
'create_something_for_system' => 'aauth/system.create_something_for_system',
10-
],
11-
'organization' => [
12-
// example organization permission
13-
'edit_something_for_organization' => 'aauth/organization.edit_something_for_organization',
14-
'create_something_for_organization' => 'aauth/organization.create_something_for_organization',
15-
],
6+
'system' => [
7+
// example system permission
8+
// key => translation
9+
'edit_something_for_system' => 'aauth/system.edit_something_for_system',
10+
'create_something_for_system' => 'aauth/system.create_something_for_system',
1611
],
12+
'organization' => [
13+
// example organization permission
14+
'edit_something_for_organization' => 'aauth/organization.edit_something_for_organization',
15+
'create_something_for_organization' => 'aauth/organization.create_something_for_organization',
16+
],
17+
],
1718
];

‎database/migrations/2021_10_18_142336_seed_initial_data.php

+4-9
Original file line numberDiff line numberDiff line change
@@ -1,30 +1,26 @@
11
<?php
22

3-
43
use AuroraWebSoftware\AAuth\Models\OrganizationNode;
54
use AuroraWebSoftware\AAuth\Models\OrganizationScope;
65
use Illuminate\Database\Migrations\Migration;
76
use Illuminate\Support\Facades\DB;
87

98
class SeedInitialData extends Migration
109
{
11-
1210
/**
1311
* Run the migrations.
1412
*
1513
* @return void
1614
*/
17-
1815
public function up()
1916
{
2017
$organizationScope = new OrganizationScope();
2118
$organizationScope->id = 1;
22-
$organizationScope->name = "Root Scope";
19+
$organizationScope->name = 'Root Scope';
2320
$organizationScope->level = 1;
24-
$organizationScope->status = "active";
21+
$organizationScope->status = 'active';
2522
$organizationScope->save();
2623

27-
2824
if (config('database.default') == 'pgsql') {
2925
DB::select("
3026
SELECT setval(pg_get_serial_sequence('organization_scopes', 'id'), coalesce(max(id)+1, 1), false)
@@ -35,8 +31,8 @@ public function up()
3531
$on = new OrganizationNode();
3632
$on->id = 1;
3733
$on->organization_scope_id = 1;
38-
$on->name = "Root Node";
39-
$on->path = "1";
34+
$on->name = 'Root Node';
35+
$on->path = '1';
4036
$on->save();
4137

4238
if (config('database.default') == 'pgsql') {
@@ -52,7 +48,6 @@ public function up()
5248
*
5349
* @return void
5450
*/
55-
5651
public function down()
5752
{
5853
OrganizationScope::whereId(1)->delete();

‎database/seeders/SampleDataSeeder.php

+4-7
Original file line numberDiff line numberDiff line change
@@ -69,7 +69,7 @@ public function run()
6969
'parent_id' => $organizationNode1->id,
7070
]
7171
);
72-
$organizationNode2->path = $organizationNode1->id . '/' . $organizationNode2->id;
72+
$organizationNode2->path = $organizationNode1->id.'/'.$organizationNode2->id;
7373
$organizationNode2->save();
7474

7575
$organizationNode3 = OrganizationNode::create(
@@ -82,7 +82,7 @@ public function run()
8282
'parent_id' => $organizationNode1->id,
8383
]
8484
);
85-
$organizationNode3->path = $organizationNode1->id . '/' . $organizationNode3->id;
85+
$organizationNode3->path = $organizationNode1->id.'/'.$organizationNode3->id;
8686
$organizationNode3->save();
8787

8888
$organizationNode4 = OrganizationNode::create(
@@ -95,10 +95,9 @@ public function run()
9595
'parent_id' => $organizationNode2->id,
9696
]
9797
);
98-
$organizationNode4->path = $organizationNode2->path . '/' . $organizationNode4->id;
98+
$organizationNode4->path = $organizationNode2->path.'/'.$organizationNode4->id;
9999
$organizationNode4->save();
100100

101-
102101
$role1 = Role::create([
103102
'type' => 'system',
104103
'name' => 'System Role 1',
@@ -174,7 +173,6 @@ public function run()
174173
'organization_node_id' => $organizationNode4->id,
175174
]);
176175

177-
178176
$systemPermissions = config('aauth.permissions.system');
179177

180178
foreach ($systemPermissions as $key => $val) {
@@ -236,14 +234,13 @@ public function run()
236234

237235
//loop through the tables
238236
foreach ($tables as $table) {
239-
240237
// if the table is not to be ignored then:
241238
if (! in_array($table->table_name, $ignores)) {
242239
//Get the max id from that table and add 1 to it
243240
$seq = DB::table($table->table_name)->max('id') + 1;
244241

245242
// alter the sequence to now RESTART WITH the new sequence index from above
246-
DB::select('ALTER SEQUENCE ' . $table->table_name . '_id_seq RESTART WITH ' . $seq);
243+
DB::select('ALTER SEQUENCE '.$table->table_name.'_id_seq RESTART WITH '.$seq);
247244
}
248245
}
249246
}

0 commit comments

Comments
 (0)
Please sign in to comment.