peliprint/app/Http/Controllers/Admin/Extensions/Blueprint/BlueprintExtensionController.php
purple ce46c8b6f5 Add yet even more comments and tell what a lot of things do.
Improves readability a ton, trust me.
2023-08-31 10:51:44 +02:00

105 lines
3.6 KiB
PHP

<?php
namespace Pterodactyl\Http\Controllers\Admin\Extensions\Blueprint;
use Illuminate\View\View;
use Illuminate\View\Factory as ViewFactory;
use Prologue\Alerts\AlertsMessageBag;
use Illuminate\Contracts\Console\Kernel;
use Pterodactyl\Http\Controllers\Controller;
use Pterodactyl\Services\Helpers\SoftwareVersionService;
use Pterodactyl\Services\Helpers\BlueprintVariableService;
use Pterodactyl\Services\Helpers\BlueprintTelemetryService;
use Pterodactyl\Services\Helpers\BlueprintExtensionLibrary;
use Pterodactyl\Services\Helpers\BlueprintPlaceholderService;
use Pterodactyl\Contracts\Repository\SettingsRepositoryInterface;
use Illuminate\Contracts\Config\Repository as ConfigRepository;
use Illuminate\Http\RedirectResponse;
use Pterodactyl\Http\Requests\Admin\AdminFormRequest;
class BlueprintExtensionController extends Controller
{
/**
* BlueprintExtensionController constructor.
*/
public function __construct(
private BlueprintVariableService $bp,
private BlueprintTelemetryService $telemetry,
private BlueprintExtensionLibrary $bplib,
private BlueprintPlaceholderService $placeholderservice,
private SoftwareVersionService $version,
private ViewFactory $view,
private Kernel $kernel,
private AlertsMessageBag $alert,
private ConfigRepository $config,
private SettingsRepositoryInterface $settings,
) {
}
/**
* Return the admin index view.
*/
public function index(): View
{
// The following code rerolls the panel identifier used for telemetry
// when the version name changes.
if ($this->settings->get('blueprint::panel:id') == "" || $this->bp->version() != $this->settings->get('blueprint::version:cache')) {
$this->settings->set('blueprint::panel:id', uniqid(rand())."@".$this->bp->version());
$this->settings->set('blueprint::version:cache', $this->bp->version());
$this->bp->config('TELEMETRY_ID',$this->settings->get("blueprint::panel:id"));
};
// Sync developer mode option with the core of Blueprint.
$this->bp->config('DEVELOPER', $this->settings->get('blueprint::developer'));
return $this->view->make(
'admin.extensions.blueprint.index', [
'version' => $this->version,
'bp' => $this->bp,
'bplib' => $this->bplib,
'telemetry' => $this->telemetry,
'root' => "/admin/extensions/blueprint",
]
);
}
/**
* @throws \Pterodactyl\Exceptions\Model\DataValidationException
* @throws \Pterodactyl\Exceptions\Repository\RecordNotFoundException
*/
public function update(BlueprintAdminFormRequest $request): RedirectResponse
{
foreach ($request->normalize() as $key => $value) {
$this->settings->set('blueprint::' . $key, $value);
}
// Confirm that the database value changes have been applied.
$this->bplib->notify("Your changes have been saved.");
// Redirect back to the page the user was on.
return redirect()->route('admin.extensions.blueprint.index');
}
}
class BlueprintAdminFormRequest extends AdminFormRequest
{
// Form validation for settings on the Blueprint admin page.
// This is included in the controller directly as that
// simplifies my work.
public function rules(): array {
return [
'placeholder' => 'string',
'developer' => 'string',
'telemetry' => 'string',
];
}
public function attributes(): array {
return [
'placeholder' => 'Placeholder Value',
'developer' => 'Developer Mode',
'telemetry' => 'Telemetry',
];
}
}