File size: 2,526 Bytes
cdaa4db
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
class Authorization {
    constructor() {
        this.roles = {
            'student': 1,
            'instructor': 2,
            'admin': 3
        };
    }

    getCurrentUserRole() {
        const currentUser = authManager.getCurrentUser();
        return currentUser ? currentUser.role : 'guest';
    }

    hasRole(requiredRole) {
        const currentRole = this.getCurrentUserRole();
        return this.roles[currentRole] >= this.roles[requiredRole];
    }

    hasAnyRole(requiredRoles) {
        const currentRole = this.getCurrentUserRole();
        return requiredRoles.includes(currentRole);
    }

    requireRole(requiredRole) {
        return (callback) => {
            if (this.hasRole(requiredRole)) {
                return callback();
            } else {
                this.showAccessDenied();
                return false;
            }
        };
    }

    requireAuth(callback) {
        return () => {
            if (authManager.isAuthenticated()) {
                return callback();
            } else {
                this.showLoginRequired();
                return false;
            }
        };
    }

    showAccessDenied() {
        alert('دسترسی denied. شما permission لازم برای این بخش را ندارید.');
    }

    showLoginRequired() {
        alert('لطفاً برای دسترسی به این بخش وارد شوید.');
        // در برنامه واقعی، کاربر به صفحه ورود هدایت می‌شود
        window.location.hash = '#/login';
    }

    // بررسی دسترسی به منابع
    canAccessLesson(lessonId) {
        const currentUser = authManager.getCurrentUser();
        if (!currentUser) return false;
        
        // در اینجا می‌توان منطق پیچیده‌تری برای دسترسی به درس‌ها پیاده‌سازی کرد
        return true;
    }

    canEditContent() {
        return this.hasAnyRole(['instructor', 'admin']);
    }

    canManageUsers() {
        return this.hasRole('admin');
    }
}

// دکوراتورهای سریع
const requireStudent = (callback) => new Authorization().requireRole('student')(callback);
const requireInstructor = (callback) => new Authorization().requireRole('instructor')(callback);
const requireAdmin = (callback) => new Authorization().requireRole('admin')(callback);
const requireAuth = (callback) => new Authorization().requireAuth(callback);

// ایجاد نمونه singleton
const authzManager = new Authorization();