mirror of
https://github.com/pelican-dev/panel.git
synced 2025-05-20 05:14:46 +02:00

* Not found property rule * Make these “better” * Day 1 * Day 2 * Day 3 * Dat 4 * Remove disabled check * Day 4 continued * Run pint * Final changes hopefully * Pint fixes * Fix again * Reset these * Update app/Filament/Admin/Pages/Health.php Co-authored-by: MartinOscar <40749467+rmartinoscar@users.noreply.github.com> * Update app/Traits/CheckMigrationsTrait.php Co-authored-by: MartinOscar <40749467+rmartinoscar@users.noreply.github.com> --------- Co-authored-by: MartinOscar <40749467+rmartinoscar@users.noreply.github.com>
55 lines
1.8 KiB
PHP
55 lines
1.8 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Middleware\Api\Daemon;
|
|
|
|
use App\Models\Node;
|
|
use Illuminate\Http\Request;
|
|
use Symfony\Component\HttpKernel\Exception\HttpException;
|
|
use Symfony\Component\HttpKernel\Exception\BadRequestHttpException;
|
|
use Symfony\Component\HttpKernel\Exception\AccessDeniedHttpException;
|
|
|
|
class DaemonAuthenticate
|
|
{
|
|
/**
|
|
* Daemon routes that this middleware should be skipped on.
|
|
*
|
|
* @var string[]
|
|
*/
|
|
protected array $except = [
|
|
'daemon.configuration',
|
|
];
|
|
|
|
/**
|
|
* Check if a request from the daemon can be properly attributed back to a single node instance.
|
|
*
|
|
* @throws \Symfony\Component\HttpKernel\Exception\HttpException
|
|
*/
|
|
public function handle(Request $request, \Closure $next): mixed
|
|
{
|
|
if (in_array($request->route()->getName(), $this->except)) {
|
|
return $next($request);
|
|
}
|
|
|
|
if (is_null($bearer = $request->bearerToken())) {
|
|
throw new HttpException(401, 'Access to this endpoint must include an Authorization header.', null, ['WWW-Authenticate' => 'Bearer']);
|
|
}
|
|
|
|
$parts = explode('.', $bearer);
|
|
// Ensure that all the correct parts are provided in the header.
|
|
if (count($parts) !== 2 || empty($parts[0]) || empty($parts[1])) {
|
|
throw new BadRequestHttpException('The Authorization header provided was not in a valid format.');
|
|
}
|
|
|
|
/** @var Node $node */
|
|
$node = Node::query()->where('daemon_token_id', $parts[0])->firstOrFail();
|
|
|
|
if (hash_equals((string) $node->daemon_token, $parts[1])) {
|
|
$request->attributes->set('node', $node);
|
|
|
|
return $next($request);
|
|
}
|
|
|
|
throw new AccessDeniedHttpException('You are not authorized to access this resource.');
|
|
}
|
|
}
|