- Move 12 markdown files from root to docs/ subdirectories - Organize documentation by category: • docs/troubleshooting/ (1 file) - Technical troubleshooting guides • docs/deployment/ (4 files) - Deployment and security documentation • docs/guides/ (3 files) - Feature-specific guides • docs/planning/ (4 files) - Planning and improvement proposals Root directory cleanup: - Reduced from 16 to 4 markdown files in root - Only essential project files remain: • CLAUDE.md (AI instructions) • README.md (Main project readme) • CLEANUP_PLAN.md (Current cleanup plan) • SRC_STRUCTURE_IMPROVEMENTS.md (Structure improvements) This improves: ✅ Documentation discoverability ✅ Logical organization by purpose ✅ Clean root directory ✅ Better maintainability
20 lines
574 B
PHP
20 lines
574 B
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace App\Framework\Console\Security\Attributes;
|
|
|
|
enum PermissionMode: string
|
|
{
|
|
case ANY = 'any'; // User needs ANY of the specified permissions
|
|
case ALL = 'all'; // User needs ALL of the specified permissions
|
|
|
|
public function check(array $userPermissions, array $requiredPermissions): bool
|
|
{
|
|
return match ($this) {
|
|
self::ANY => ! empty(array_intersect($userPermissions, $requiredPermissions)),
|
|
self::ALL => empty(array_diff($requiredPermissions, $userPermissions))
|
|
};
|
|
}
|
|
}
|