ctrlpanel/app/Http/Controllers/ProductController.php
1day2die 0c067e26c8 Revert "Merge branch 'development' into main"
This reverts commit 3810b487cd, reversing
changes made to d9a41840ce.
2023-04-25 09:22:30 +02:00

122 lines
3.9 KiB
PHP

<?php
namespace App\Http\Controllers;
use App\Classes\Pterodactyl;
use App\Models\Egg;
use App\Models\Location;
use App\Models\Node;
use App\Models\Product;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Http\JsonResponse;
use Illuminate\Http\Request;
use Illuminate\Support\Collection;
class ProductController extends Controller
{
/**
* @description get product locations based on selected egg
*
* @param Request $request
* @param Egg $egg
* @return Collection|JsonResponse
*/
public function getNodesBasedOnEgg(Request $request, Egg $egg)
{
if (is_null($egg->id)) {
return response()->json('Egg ID is required', '400');
}
//get products that include this egg
$products = Product::query()
->with('nodes')
->where('disabled', '=', false)
->whereHas('eggs', function (Builder $builder) use ($egg) {
$builder->where('id', '=', $egg->id);
})->get();
$nodes = collect();
//filter unique nodes
$products->each(function (Product $product) use ($nodes) {
$product->nodes->each(function (Node $node) use ($nodes) {
if (! $nodes->contains('id', $node->id) && ! $node->disabled) {
$nodes->add($node);
}
});
});
return $nodes;
}
/**
* @description get product locations based on selected egg
*
* @param Request $request
* @param Egg $egg
* @return Collection|JsonResponse
*/
public function getLocationsBasedOnEgg(Request $request, Egg $egg)
{
$nodes = $this->getNodesBasedOnEgg($request, $egg);
foreach ($nodes as $key => $node) {
$pteroNode = Pterodactyl::getNode($node->id);
if ($pteroNode['allocated_resources']['memory'] >= ($pteroNode['memory'] * ($pteroNode['memory_overallocate'] + 100) / 100) || $pteroNode['allocated_resources']['disk'] >= ($pteroNode['disk'] * ($pteroNode['disk_overallocate'] + 100) / 100)) {
$nodes->forget($key);
}
}
$locations = collect();
//locations
$nodes->each(function (Node $node) use ($nodes, $locations) {
/** @var Location $location */
$location = $node->location;
if (! $locations->contains('id', $location->id)) {
$nodeIds = $nodes->map(function ($node) {
return $node->id;
});
$location->nodes = $location->nodes()
->whereIn('id', $nodeIds)
->get();
$locations->add($location);
}
});
return $locations;
}
/**
* @param Node $node
* @param Egg $egg
* @return Collection|JsonResponse
*/
public function getProductsBasedOnNode(Egg $egg, Node $node)
{
if (is_null($egg->id) || is_null($node->id)) {
return response()->json('node and egg id is required', '400');
}
$products = Product::query()
->where('disabled', '=', false)
->whereHas('nodes', function (Builder $builder) use ($node) {
$builder->where('id', '=', $node->id);
})
->whereHas('eggs', function (Builder $builder) use ($egg) {
$builder->where('id', '=', $egg->id);
})
->get();
$pteroNode = Pterodactyl::getNode($node->id);
foreach ($products as $key => $product) {
if ($product->memory > ($pteroNode['memory'] * ($pteroNode['memory_overallocate'] + 100) / 100) - $pteroNode['allocated_resources']['memory'] || $product->disk > ($pteroNode['disk'] * ($pteroNode['disk_overallocate'] + 100) / 100) - $pteroNode['allocated_resources']['disk']) {
$product->doesNotFit = true;
}
}
return $products;
}
}