This commit is contained in:
hackerESQ
2025-01-24 22:45:28 -06:00
parent b8f24d4b67
commit 62dcae48bb
6 changed files with 86 additions and 8 deletions
@@ -5,22 +5,53 @@ declare(strict_types=1);
namespace App\Http\ApiControllers;
use App\Models\Portfolio;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Gate;
use HackerEsq\FilterModels\FilterModels;
use App\Http\Resources\PortfolioResource;
use App\Http\Requests\StorePortfolioRequest;
use App\Http\Requests\UpdatePortfolioRequest;
use App\Http\ApiControllers\Controller as ApiController;
class PortfolioController extends ApiController
{
public function index(FilterModels $filters)
{
$filters->setQuery(Portfolio::query());
$filters->setScopes(['myPortfolios']);
$filters->setEagerRelations(['users', 'transactions', 'holdings']);
$filters->setFilterableRelations(['holdings' => 'symbol', 'transactions' => 'symbol']);
$filters->setFilterableRelations(['holdings.symbol']);
$filters->setSearchableColumns(['title', 'notes']);
return PortfolioResource::collection($filters->paginated());
}
public function store(StorePortfolioRequest $request)
{
$portfolio = Portfolio::create($request->validated());
return PortfolioResource::make($portfolio);
}
public function show(Portfolio $portfolio)
{
Gate::authorize('readOnly', $portfolio);
return PortfolioResource::make($portfolio);
}
public function update(UpdatePortfolioRequest $request, Portfolio $portfolio)
{
Gate::authorize('fullAccess', $portfolio);
$portfolio->update($request->validated());
return PortfolioResource::make($portfolio);
}
public function destroy(Portfolio $portfolio)
{
Gate::authorize('fullAccess', $portfolio);
return response()->noContent();
}
}
@@ -0,0 +1,23 @@
<?php
namespace App\Http\Requests;
use Illuminate\Foundation\Http\FormRequest;
class StorePortfolioRequest extends FormRequest
{
/**
* Get the validation rules that apply to the request.
*
* @return array<string, \Illuminate\Contracts\Validation\ValidationRule|array<mixed>|string>
*/
public function rules(): array
{
return [
'title' => ['required', 'string', 'max:255'],
'notes' => ['sometimes', 'nullable', 'string'],
'wishlist' => ['sometimes', 'nullable', 'boolean'],
];
}
}
@@ -0,0 +1,23 @@
<?php
namespace App\Http\Requests;
use Illuminate\Foundation\Http\FormRequest;
class UpdatePortfolioRequest extends FormRequest
{
/**
* Get the validation rules that apply to the request.
*
* @return array<string, \Illuminate\Contracts\Validation\ValidationRule|array<mixed>|string>
*/
public function rules(): array
{
return [
'title' => ['sometimes', 'string', 'max:255'],
'notes' => ['sometimes', 'nullable', 'string'],
'wishlist' => ['sometimes', 'nullable', 'boolean'],
];
}
}
+1
View File
@@ -19,6 +19,7 @@ class PortfolioResource extends JsonResource
return [
'id' => $this->id,
'title' => $this->title,
'notes' => $this->notes,
'wishlist' => $this->wishlist,
'owner' => UserResource::make($this->owner),
'transactions' => TransactionResource::collection($this->whenLoaded('transactions')),
Generated
+4 -4
View File
@@ -1733,12 +1733,12 @@
"source": {
"type": "git",
"url": "https://github.com/hackerESQ/filter-models.git",
"reference": "4ddba2483dc3987dcdf3f637be7edb8a2c96606c"
"reference": "565537120ea01bd73f49051ecde90d05e4127c6b"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/hackerESQ/filter-models/zipball/4ddba2483dc3987dcdf3f637be7edb8a2c96606c",
"reference": "4ddba2483dc3987dcdf3f637be7edb8a2c96606c",
"url": "https://api.github.com/repos/hackerESQ/filter-models/zipball/565537120ea01bd73f49051ecde90d05e4127c6b",
"reference": "565537120ea01bd73f49051ecde90d05e4127c6b",
"shasum": ""
},
"require": {
@@ -1764,7 +1764,7 @@
"source": "https://github.com/hackerESQ/filter-models/tree/main",
"issues": "https://github.com/hackerESQ/filter-models/issues"
},
"time": "2025-01-25T01:22:46+00:00"
"time": "2025-01-25T04:44:58+00:00"
},
{
"name": "jfcherng/php-color-output",
+1 -1
View File
@@ -13,7 +13,7 @@ Route::middleware(['auth:sanctum'])->group(function () {
Route::get('/me', [UserController::class, 'me']);
// portfolio
Route::get('/portfolio', [PortfolioController::class, 'index']);
Route::apiResource('/portfolio', PortfolioController::class);
// transaction
Route::get('/transaction', [TransactionController::class, 'index']);