لینکهای مفید برای شرکت در مسابقه:
در زمان مسابقه میتوانید سوالهای خود را از قسمت "سوال بپرسید" مطرح کنید.
دو سری راهنمایی برای سوالات اضافه شده است.
محدود کردن دسترسی بر اساس نقش (Role Based Access Control) نوعی مدیریت دسترسی است که در آن هر کاربر دارای یک نقش (Role) بوده و هر نقش دارای یک مجموعه دسترسی است. در این سؤال قرار است این سیستم را پیادهسازی کنید.
پروژهی اولیه را از این لینک دانلود کنید. ساختار فایلهای این پروژه بهصورت زیر است:
برای اجرای پروژه، باید php
و composer
را از قبل نصب کرده باشید.
composer install
را در پوشهی اصلی پروژه برای نصب نیازمندیها اجرا کنید.مدلها در پروژه اولیه داده شده است. همچنین میتوانید با اجرای دستور php artisan migrate
مایگریشنها را اجرا کرده و پایگاه داده را به طور کامل داشته باشید. در این پروژه از پایگاه دادهی SQLite استفاده شده است. در ادامه، لیست مدلها و توضیحات آمده است:
User
: مدل کاربر که دارای فیلدهای name
، email
و password
است؛ فیلدهای name
و password
را میتوانید دلخواه مقدار دهید.
Role
: مدل نقش که دارای فیلد name
است
Permission
: مدل دسترسی که دارای فیلد name
است
علاوه بر این مدلها، دو جدول permission_role
و role_user
نیز وجود دارند که جدولهای رابطه هستند.
شما باید متدهای زیر را در کلاس RBACController
پیادهسازی کنید:
createRole($name)
: این متد با ورودی گرفتن نام نقش آن را اضافه میکند.
addPermissionToRole($class, $function, $role)
: این متد با گرفتن نام کلاس، نام متد و نام نقش، اجازه دسترسی یک نقش به یک متد از یک کلاس را میدهد.
addUser($email)
: این متد یک کاربر با ایمیل داده شده را ایجاد میکند.
addRoleToUser($role, $email)
: این متد با با دریافت نام نقش و ایمیل کاربر، آن نقش را به کاربر مورد نظر میدهد. هر کاربر میتواند چند نقش داشته باشد.
برنامهی شما به این صورت داوری میشود که کلاسی با ارثبری از کنترلر اصلی لاراول (App\Http\Controllers\Controller
) به کد شما اضافه میشود. شما باید چهار متد create
، update
، store
و edit
را در کلاس Controller
طوری پیادهسازی کنید که بهترتیب چهار دسترسی create
، update
، store
و edit
برای کلاسی که از Controller
ارثبری کرده است را بررسی کند. در صورتی که برای کاربر لاگینشده دسترسی موردنظر وجود نداشته باشد، متد موجود در Controller
باید عدد 403
را برگرداند (return 403;
). در غیر اینصورت، این متدها نباید مقداری را برگردانند. تضمین میشود که هنگام تست این متدها، کاربر در سایت لاگین کرده است (با استفاده از Auth::user()
میتوانید اطلاعات کاربر را دریافت کنید).
توجه: شما تنها مجاز به تغییر فایلهای موجود در پوشهی /app
هستید.
پس از اعمال تغییرات، کل پروژه به غیر از پوشهی vendor
را Zip کرده و آپلود کنید. نام فایل Zip اهمیتی ندارد.
در این قسمت راهنماییهای سوال، به مرور اضافه میشود. مشکلاتتان در راستای حل سوال را میتوانید از بخش "سوال بپرسید" مطرح کنید.
برای پیادهسازی متد createRole
، میتوان از متد create
در مدل Role
استفاده کرد. متد addUser
نیز مشابه این متد پیادهسازی میشود:
برای پیادهسازی متد addRoleToUser
، میتوان ابتدا Role
متناظر با نام ورودی و User
متناظر با ایمیل ورودی را دریافت کرد و سپس Role
را به User
attach کرد:
برای پیادهسازی متد addPermissionToRole
، یک روش برای ذخیرهسازی نام کلاس و نام متد در فیلد name
دسترسی، جداسازی آنها با استفاده از یک کاراکتر space است:
برای پیادهسازی متد create
در کلاس Controller
، باید ابتدا Role
های کاربر و سپس Permission
های متناظر با Role
ها را دریافت کرد. نام کلاسی که این متد را صدا میزند با استفاده از کلاس ReflectionClass
یا get_called_class
قابل دریافت است. در صورتی که دسترسی موردنظر وجود نداشته باشد، باید عدد 403
را برگرداند.
برای جلوگیری از مشکل ، میتوان از join
استفاده کرد:
سایر متدهای کلاس Controller
نیز مشابه متد create
پیادهسازی میشوند.