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

* add node cpu limit to backend * update makenodecommand * add node cpu limit to frontend * add migration and update mysql schema * run pint * fix typo in mysql schema * forgot this assert * forgot to setCpu here * run pint * adjust migration * Fix db migration * make cpu optional * set default value for cpu in node deployment * update mysql schema --------- Co-authored-by: notCharles <charles@pelican.dev>
41 lines
1.4 KiB
PHP
41 lines
1.4 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Api\Application\Nodes;
|
|
|
|
use App\Services\Deployment\FindViableNodesService;
|
|
use App\Transformers\Api\Application\NodeTransformer;
|
|
use App\Http\Controllers\Api\Application\ApplicationApiController;
|
|
use App\Http\Requests\Api\Application\Nodes\GetDeployableNodesRequest;
|
|
|
|
class NodeDeploymentController extends ApplicationApiController
|
|
{
|
|
/**
|
|
* NodeDeploymentController constructor.
|
|
*/
|
|
public function __construct(private FindViableNodesService $viableNodesService)
|
|
{
|
|
parent::__construct();
|
|
}
|
|
|
|
/**
|
|
* Finds any nodes that are available using the given deployment criteria. This works
|
|
* similarly to the server creation process, but allows you to pass the deployment object
|
|
* to this endpoint and get back a list of all Nodes satisfying the requirements.
|
|
*
|
|
* @throws \App\Exceptions\Service\Deployment\NoViableNodeException
|
|
*/
|
|
public function __invoke(GetDeployableNodesRequest $request): array
|
|
{
|
|
$data = $request->validated();
|
|
$nodes = $this->viableNodesService
|
|
->setMemory($data['memory'])
|
|
->setDisk($data['disk'])
|
|
->setCpu($data['cpu'] ?? 0)
|
|
->handle((int) $request->query('per_page'), (int) $request->query('page'));
|
|
|
|
return $this->fractal->collection($nodes)
|
|
->transformWith($this->getTransformer(NodeTransformer::class))
|
|
->toArray();
|
|
}
|
|
}
|