2024-02-19 11:03:39 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
|
|
|
|
use App\Mail\CuratedRegisterAcceptUser;
|
|
|
|
use App\Mail\CuratedRegisterRejectUser;
|
2024-02-27 03:41:27 +00:00
|
|
|
use App\Mail\CuratedRegisterRequestDetailsFromUser;
|
|
|
|
use App\Models\CuratedRegister;
|
|
|
|
use App\Models\CuratedRegisterActivity;
|
|
|
|
use App\Models\CuratedRegisterTemplate;
|
2024-02-19 11:03:39 +00:00
|
|
|
use App\User;
|
2024-02-27 03:41:27 +00:00
|
|
|
use Illuminate\Http\Request;
|
|
|
|
use Illuminate\Support\Facades\Mail;
|
|
|
|
use Illuminate\Support\Str;
|
2024-02-19 11:03:39 +00:00
|
|
|
|
|
|
|
class AdminCuratedRegisterController extends Controller
|
|
|
|
{
|
|
|
|
public function __construct()
|
|
|
|
{
|
2024-02-27 03:41:27 +00:00
|
|
|
$this->middleware(['auth', 'admin']);
|
2024-02-19 11:03:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function index(Request $request)
|
|
|
|
{
|
|
|
|
$this->validate($request, [
|
2024-02-24 10:45:09 +00:00
|
|
|
'filter' => 'sometimes|in:open,all,awaiting,approved,rejected,responses',
|
2024-02-27 03:41:27 +00:00
|
|
|
'sort' => 'sometimes|in:asc,desc',
|
2024-02-19 11:03:39 +00:00
|
|
|
]);
|
|
|
|
$filter = $request->input('filter', 'open');
|
2024-02-24 10:45:09 +00:00
|
|
|
$sort = $request->input('sort', 'asc');
|
2024-02-27 03:41:27 +00:00
|
|
|
$records = CuratedRegister::when($filter, function ($q, $filter) {
|
|
|
|
if ($filter === 'open') {
|
|
|
|
return $q->where('is_rejected', false)
|
|
|
|
->where(function ($query) {
|
2024-02-24 10:45:09 +00:00
|
|
|
return $query->where('user_has_responded', true)->orWhere('is_awaiting_more_info', false);
|
|
|
|
})
|
2024-02-19 11:03:39 +00:00
|
|
|
->whereNotNull('email_verified_at')
|
|
|
|
->whereIsClosed(false);
|
2024-02-27 03:41:27 +00:00
|
|
|
} elseif ($filter === 'all') {
|
|
|
|
return $q;
|
|
|
|
} elseif ($filter === 'responses') {
|
|
|
|
return $q->whereIsClosed(false)
|
|
|
|
->whereNotNull('email_verified_at')
|
|
|
|
->where('user_has_responded', true)
|
|
|
|
->where('is_awaiting_more_info', true);
|
|
|
|
} elseif ($filter === 'awaiting') {
|
|
|
|
return $q->whereIsClosed(false)
|
|
|
|
->where('is_rejected', false)
|
|
|
|
->where('is_approved', false)
|
|
|
|
->where('user_has_responded', false)
|
|
|
|
->where('is_awaiting_more_info', true);
|
|
|
|
} elseif ($filter === 'approved') {
|
|
|
|
return $q->whereIsClosed(true)->whereIsApproved(true);
|
|
|
|
} elseif ($filter === 'rejected') {
|
|
|
|
return $q->whereIsClosed(true)->whereIsRejected(true);
|
|
|
|
}
|
|
|
|
})
|
|
|
|
->when($sort, function ($query, $sort) {
|
2024-02-24 10:45:09 +00:00
|
|
|
return $query->orderBy('id', $sort);
|
|
|
|
})
|
|
|
|
->paginate(10)
|
|
|
|
->withQueryString();
|
2024-02-27 03:41:27 +00:00
|
|
|
|
2024-02-19 11:03:39 +00:00
|
|
|
return view('admin.curated-register.index', compact('records', 'filter'));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function show(Request $request, $id)
|
|
|
|
{
|
|
|
|
$record = CuratedRegister::findOrFail($id);
|
2024-02-27 03:41:27 +00:00
|
|
|
|
2024-02-19 11:03:39 +00:00
|
|
|
return view('admin.curated-register.show', compact('record'));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function apiActivityLog(Request $request, $id)
|
|
|
|
{
|
|
|
|
$record = CuratedRegister::findOrFail($id);
|
|
|
|
|
|
|
|
$res = collect([
|
|
|
|
[
|
|
|
|
'id' => 1,
|
|
|
|
'action' => 'created',
|
|
|
|
'title' => 'Onboarding application created',
|
|
|
|
'message' => null,
|
|
|
|
'link' => null,
|
|
|
|
'timestamp' => $record->created_at,
|
2024-02-27 03:41:27 +00:00
|
|
|
],
|
2024-02-19 11:03:39 +00:00
|
|
|
]);
|
|
|
|
|
2024-02-27 03:41:27 +00:00
|
|
|
if ($record->email_verified_at) {
|
2024-02-19 11:03:39 +00:00
|
|
|
$res->push([
|
|
|
|
'id' => 3,
|
|
|
|
'action' => 'email_verified_at',
|
|
|
|
'title' => 'Applicant successfully verified email address',
|
|
|
|
'message' => null,
|
|
|
|
'link' => null,
|
|
|
|
'timestamp' => $record->email_verified_at,
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
$activities = CuratedRegisterActivity::whereRegisterId($record->id)->get();
|
|
|
|
|
|
|
|
$idx = 4;
|
|
|
|
$userResponses = collect([]);
|
|
|
|
|
2024-02-27 03:41:27 +00:00
|
|
|
foreach ($activities as $activity) {
|
2024-02-19 11:03:39 +00:00
|
|
|
$idx++;
|
2024-02-29 09:04:43 +00:00
|
|
|
|
|
|
|
if ($activity->type === 'user_resend_email_confirmation') {
|
|
|
|
continue;
|
|
|
|
}
|
2024-02-27 03:41:27 +00:00
|
|
|
if ($activity->from_user) {
|
2024-02-19 11:03:39 +00:00
|
|
|
$userResponses->push($activity);
|
2024-02-27 03:41:27 +00:00
|
|
|
|
2024-02-19 11:03:39 +00:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
$res->push([
|
|
|
|
'id' => $idx,
|
|
|
|
'aid' => $activity->id,
|
|
|
|
'action' => $activity->type,
|
|
|
|
'title' => $activity->from_admin ? 'Admin requested info' : 'User responded',
|
|
|
|
'message' => $activity->message,
|
|
|
|
'link' => $activity->adminReviewUrl(),
|
|
|
|
'timestamp' => $activity->created_at,
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
2024-02-27 03:41:27 +00:00
|
|
|
foreach ($userResponses as $ur) {
|
|
|
|
$res = $res->map(function ($r) use ($ur) {
|
|
|
|
if (! isset($r['aid'])) {
|
2024-02-19 11:03:39 +00:00
|
|
|
return $r;
|
|
|
|
}
|
2024-02-27 03:41:27 +00:00
|
|
|
if ($ur->reply_to_id === $r['aid']) {
|
2024-02-19 11:03:39 +00:00
|
|
|
$r['user_response'] = $ur;
|
2024-02-27 03:41:27 +00:00
|
|
|
|
2024-02-19 11:03:39 +00:00
|
|
|
return $r;
|
|
|
|
}
|
2024-02-27 03:41:27 +00:00
|
|
|
|
2024-02-19 11:03:39 +00:00
|
|
|
return $r;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2024-02-27 03:41:27 +00:00
|
|
|
if ($record->is_approved) {
|
2024-02-19 11:03:39 +00:00
|
|
|
$idx++;
|
|
|
|
$res->push([
|
|
|
|
'id' => $idx,
|
|
|
|
'action' => 'approved',
|
|
|
|
'title' => 'Application Approved',
|
|
|
|
'message' => null,
|
|
|
|
'link' => null,
|
|
|
|
'timestamp' => $record->action_taken_at,
|
|
|
|
]);
|
2024-02-27 03:41:27 +00:00
|
|
|
} elseif ($record->is_rejected) {
|
2024-02-19 11:03:39 +00:00
|
|
|
$idx++;
|
|
|
|
$res->push([
|
|
|
|
'id' => $idx,
|
|
|
|
'action' => 'rejected',
|
|
|
|
'title' => 'Application Rejected',
|
|
|
|
'message' => null,
|
|
|
|
'link' => null,
|
|
|
|
'timestamp' => $record->action_taken_at,
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $res->reverse()->values();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function apiMessagePreviewStore(Request $request, $id)
|
|
|
|
{
|
|
|
|
$record = CuratedRegister::findOrFail($id);
|
2024-02-27 03:41:27 +00:00
|
|
|
|
2024-02-19 11:03:39 +00:00
|
|
|
return $request->all();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function apiMessageSendStore(Request $request, $id)
|
|
|
|
{
|
|
|
|
$this->validate($request, [
|
2024-05-07 10:22:28 +00:00
|
|
|
'message' => 'required|string|min:5|max:3000',
|
2024-02-19 11:03:39 +00:00
|
|
|
]);
|
|
|
|
$record = CuratedRegister::findOrFail($id);
|
|
|
|
abort_if($record->email_verified_at === null, 400, 'Cannot message an unverified email');
|
|
|
|
$activity = new CuratedRegisterActivity;
|
|
|
|
$activity->register_id = $record->id;
|
|
|
|
$activity->admin_id = $request->user()->id;
|
|
|
|
$activity->secret_code = Str::random(32);
|
|
|
|
$activity->type = 'request_details';
|
|
|
|
$activity->from_admin = true;
|
|
|
|
$activity->message = $request->input('message');
|
|
|
|
$activity->save();
|
|
|
|
$record->is_awaiting_more_info = true;
|
2024-02-24 10:45:09 +00:00
|
|
|
$record->user_has_responded = false;
|
2024-02-19 11:03:39 +00:00
|
|
|
$record->save();
|
|
|
|
Mail::to($record->email)->send(new CuratedRegisterRequestDetailsFromUser($record, $activity));
|
2024-02-27 03:41:27 +00:00
|
|
|
|
2024-02-19 11:03:39 +00:00
|
|
|
return $request->all();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function previewDetailsMessageShow(Request $request, $id)
|
|
|
|
{
|
|
|
|
$record = CuratedRegister::findOrFail($id);
|
|
|
|
abort_if($record->email_verified_at === null, 400, 'Cannot message an unverified email');
|
|
|
|
$activity = new CuratedRegisterActivity;
|
|
|
|
$activity->message = $request->input('message');
|
2024-02-27 03:41:27 +00:00
|
|
|
|
2024-02-19 11:03:39 +00:00
|
|
|
return new \App\Mail\CuratedRegisterRequestDetailsFromUser($record, $activity);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function previewMessageShow(Request $request, $id)
|
|
|
|
{
|
|
|
|
$record = CuratedRegister::findOrFail($id);
|
|
|
|
abort_if($record->email_verified_at === null, 400, 'Cannot message an unverified email');
|
|
|
|
$record->message = $request->input('message');
|
2024-02-27 03:41:27 +00:00
|
|
|
|
2024-02-19 11:03:39 +00:00
|
|
|
return new \App\Mail\CuratedRegisterSendMessage($record);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function apiHandleReject(Request $request, $id)
|
|
|
|
{
|
|
|
|
$this->validate($request, [
|
2024-02-27 03:41:27 +00:00
|
|
|
'action' => 'required|in:reject-email,reject-silent',
|
2024-02-19 11:03:39 +00:00
|
|
|
]);
|
|
|
|
$action = $request->input('action');
|
|
|
|
$record = CuratedRegister::findOrFail($id);
|
|
|
|
abort_if($record->email_verified_at === null, 400, 'Cannot reject an unverified email');
|
|
|
|
$record->is_rejected = true;
|
|
|
|
$record->is_closed = true;
|
|
|
|
$record->action_taken_at = now();
|
|
|
|
$record->save();
|
2024-02-27 03:41:27 +00:00
|
|
|
if ($action === 'reject-email') {
|
2024-02-19 11:03:39 +00:00
|
|
|
Mail::to($record->email)->send(new CuratedRegisterRejectUser($record));
|
|
|
|
}
|
2024-02-27 03:41:27 +00:00
|
|
|
|
2024-02-19 11:03:39 +00:00
|
|
|
return [200];
|
|
|
|
}
|
|
|
|
|
|
|
|
public function apiHandleApprove(Request $request, $id)
|
|
|
|
{
|
|
|
|
$record = CuratedRegister::findOrFail($id);
|
|
|
|
abort_if($record->email_verified_at === null, 400, 'Cannot reject an unverified email');
|
|
|
|
$record->is_approved = true;
|
|
|
|
$record->is_closed = true;
|
|
|
|
$record->action_taken_at = now();
|
|
|
|
$record->save();
|
2024-05-16 11:45:31 +00:00
|
|
|
|
|
|
|
if (User::withTrashed()->whereEmail($record->email)->exists()) {
|
|
|
|
return [200];
|
|
|
|
}
|
|
|
|
|
2024-02-19 11:03:39 +00:00
|
|
|
$user = User::create([
|
|
|
|
'name' => $record->username,
|
|
|
|
'username' => $record->username,
|
|
|
|
'email' => $record->email,
|
|
|
|
'password' => $record->password,
|
|
|
|
'app_register_ip' => $record->ip_address,
|
|
|
|
'email_verified_at' => now(),
|
2024-02-27 03:41:27 +00:00
|
|
|
'register_source' => 'cur_onboarding',
|
2024-02-19 11:03:39 +00:00
|
|
|
]);
|
|
|
|
|
|
|
|
Mail::to($record->email)->send(new CuratedRegisterAcceptUser($record));
|
2024-02-27 03:41:27 +00:00
|
|
|
|
2024-02-19 11:03:39 +00:00
|
|
|
return [200];
|
|
|
|
}
|
2024-02-27 03:41:27 +00:00
|
|
|
|
|
|
|
public function templates(Request $request)
|
|
|
|
{
|
|
|
|
$templates = CuratedRegisterTemplate::paginate(10);
|
|
|
|
|
|
|
|
return view('admin.curated-register.templates', compact('templates'));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function templateCreate(Request $request)
|
|
|
|
{
|
|
|
|
return view('admin.curated-register.template-create');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function templateEdit(Request $request, $id)
|
|
|
|
{
|
|
|
|
$template = CuratedRegisterTemplate::findOrFail($id);
|
|
|
|
|
|
|
|
return view('admin.curated-register.template-edit', compact('template'));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function templateEditStore(Request $request, $id)
|
|
|
|
{
|
|
|
|
$this->validate($request, [
|
|
|
|
'name' => 'required|string|max:30',
|
|
|
|
'content' => 'required|string|min:5|max:3000',
|
|
|
|
'description' => 'nullable|sometimes|string|max:1000',
|
|
|
|
'active' => 'sometimes',
|
|
|
|
]);
|
|
|
|
$template = CuratedRegisterTemplate::findOrFail($id);
|
|
|
|
$template->name = $request->input('name');
|
|
|
|
$template->content = $request->input('content');
|
|
|
|
$template->description = $request->input('description');
|
|
|
|
$template->is_active = $request->boolean('active');
|
|
|
|
$template->save();
|
|
|
|
|
|
|
|
return redirect()->back()->with('status', 'Successfully updated template!');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function templateDelete(Request $request, $id)
|
|
|
|
{
|
|
|
|
$template = CuratedRegisterTemplate::findOrFail($id);
|
|
|
|
$template->delete();
|
|
|
|
|
|
|
|
return redirect(route('admin.curated-onboarding.templates'))->with('status', 'Successfully deleted template!');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function templateStore(Request $request)
|
|
|
|
{
|
|
|
|
$this->validate($request, [
|
|
|
|
'name' => 'required|string|max:30',
|
|
|
|
'content' => 'required|string|min:5|max:3000',
|
|
|
|
'description' => 'nullable|sometimes|string|max:1000',
|
|
|
|
'active' => 'sometimes',
|
|
|
|
]);
|
|
|
|
CuratedRegisterTemplate::create([
|
|
|
|
'name' => $request->input('name'),
|
|
|
|
'content' => $request->input('content'),
|
|
|
|
'description' => $request->input('description'),
|
|
|
|
'is_active' => $request->boolean('active'),
|
|
|
|
]);
|
|
|
|
|
|
|
|
return redirect(route('admin.curated-onboarding.templates'))->with('status', 'Successfully created new template!');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getActiveTemplates(Request $request)
|
|
|
|
{
|
|
|
|
$templates = CuratedRegisterTemplate::whereIsActive(true)
|
|
|
|
->orderBy('order')
|
|
|
|
->get()
|
|
|
|
->map(function ($tmp) {
|
|
|
|
return [
|
|
|
|
'name' => $tmp->name,
|
|
|
|
'content' => $tmp->content,
|
|
|
|
];
|
|
|
|
});
|
|
|
|
|
|
|
|
return response()->json($templates);
|
|
|
|
}
|
2024-02-19 11:03:39 +00:00
|
|
|
}
|