staffmanager/app/Http/Controllers/ApplicationController.php

245 lines
8.8 KiB
PHP
Raw Normal View History

<?php
2020-10-10 16:30:26 +00:00
/*
* Copyright © 2020 Miguel Nogueira
*
* This file is part of Raspberry Staff Manager.
*
* Raspberry Staff Manager is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Raspberry Staff Manager is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Raspberry Staff Manager. If not, see <https://www.gnu.org/licenses/>.
*/
namespace App\Http\Controllers;
use App\Application;
use App\Events\ApplicationDeniedEvent;
use App\Notifications\ApplicationMoved;
2020-10-10 16:30:26 +00:00
use App\Notifications\NewApplicant;
use App\Response;
use App\User;
use App\Vacancy;
use ContextAwareValidator;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Log;
class ApplicationController extends Controller
{
private function canVote($votes)
{
$allvotes = collect([]);
2020-10-10 16:30:26 +00:00
foreach ($votes as $vote) {
if ($vote->userID == Auth::user()->id) {
$allvotes->push($vote);
}
}
return ($allvotes->count() == 1) ? false : true;
}
2020-05-11 15:44:47 +00:00
public function showUserApps()
{
2020-05-11 15:44:47 +00:00
return view('dashboard.user.applications')
->with('applications', Auth::user()->applications);
}
public function showUserApp(Request $request, Application $application)
{
$this->authorize('view', $application);
2020-10-10 16:30:26 +00:00
if (! is_null($application)) {
return view('dashboard.user.viewapp')
->with(
[
'application' => $application,
'comments' => $application->comments,
'structuredResponses' => json_decode($application->response->responseData, true),
'formStructure' => $application->response->form,
'vacancy' => $application->response->vacancy,
2020-10-10 16:30:26 +00:00
'canVote' => $this->canVote($application->votes),
]
);
2020-10-10 16:30:26 +00:00
} else {
$request->session()->flash('error', 'The application you requested could not be found.');
}
return redirect()->back();
}
2020-07-11 01:43:59 +00:00
public function showAllApps()
{
$this->authorize('viewAny', Application::class);
2020-07-11 01:43:59 +00:00
return view('dashboard.appmanagement.all')
->with('applications', Application::paginate(6));
}
public function showAllPendingApps()
{
$this->authorize('viewAny', Application::class);
return view('dashboard.appmanagement.outstandingapps')
->with('applications', Application::where('applicationStatus', 'STAGE_SUBMITTED')->get());
}
public function showPendingInterview()
2020-05-01 05:21:44 +00:00
{
$this->authorize('viewAny', Application::class);
$applications = Application::with('appointment', 'user')->get();
$count = 0;
$pendingInterviews = collect([]);
$upcomingInterviews = collect([]);
2020-10-10 16:30:26 +00:00
foreach ($applications as $application) {
if (! is_null($application->appointment) && $application->appointment->appointmentStatus == 'CONCLUDED') {
$count = +1;
}
2020-10-10 16:30:26 +00:00
switch ($application->applicationStatus) {
case 'STAGE_INTERVIEW':
$upcomingInterviews->push($application);
break;
case 'STAGE_INTERVIEW_SCHEDULED':
$pendingInterviews->push($application);
break;
}
}
return view('dashboard.appmanagement.interview')
->with([
'finishedCount' => $count,
'applications' => $pendingInterviews,
2020-10-10 16:30:26 +00:00
'upcomingApplications' => $upcomingInterviews,
]);
2020-05-01 05:21:44 +00:00
}
2020-05-02 05:54:14 +00:00
public function showPeerReview()
2020-05-02 05:54:14 +00:00
{
$this->authorize('viewAny', Application::class);
2020-10-10 16:30:26 +00:00
return view('dashboard.appmanagement.peerreview')
->with('applications', Application::where('applicationStatus', 'STAGE_PEERAPPROVAL')->get());
2020-05-02 05:54:14 +00:00
}
public function renderApplicationForm(Request $request, $vacancySlug)
{
// FIXME: Get rid of references to first(), this is a wonky query
$vacancyWithForm = Vacancy::with('forms')->where('vacancySlug', $vacancySlug)->get();
$firstVacancy = $vacancyWithForm->first();
2020-10-10 16:30:26 +00:00
if (! $vacancyWithForm->isEmpty() && $firstVacancy->vacancyCount !== 0 && $firstVacancy->vacancyStatus == 'OPEN') {
return view('dashboard.application-rendering.apply')
->with([
'vacancy' => $vacancyWithForm->first(),
2020-10-10 16:30:26 +00:00
'preprocessedForm' => json_decode($vacancyWithForm->first()->forms->formStructure, true),
]);
2020-10-10 16:30:26 +00:00
} else {
abort(404, 'The application you\'re looking for could not be found or it is currently unavailable.');
}
}
public function saveApplicationAnswers(Request $request, $vacancySlug)
{
$vacancy = Vacancy::with('forms')->where('vacancySlug', $vacancySlug)->get();
2020-10-10 16:30:26 +00:00
if ($vacancy->first()->vacancyCount == 0 || $vacancy->first()->vacancyStatus !== 'OPEN') {
$request->session()->flash('error', 'This application is unavailable.');
2020-10-10 16:30:26 +00:00
return redirect()->back();
}
Log::info('Processing new application!');
$formStructure = json_decode($vacancy->first()->forms->formStructure, true);
$responseValidation = ContextAwareValidator::getResponseValidator($request->all(), $formStructure);
Log::info('Built response & validator structure!');
2020-10-10 16:30:26 +00:00
if (! $responseValidation->get('validator')->fails()) {
$response = Response::create([
'responseFormID' => $vacancy->first()->forms->id,
'associatedVacancyID' => $vacancy->first()->id, // Since a form can be used by multiple vacancies, we can only know which specific vacancy this response ties to by using a vacancy ID
2020-10-10 16:30:26 +00:00
'responseData' => $responseValidation->get('responseStructure'),
]);
2020-10-10 16:30:26 +00:00
Log::info('Registered form response for user '.Auth::user()->name.' for vacancy '.$vacancy->first()->vacancyName);
$application = Application::create([
'applicantUserID' => Auth::user()->id,
'applicantFormResponseID' => $response->id,
'applicationStatus' => 'STAGE_SUBMITTED',
]);
2020-10-10 16:30:26 +00:00
Log::info('Submitted application for user '.Auth::user()->name.' with response ID'.$response->id);
2020-10-10 16:30:26 +00:00
foreach (User::all() as $user) {
if ($user->hasRole('admin')) {
$user->notify((new NewApplicant($application, $vacancy->first()))->delay(now()->addSeconds(10)));
}
}
$request->session()->flash('success', 'Thank you for your application! It will be reviewed as soon as possible.');
2020-10-10 16:30:26 +00:00
return redirect()->to(route('showUserApps'));
2020-10-10 16:30:26 +00:00
} else {
Log::warning('Application form for '.Auth::user()->name.' contained errors, resetting!');
$request->session()->flash('error', 'There are one or more errors in your application. Please make sure none of your fields are empty, since they are all required.');
}
return redirect()->back();
}
2020-09-02 19:52:56 +00:00
public function updateApplicationStatus(Request $request, Application $application, $newStatus)
{
$this->authorize('update', Application::class);
2020-10-10 16:30:26 +00:00
switch ($newStatus) {
case 'deny':
event(new ApplicationDeniedEvent($application));
break;
case 'interview':
2020-10-10 16:30:26 +00:00
Log::info('User '.Auth::user()->name.' has moved application ID '.$application->id.'to interview stage');
$request->session()->flash('success', 'Application moved to interview stage! (:');
$application->setStatus('STAGE_INTERVIEW');
$application->user->notify(new ApplicationMoved());
break;
default:
$request->session()->flash('error', 'There are no suitable statuses to update to. Do not mess with the URL.');
}
return redirect()->back();
}
public function delete(Request $request, Application $application)
{
2020-10-10 16:30:26 +00:00
$this->authorize('delete', $application);
$application->delete(); // observers will run, cleaning it up
2020-10-10 16:30:26 +00:00
$request->session()->flash('success', 'Application deleted. Comments, appointments and responses have also been deleted.');
2020-10-10 16:30:26 +00:00
return redirect()->back();
}
}