mirror of
https://github.com/Huber1/skigemeinschaft.git
synced 2026-05-13 12:27:34 +02:00
81 lines
1.7 KiB
PHP
81 lines
1.7 KiB
PHP
<?php
|
|
|
|
use Kirby\Exception\Exception;
|
|
use Kirby\Exception\InvalidArgumentException;
|
|
|
|
/**
|
|
* System Routes
|
|
*/
|
|
return [
|
|
|
|
[
|
|
'pattern' => 'system',
|
|
'method' => 'GET',
|
|
'auth' => false,
|
|
'action' => function () {
|
|
$system = $this->kirby()->system();
|
|
$model = $this->resolve($system);
|
|
|
|
if ($this->kirby()->user()) {
|
|
return $model->view('panel');
|
|
}
|
|
|
|
return match ($system->isOk()) {
|
|
true => $model->view('login'),
|
|
false => $model->view('troubleshooting')
|
|
};
|
|
}
|
|
],
|
|
[
|
|
'pattern' => 'system/register',
|
|
'method' => 'POST',
|
|
'action' => function () {
|
|
return $this->kirby()->system()->register($this->requestBody('license'), $this->requestBody('email'));
|
|
}
|
|
],
|
|
[
|
|
'pattern' => 'system/install',
|
|
'method' => 'POST',
|
|
'auth' => false,
|
|
'action' => function () {
|
|
$system = $this->kirby()->system();
|
|
$auth = $this->kirby()->auth();
|
|
|
|
// csrf token check
|
|
if ($auth->type() === 'session' && $auth->csrf() === false) {
|
|
throw new InvalidArgumentException(
|
|
message: 'Invalid CSRF token'
|
|
);
|
|
}
|
|
|
|
if ($system->isOk() === false) {
|
|
throw new Exception(
|
|
message: 'The server is not setup correctly'
|
|
);
|
|
}
|
|
|
|
if ($system->isInstallable() === false) {
|
|
throw new Exception(
|
|
message: 'The Panel cannot be installed'
|
|
);
|
|
}
|
|
|
|
if ($system->isInstalled() === true) {
|
|
throw new Exception(
|
|
message: 'The Panel is already installed'
|
|
);
|
|
}
|
|
|
|
// create the first user
|
|
$user = $this->users()->create($this->requestBody());
|
|
$token = $user->login($this->requestBody('password'));
|
|
|
|
return [
|
|
'status' => 'ok',
|
|
'token' => $token,
|
|
'user' => $this->resolve($user)->view('auth')->toArray()
|
|
];
|
|
}
|
|
]
|
|
|
|
];
|