در این سوال قصد داریم سیستم برگزاری آزمون آنلاین، (چیزی شبیه به Quera) طراحی کنیم.
این سیستم تنها قابلیت برگزاری یک آزمون را دارد و سوالات آزمون کوتاهپاسخ اند.
- لیست سوالات آزمون
- لیست ارسالها
- جدول امتیازات
- داوری ارسالها
# پروژه اولیه
پروژه اولیه را از
[اینجا](http://bayanbox.ir/download/2261348370094388608/contest-initial.zip)
دانلود کنید. ساختار فایلهای این پروژه به صورت زیر است:
```
contest_initial
├─ app
│ ├─ Console
│ │ └─ Kernel.php
│ ├─ Database
│ │ ├─ Problem.php
│ │ ├─ Submission.php
│ │ └─ User.php
│ ├─ Exceptions
│ │ └─ Handler.php
│ ├─ Http
│ │ ├─ Controllers
│ │ │ ├─ Auth
│ │ │ │ ├─ ForgotPasswordController.php
│ │ │ │ ├─ LoginController.php
│ │ │ │ ├─ RegisterController.php
│ │ │ │ ├─ ResetPasswordController.php
│ │ │ │ └─ VerificationController.php
│ │ │ ├─ Controller.php
│ │ │ ├─ ProblemController.php
│ │ │ ├─ ScoreboardController.php
│ │ │ └─ SubmissionController.php
│ │ ├─ Middleware
│ │ │ ├─ Authenticate.php
│ │ │ ├─ CheckForMaintenanceMode.php
│ │ │ ├─ EncryptCookies.php
│ │ │ ├─ RedirectIfAuthenticated.php
│ │ │ ├─ TrimStrings.php
│ │ │ ├─ TrustProxies.php
│ │ │ └─ VerifyCsrfToken.php
│ │ └─ Kernel.php
│ └─ Providers
│ ├─ AppServiceProvider.php
│ ├─ AuthServiceProvider.php
│ ├─ BroadcastServiceProvider.php
│ ├─ EventServiceProvider.php
│ └─ RouteServiceProvider.php
├─ bootstrap
│ ├─ cache
│ └─ app.php
├─ config
│ ├─ app.php
│ ├─ auth.php
│ ├─ broadcasting.php
│ ├─ cache.php
│ ├─ database.php
│ ├─ filesystems.php
│ ├─ hashing.php
│ ├─ logging.php
│ ├─ mail.php
│ ├─ queue.php
│ ├─ services.php
│ ├─ session.php
│ └─ view.php
├─ database
│ ├─ factories
│ │ └─ UserFactory.php
│ ├─ migrations
│ │ ├─ 2014_10_12_000000_create_users_table.php
│ │ ├─ 2014_10_12_100000_create_password_resets_table.php
│ │ └─ 2018_10_17_214246_contest.php
│ └─ seeds
│ └─ DatabaseSeeder.php
├─ public
│ ├─ css
│ │ └─ app.css
│ ├─ js
│ │ └─ app.js
│ ├─ svg
│ │ ├─ 403.svg
│ │ ├─ 404.svg
│ │ ├─ 500.svg
│ │ └─ 503.svg
│ ├─ .htaccess
│ ├─ favicon.ico
│ ├─ index.php
│ └─ robots.txt
├─ resources
│ ├─ js
│ │ ├─ components
│ │ │ └─ ExampleComponent.vue
│ │ ├─ app.js
│ │ └─ bootstrap.js
│ ├─ lang
│ │ └─ en
│ │ ├─ auth.php
│ │ ├─ pagination.php
│ │ ├─ passwords.php
│ │ └─ validation.php
│ ├─ sass
│ │ ├─ _variables.scss
│ │ └─ app.scss
│ └─ views
│ ├─ auth
│ │ ├─ passwords
│ │ │ ├─ email.blade.php
│ │ │ └─ reset.blade.php
│ │ ├─ login.blade.php
│ │ ├─ register.blade.php
│ │ └─ verify.blade.php
│ ├─ layouts
│ │ └─ app.blade.php
│ ├─ problem.blade.php
│ ├─ problems.blade.php
│ ├─ scoreboard.blade.php
│ └─ submissions.blade.php
├─ routes
│ ├─ api.php
│ ├─ channels.php
│ ├─ console.php
│ └─ web.php
├─ storage
│ ├─ app
│ ├─ framework
│ │ ├─ cache
│ │ ├─ sessions
│ │ ├─ testing
│ │ └─ views
│ └─ logs
├─ tests
│ ├─ Feature
│ │ └─ Example1Test.php
│ ├─ CreatesApplication.php
│ └─ TestCase.php
├─ .editorconfig
├─ .env
├─ .env.example
├─ .gitattributes
├─ artisan
├─ composer.json
├─ composer.lock
├─ package.json
├─ phpunit.xml
├─ server.php
└─ webpack.mix.js
```
# جزئیات
جدولهای پایگاه داده به شرح زیر است:
### users
این جدول شامل اطلاعات کاربران است که در فیلدهای زیر ذخیره شده اند :
- id: شناسهی کاربر
- name: نام نمایشی کاربر
- email: ایمیل کاربر
- password: رمز کاربر
### problems
این جدول شامل اطلاعات پرسشها است که در فیلدهای زیر ذخیره شده اند :
- id: شناسهی پرسش
- subject: عنوان پرسش
- content: محتوای پرسش
### submissions
این جدول شامل اطلاعات ارسالها است که در فیلدهای زیر ذخیره شده اند :
- id: شناسهی ارسال
- user_id: شناسهی کاربر ارسالکنندهی پاسخ
- problem_id: شناسهی سوالی که ارسال برای آن انجام شدهاست.
- answer: پاسخ ارسالی
- status: وضعیت پاسخ
- 0: به معنی داوری نشده
- 1: به معنی داوری شده و درست
- 2: به معنی داوری شده و غلط
- submitted_at: زمانی که پاسخ ارسال شدهاست
بخشهایی از این سیستم پیادهسازی شدهاست و شما کافی است بخشهای زیر را پیادهسازی کنید:
### پرسشها
در صفحهی نخست سایت بخشی برای ورود به سایت و بخشی برای نمایش لیست پرسشهای مسابقه باشد.
### صفحهی پرسش
کاربر با کلیک بر روی هر یک از پرسشها به صفحهی پرسش برود که صفحهی پرسش دو قسمت دارد.
1. بخش نمایش پرسش که عنوان و متن پرسش را نشان بدهد.
2. بخش ارسال پاسخ، در صورتی که کاربر وارد سایت شدهبود، باید فرمی برای ارسال پاسخ به او نشان دادهشود.
### بخش ارسال پاسخ
در صورتی که کاربر وارد سایت شده بود پاسخ او به عنوان یک sumbission داوری نشده ثبت شود و به صفحهی ارسالها منتقل شود و در غیر اینصورت خطای ۴۰۳ بدهد.
### صفحهی ارسالها
در صورتی که کاربری وارد سایت شدهبود در این بخش تمام ارسالهای انجام شده توسط خودش را ببیند در غیر اینصورت خطای ۴۰۳ بدهد.
### رتبهبندی
در این صفحه لیست رتبهبندی تمام کاربران شامل رتبهی آنها، پنالتی گرفته شده و تعداد پرسشهای حل شدهی هر کاربر نمایش داده می شود.
منظور از پنالتی یک کاربر مجموع پنالتی پرسشهایی که کاربر توانسته در انتها به آنها پاسخ بدهد است.
پنالتی یک پرسش حلشده مثل $p$ برای کاربری مثل $u$ برابر با زمان ثبت اولین ارسال درست برای آن پرسش توسط $u$ از زمان شروع مسابقه به دقیقه، بهاضافهی بیست برابر تعداد ارسالهای غلط ثبتشده توسط $u$ برای پرسش $p$ قبل از زمان ارسال اولین پاسخ صحیح توسط $u$ برای پرسش $p$ است.
نفر $a$ از نفر $b$ رتبه بهتری دارد اگر تعداد پرسشهای حلشده توسط $a$ از $b$ بیشتر باشد و در صورت برابری تعداد پرسشهای حلشده، پنالتی کمتری داشتهباشد.
دقت کنید که زمان شروع کانتست داخل فایل `.env` تنظیم شدهاست و تمام کاربران (چه ارسالی داشتهاند یا نداشتهاند) در رتبهبندی میآیند.
### داوری
با دستور `php artisan judge` باید داوری اجرا شود.
اولین ارسال داوری نشده به ترتیب زمان ارسال را برای داوری انتخاب میکند. سپس در صورت وجود ارسال، اطلاعاتی به شکل زیر نمایش میدهد:
```
Problem ID: {problem_id}
Answer: {answer}
```
که `{problem_id}` شناسهی سوالی است که ارسال برای آن انجام شده و `{answer}` پاسخ ارسالی است.
سپس یک سوال با محتوا `Is it OK?` میپرسد که در صورتی که `yes` وارد شود ارسال به عنوان پاسخ صحیح علامتگذاری و در غیر اینصورت به عنوان پاسخ غلط علامتگذاری میشود.
# نکات
- شما مجاز به تغییر همهی فایلهای داخل پوشهی `app/` هستید.
- حق تغییر در ساختار اصلی مدلها را ندارید اما میتوانید فیلدها و ریلیشنهای دلخواهتان را به آن اضافه کنید.
- از `view`ها برای فهمیدن آنچه باید بنویسید کمک بگیرید.
- پس از اعمال تغییرات کل پروژه به غیر از پوشهی `vendor` را _Zip_ کرده و ارسال کنید.
- نام فایل Zip اهمیتی ندارد.