Files
UNIT3D-Community-Edition/app/Http/Controllers/Auth/ApplicationController.php
HDVinnie 2ca429c4ce Revert "PSR12 Linting"
This reverts commit 7e65e1d589.
2022-09-11 19:51:58 -04:00

127 lines
4.5 KiB
PHP

<?php
/**
* NOTICE OF LICENSE.
*
* UNIT3D Community Edition is open-sourced software licensed under the GNU Affero General Public License v3.0
* The details is bundled with this project in the file LICENSE.txt.
*
* @project UNIT3D Community Edition
*
* @author HDVinnie <hdinnovations@protonmail.com>
* @license https://www.gnu.org/licenses/agpl-3.0.en.html/ GNU Affero General Public License v3.0
*/
namespace App\Http\Controllers\Auth;
use App\Http\Controllers\Controller;
use App\Models\Application;
use App\Models\ApplicationImageProof;
use App\Models\ApplicationUrlProof;
use App\Rules\EmailBlacklist;
use Illuminate\Http\Request;
/**
* @see \Tests\Todo\Feature\Http\Controllers\Staff\ApplicationControllerTest
*/
class ApplicationController extends Controller
{
/**
* Application Add Form.
*/
public function create(): \Illuminate\Contracts\View\Factory|\Illuminate\View\View
{
return \view('auth.application.create');
}
/**
* Store A New Application.
*/
public function store(Request $request): \Illuminate\Http\RedirectResponse
{
$application = \resolve(Application::class);
$application->type = $request->input('type');
$application->email = $request->input('email');
$application->referrer = $request->input('referrer');
if (\config('email-blacklist.enabled')) {
if (! \config('captcha.enabled')) {
$v = \validator($request->all(), [
'type' => 'required',
'email' => [
'required',
'string',
'email',
'max:70',
'unique:invites',
'unique:users',
'unique:applications',
new EmailBlacklist(),
],
'referrer' => 'required',
'images.*' => 'filled',
'images' => 'min:2',
'links.*' => 'filled',
'links' => 'min:2',
]);
} else {
$v = \validator($request->all(), [
'type' => 'required',
'email' => [
'required',
'string',
'email',
'max:70',
'unique:invites',
'unique:users',
'unique:applications',
new EmailBlacklist(),
],
'referrer' => 'required',
'images.*' => 'filled',
'images' => 'min:2',
'links.*' => 'filled',
'links' => 'min:2',
'captcha' => 'hiddencaptcha',
]);
}
} elseif (! \config('captcha.enabled')) {
$v = \validator($request->all(), [
'type' => 'required',
'email' => 'required|string|email|max:70|unique:invites|unique:users|unique:applications',
'referrer' => 'required',
'images.*' => 'filled',
'images' => 'min:2',
'links.*' => 'filled',
'links' => 'min:2',
]);
} else {
$v = \validator($request->all(), [
'type' => 'required',
'email' => 'required|string|email|max:70|unique:invites|unique:users|unique:applications',
'referrer' => 'required',
'images.*' => 'filled',
'images' => 'min:2',
'links.*' => 'filled',
'links' => 'min:2',
'captcha' => 'hiddencaptcha',
]);
}
if ($v->fails()) {
return \to_route('application.create')
->withErrors($v->errors());
}
$application->save();
// Map And Save IMG Proofs
$imgs = \collect($request->input('images'))->map(fn ($value) => new ApplicationImageProof(['image' => $value]));
$application->imageProofs()->saveMany($imgs);
// Map And Save URL Proofs
$urls = \collect($request->input('links'))->map(fn ($value) => new ApplicationUrlProof(['url' => $value]));
$application->urlProofs()->saveMany($urls);
return \to_route('login')
->withSuccess(\trans('auth.application-submitted'));
}
}