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

* Add Docker, Refactor, Fix Notification Co-authored-by: notCharles <charles@pelican.dev> * Pint * Required adjustments * Remove deprecated * Third time's the charm --------- Co-authored-by: notCharles <charles@pelican.dev>
59 lines
1.7 KiB
PHP
59 lines
1.7 KiB
PHP
<?php
|
|
|
|
namespace App\Services\Nodes;
|
|
|
|
use App\Models\ApiKey;
|
|
use App\Models\Node;
|
|
use App\Services\Api\KeyCreationService;
|
|
use Illuminate\Http\Request;
|
|
|
|
class NodeAutoDeployService
|
|
{
|
|
/**
|
|
* NodeAutoDeployService constructor.
|
|
*/
|
|
public function __construct(
|
|
private readonly KeyCreationService $keyCreationService
|
|
) {
|
|
}
|
|
|
|
/**
|
|
* Generates a new API key for the logged-in user with only permission to read
|
|
* nodes, and returns that as the deployment key for a node.
|
|
*
|
|
* @throws \App\Exceptions\Model\DataValidationException
|
|
*/
|
|
public function handle(Request $request, Node $node, ?bool $docker = false): ?string
|
|
{
|
|
/** @var ApiKey|null $key */
|
|
$key = ApiKey::query()
|
|
->where('key_type', ApiKey::TYPE_APPLICATION)
|
|
->where('r_nodes', true)
|
|
->first();
|
|
|
|
// We couldn't find a key that exists for this user with only permission for
|
|
// reading nodes. Go ahead and create it now.
|
|
if (!$key) {
|
|
$key = $this->keyCreationService->setKeyType(ApiKey::TYPE_APPLICATION)->handle([
|
|
'memo' => 'Automatically generated node deployment key.',
|
|
'user_id' => $request->user()->id,
|
|
], ['r_nodes' => true]);
|
|
}
|
|
|
|
$token = $key->identifier . $key->token;
|
|
|
|
if (!$token) {
|
|
return null;
|
|
}
|
|
|
|
return sprintf(
|
|
'%s wings configure --panel-url %s --token %s --node %d%s',
|
|
$docker ? 'docker compose exec -it' : 'sudo',
|
|
config('app.url'),
|
|
$token,
|
|
$node->id,
|
|
$request->isSecure() ? '' : ' --allow-insecure'
|
|
);
|
|
}
|
|
}
|