mirror of
https://github.com/robonen/education-project.git
synced 2026-03-20 02:44:31 +00:00
Модуль Задания
This commit is contained in:
@@ -3,6 +3,7 @@
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use App\Models\AnswerToTask;
|
||||
use App\Models\BankTask;
|
||||
use Illuminate\Http\Request;
|
||||
use App\Models\Task;
|
||||
use Illuminate\Support\Facades\Auth;
|
||||
@@ -13,28 +14,41 @@ class AnswerToTaskController extends Controller
|
||||
{
|
||||
public function store(Task $task, Request $request) {
|
||||
$input = $request->all();
|
||||
$input->class_id = $task->class_id; // Не работает
|
||||
$input->student_id = Student::where('user_id', '=', Auth::id())->get(['id']); // Не работает
|
||||
|
||||
$answer = AnswerToTask::create($input);
|
||||
|
||||
$answer = AnswerToTask::create($input+ ['task_id' => $task->id,
|
||||
'student_id' => 1]);
|
||||
return response()->json($answer, 201);
|
||||
|
||||
}
|
||||
|
||||
public function show(Task $task, Student $student) {
|
||||
$name = BankTask::find($task->banktask_id)->name;
|
||||
|
||||
$answer = AnswerToTask::where([
|
||||
['student_id', '=', $student->id],
|
||||
['task_id', '=', $task->id]
|
||||
])->get();
|
||||
$file = TaskFile::where([
|
||||
['student_id', '=', $student->id],
|
||||
$answer->name = $name;
|
||||
$answer->deadline = $task->deadline;
|
||||
$studentFile = TaskFile::where([
|
||||
['user_id', '=', '2'], // Auth::id()
|
||||
['task_id', '=', $task->id]
|
||||
])
|
||||
->get(['id','name', 'type', 'url']);
|
||||
$teacherFile = TaskFile::where([
|
||||
['user_id', '=', '2'], // Auth::id()
|
||||
['task_id', '=', $task->id],
|
||||
['review', '=', 1]
|
||||
])
|
||||
->get(['id','name', 'type', 'url']);
|
||||
|
||||
return response()->json([
|
||||
'answer' => $answer,
|
||||
'files' => $file
|
||||
'files' => [
|
||||
'student' => $studentFile,
|
||||
'teacher' => $teacherFile
|
||||
]
|
||||
],200);
|
||||
}
|
||||
|
||||
|
||||
@@ -79,7 +79,6 @@ class BankTaskFileController extends Controller
|
||||
}
|
||||
|
||||
public function delete(BankTaskFile $file) {
|
||||
echo $file;
|
||||
if (Storage::disk('local')->exists('/public/banktask/' . $file->banktask_id . '/' . $file->type . '/' . $file->name )) {
|
||||
if (Storage::disk('local')->delete('/public/banktask/' . $file->banktask_id . '/' . $file->type . '/' . $file->name)) {
|
||||
return response()->json($file->delete());
|
||||
|
||||
@@ -18,7 +18,7 @@ class SubjectController extends Controller
|
||||
*/
|
||||
public function index()
|
||||
{
|
||||
return response()->json(Subject::all()->sortBy('name'), 200);
|
||||
return response()->json(Subject::all(), 200);
|
||||
}
|
||||
|
||||
/**
|
||||
|
||||
@@ -21,7 +21,7 @@ class ThemeController extends Controller
|
||||
*/
|
||||
public function index(Request $request)
|
||||
{
|
||||
return response()->json(Theme::all()->sortBy($request->input('sort_by')), 200);
|
||||
return response()->json(Theme::all(), 200);
|
||||
}
|
||||
|
||||
/**
|
||||
|
||||
@@ -3,8 +3,10 @@
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use App\Models\AnswerToTask;
|
||||
use App\Models\BankTask;
|
||||
use App\Models\SchoolClass;
|
||||
use App\Models\Student;
|
||||
use App\Models\User;
|
||||
use Illuminate\Http\Request;
|
||||
use App\Models\Task;
|
||||
use App\Http\Requests\TaskRequest;
|
||||
@@ -17,37 +19,60 @@ class TaskController extends Controller
|
||||
|
||||
{
|
||||
public function index(Request $request) {
|
||||
$tasks = Task::where('class_id', '=', $request->class_id)->get()->sortBy('deadline');
|
||||
$temp = [];
|
||||
foreach ($tasks as $task) {
|
||||
|
||||
return Task::where('class_id', '=', $request->class_id);
|
||||
$task->banktask->subject;
|
||||
array_push($temp, collect($task)->except(
|
||||
'banktask.id',
|
||||
'banktask.description',
|
||||
'banktask.short_description',
|
||||
'banktask.theme_id',
|
||||
'banktask.created_at',
|
||||
'banktask.updated_at',
|
||||
'banktask.author',
|
||||
'banktask.subject.created_at',
|
||||
'banktask.subject.updated_at',
|
||||
'banktask.subject_id'
|
||||
));
|
||||
|
||||
|
||||
}
|
||||
|
||||
return response()->json($temp , 200);
|
||||
}
|
||||
|
||||
public function store(TaskRequest $request) {
|
||||
$class = SchoolClass::find(1);
|
||||
$teacherId = 1; // Auth()->id();
|
||||
$newTask = $class->tasks()->create($request->all() + ['teacher_id' => $teacherId]);
|
||||
$banktaskName = BankTask::find($request->banktask_id)->name;
|
||||
$banktaskSubject = BankTask::find($request->banktask_id)->subject_id;
|
||||
$newTask = Task::create($request->all() + ['teacher_id' => $teacherId
|
||||
]);
|
||||
|
||||
|
||||
return response()->json($newTask, 201);
|
||||
}
|
||||
|
||||
public function addbanktask(Task $task, Request $request) {
|
||||
$temp = new TaskHistory();
|
||||
$temp->task_id = $task->id;
|
||||
$temp->banktask_id = $request->input('banktask_id'); // Баг - можно впихнуть 2 одинаковых задания из банка задач в один таск
|
||||
|
||||
$temp->save();
|
||||
|
||||
return response()->json($temp, 201);
|
||||
}
|
||||
// public function addbanktask(Task $task, Request $request) {
|
||||
// $temp = new TaskHistory();
|
||||
// $temp->task_id = $task->id;
|
||||
// $temp->banktask_id = $request->input('banktask_id'); // Баг - можно впихнуть 2 одинаковых задания из банка задач в один таск
|
||||
//
|
||||
// $temp->save();
|
||||
//
|
||||
// return response()->json($temp, 201);
|
||||
// }
|
||||
|
||||
public function show(Task $task) {
|
||||
$file = TaskFile::where([
|
||||
['task_id', '=', $task->id],
|
||||
['add_by_teacher', '=', '1']
|
||||
])->get(['id', 'name', 'type', 'url', 'user_id']);
|
||||
$userId = Teacher::find($task->teacher_id)->user_id;
|
||||
|
||||
$file = TaskFile::where('task_id', '=', $task->id)->get(['id', 'name', 'type', 'url', 'user_id']);
|
||||
return response()->json([
|
||||
'task' => $task,
|
||||
'files' => $file
|
||||
$task,
|
||||
'files' => $file,
|
||||
|
||||
|
||||
|
||||
], 200);
|
||||
}
|
||||
@@ -58,13 +83,11 @@ class TaskController extends Controller
|
||||
return response()->json(true, 200);
|
||||
}
|
||||
|
||||
public function update(Task $task, TaskRequest $request) {
|
||||
public function update(Task $task, Request $request) {
|
||||
$request->validate([
|
||||
'name' => 'required|min:5:max:100',
|
||||
'banktask_id' => 'required|exists:bank_tasks,id',
|
||||
]);
|
||||
$task->update($request->all());
|
||||
// $task->name = $request->input('name');
|
||||
// $task->description = $request->input('description');
|
||||
|
||||
|
||||
$task->save();
|
||||
@@ -80,8 +103,12 @@ class TaskController extends Controller
|
||||
$answer->comment_by_teacher = $request->input('comment_by_teacher');
|
||||
$answer->mark = $request->input('mark');
|
||||
$answer->checked = 1;
|
||||
|
||||
$answer->save();
|
||||
|
||||
|
||||
|
||||
|
||||
return response()->json($answer, 200);
|
||||
}
|
||||
|
||||
|
||||
@@ -18,7 +18,7 @@ class TaskFileController extends Controller
|
||||
{
|
||||
|
||||
$taskId = $task->id;
|
||||
$studentId = Student::where('user_id', '=', Auth::id())->get();
|
||||
$studentId = 1;
|
||||
$max_size = (int)ini_get('upload_max_filesize') * 1000;
|
||||
$all_ext = implode(',', $this->allExtensions());
|
||||
$this->validate($request, [
|
||||
@@ -30,41 +30,31 @@ class TaskFileController extends Controller
|
||||
$ext = $file->getClientOriginalExtension();
|
||||
$type = $this->getType($ext);
|
||||
|
||||
if(auth()->user()->role_id == 2) {
|
||||
if (Storage::putFileAs('public/task/' . $taskId . '/' . $type . '/', $file, $request->name)) {
|
||||
TaskFile::create(
|
||||
[
|
||||
'name' => $request->name,
|
||||
'type' => $type,
|
||||
'extension' => $ext,
|
||||
'task_id' => $taskId,
|
||||
'url' => '/storage/task' . '/' . $taskId . '/' . $type . '/' . $request->name,
|
||||
'user_id' => Auth::id(),
|
||||
'add_by_teacher' => 1,
|
||||
$file,
|
||||
$request->name . $ext
|
||||
]
|
||||
);
|
||||
return response()->json(true, 201);
|
||||
}
|
||||
} elseif (auth()->user()->role_id == 3) {
|
||||
if (Storage::putFileAs('public/task/' . $taskId . '/student/'. Auth::id() . $type . '/', $file, $request->name)) {
|
||||
TaskFile::create(
|
||||
[
|
||||
'name' => $request->name,
|
||||
'type' => $type,
|
||||
'extension' => $ext,
|
||||
'task_id' => $taskId,
|
||||
'url' => '/storage/task' . '/' . $taskId . '/student/'. Auth::id() . $type . '/' . $request->name,
|
||||
'user_id' => Auth::id(),
|
||||
$file,
|
||||
$request->name . $ext
|
||||
]
|
||||
);
|
||||
return response()->json(true, 201);
|
||||
}
|
||||
|
||||
if ($request->has('by_teacher') && $request->by_teacher == 1) { // auth()->user()->role_id == 2
|
||||
$path = '/storage/task' . '/' . $taskId . '/student/'. $studentId . '/' . '/review/' . $type . '/' . $request->name;
|
||||
$review = 1;
|
||||
} elseif (true) {
|
||||
$path = '/storage/task' . '/' . $taskId . '/student/'. $studentId . '/' . $type . '/' . $request->name;
|
||||
$review = 0;
|
||||
}
|
||||
|
||||
|
||||
if (Storage::putFileAs('public/task/' . $taskId . '/student/' . $studentId . '/' . $type . '/', $file, $request->name)) {
|
||||
TaskFile::create(
|
||||
[
|
||||
'name' => $request->name,
|
||||
'type' => $type,
|
||||
'extension' => $ext,
|
||||
'task_id' => $taskId,
|
||||
'url' => $path,
|
||||
'user_id' => '2',
|
||||
'review' => $review,
|
||||
$file,
|
||||
$request->name . $ext
|
||||
]
|
||||
);
|
||||
return response()->json(true, 201);
|
||||
}
|
||||
return response()->json(false, 422);
|
||||
}
|
||||
|
||||
@@ -78,10 +68,10 @@ class TaskFileController extends Controller
|
||||
|
||||
}
|
||||
|
||||
public function download(TaskFile $file)
|
||||
{
|
||||
return Storage::download('/public/task/' . $file->task_id . '/' . $file->type . '/' . $file->name);
|
||||
}
|
||||
// public function download(TaskFile $file)
|
||||
// {
|
||||
// return Storage::download('/public/task/' . $file->task_id . '/' . $file->type . '/' . $file->name);
|
||||
// }
|
||||
|
||||
// public function update(TaskFile $file, Request $request) Бесполезная функция
|
||||
// {
|
||||
@@ -104,8 +94,9 @@ class TaskFileController extends Controller
|
||||
// }
|
||||
|
||||
public function delete(TaskFile $file) {
|
||||
if (Storage::disk('local')->exists('/public/task/' . $file->task_id . '/' . $file->type . '/' . $file->name )) {
|
||||
if (Storage::disk('local')->delete('/public/task/' . $file->task_id . '/' . $file->type . '/' . $file->name)) {
|
||||
$studentId = Student::where('user_id', '=', $file->user_id)->get()->id;
|
||||
if (Storage::disk('local')->exists('/public/task/' . $file->task_id . '/student/' . $studentId . $file->type . '/' . $file->name)) {
|
||||
if (Storage::disk('local')->delete('/public/task/' . $file->task_id . '/student/' . $studentId . $file->type . '/' . $file->name)) {
|
||||
return response()->json($file->delete());
|
||||
}
|
||||
}
|
||||
|
||||
@@ -4,6 +4,7 @@ namespace App\Http\Controllers\Users;
|
||||
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Http\Requests\StudentRequest;
|
||||
use App\Models\AnswerToTask;
|
||||
use App\Models\SchoolClass;
|
||||
use App\Models\Student;
|
||||
use Illuminate\Http\JsonResponse;
|
||||
@@ -65,4 +66,8 @@ class StudentController extends Controller
|
||||
$new_class->save();
|
||||
return response()->json(collect($student)->except('school_class'), 200);
|
||||
}
|
||||
|
||||
public function getAnswers(Student $student) {
|
||||
return AnswerToTask::where('student_id', '=', $student->id)->get();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -15,12 +15,14 @@ class Kernel extends HttpKernel
|
||||
*/
|
||||
protected $middleware = [
|
||||
// \App\Http\Middleware\TrustHosts::class,
|
||||
\Fruitcake\Cors\HandleCors::class,
|
||||
\App\Http\Middleware\TrustProxies::class,
|
||||
\Fruitcake\Cors\HandleCors::class,
|
||||
\App\Http\Middleware\PreventRequestsDuringMaintenance::class,
|
||||
\Illuminate\Foundation\Http\Middleware\ValidatePostSize::class,
|
||||
\App\Http\Middleware\TrimStrings::class,
|
||||
\Illuminate\Foundation\Http\Middleware\ConvertEmptyStringsToNull::class,
|
||||
|
||||
];
|
||||
|
||||
/**
|
||||
|
||||
@@ -12,6 +12,6 @@ class VerifyCsrfToken extends Middleware
|
||||
* @var array
|
||||
*/
|
||||
protected $except = [
|
||||
//
|
||||
'api/*'
|
||||
];
|
||||
}
|
||||
|
||||
@@ -19,7 +19,8 @@ class TaskRequest extends ApiFormRequest
|
||||
public function rules()
|
||||
{
|
||||
return [
|
||||
'name' => 'required|max:255',
|
||||
'banktask_id' => 'required|exists:bank_tasks,id',
|
||||
'deadline' => 'required'
|
||||
|
||||
];
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user