first commit

This commit is contained in:
Noor E Ilahi
2026-01-09 12:54:53 +05:30
commit 7ccf44f7da
1070 changed files with 113036 additions and 0 deletions

View File

@@ -0,0 +1,36 @@
<?php
namespace App\Scopes;
use App\Enums\Role;
use App\Exceptions\Entities\AuthorizationException;
use Illuminate\Contracts\Database\Query\Builder;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Scope;
use Throwable;
class ProjectAccessScope implements Scope
{
/**
* @param Builder $builder
* @param Model $model
* @return Builder
* @throws Throwable
*/
public function apply(Builder $builder, Model $model): Builder
{
if (app()->runningInConsole()) {
return $builder;
}
$user = optional(request())->user();
throw_unless($user, new AuthorizationException);
if ($user->hasRole([Role::ADMIN, Role::MANAGER, Role::AUDITOR])) {
return $builder;
}
return $builder->whereHas('users', static fn(Builder $query) => $query->where('user_id', $user->id));
}
}

View File

@@ -0,0 +1,49 @@
<?php
namespace App\Scopes;
use App\Exceptions\Entities\AuthorizationException;
use App\Enums\Role;
use Illuminate\Contracts\Database\Query\Builder;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Scope;
use Throwable;
class TaskAccessScope implements Scope
{
/**
* @param Builder $builder
* @param Model $model
* @return Builder
* @throws Throwable
*/
public function apply(Builder $builder, Model $model): Builder
{
if (app()->runningInConsole()) {
return $builder;
}
$user = optional(request())->user();
throw_unless($user, new AuthorizationException);
if (!$user || $user->hasRole([Role::ADMIN, Role::MANAGER, Role::AUDITOR])) {
return $builder;
}
return $builder
// A user with the user project role sees only their own tasks
->whereHas('users', static fn(Builder $builder) => $builder->where('id', $user->id))
->orWhereHas('project.users', static fn(Builder $builder) => $builder
->where('user_id', $user->id)
->whereIn(
'projects_users.role_id',
[
Role::MANAGER->value,
Role::USER->value,
Role::AUDITOR->value,
],
))
->orderBy('created_at', 'desc');
}
}

View File

@@ -0,0 +1,43 @@
<?php
namespace App\Scopes;
use App\Enums\Role;
use App\Exceptions\Entities\AuthorizationException;
use Illuminate\Contracts\Database\Query\Builder;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Scope;
use Throwable;
class TimeIntervalAccessScope implements Scope
{
/**
* @param Builder $builder
* @param Model $model
* @return Builder|null
* @throws Throwable
*/
public function apply(Builder $builder, Model $model): ?Builder
{
if (app()->runningInConsole()) {
return $builder;
}
$user = optional(request())->user();
throw_unless($user, new AuthorizationException);
if ($user->hasRole([Role::ADMIN, Role::MANAGER, Role::AUDITOR])) {
return $builder;
}
return $builder
->where('time_intervals.user_id', $user->id)
->orWhereHas('task.project.users', static fn(Builder $builder) => $builder
->where('projects_users.user_id', $user->id)
->where('projects_users.role_id', Role::MANAGER->value))
->orWhereHas('task.project.users', static fn(Builder $builder) => $builder
->where('projects_users.user_id', $user->id)
->where('projects_users.role_id', Role::AUDITOR->value));
}
}

View File

@@ -0,0 +1,51 @@
<?php
namespace App\Scopes;
use App\Exceptions\Entities\AuthorizationException;
use App\Enums\Role;
use Illuminate\Contracts\Database\Query\Builder;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Scope;
use Throwable;
class UserAccessScope implements Scope
{
/**
* @param Builder $builder
* @param Model $model
* @return Builder|null
* @throws Throwable
*/
public function apply(Builder $builder, Model $model): ?Builder
{
if (!auth()->hasUser()) {
return null;
}
if (app()->runningInConsole()) {
return $builder;
}
$user = optional(request())->user();
throw_unless($user, new AuthorizationException);
if ($user->hasRole([Role::ADMIN, Role::MANAGER, Role::AUDITOR])) {
return $builder;
}
return $builder
->where('id', $user->id)
->orWhereHas('projectsRelation', static fn(Builder $builder) => $builder
->whereIn('project_id', static fn(Builder $builder) => $builder
->from('projects_users')
->select('project_id')
->where(static fn(Builder $builder) => $builder
->where('user_id', $user->id)
->where('role_id', Role::MANAGER->value))
->orWhere(static fn(Builder $builder) => $builder
->where('user_id', $user->id)
->where('role_id', Role::AUDITOR->value))));
}
}