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; namespace App\Http\ApiControllers;
use App\Models\Portfolio; use App\Models\Portfolio;
use Illuminate\Http\Request; use Illuminate\Support\Facades\Gate;
use HackerEsq\FilterModels\FilterModels; use HackerEsq\FilterModels\FilterModels;
use App\Http\Resources\PortfolioResource; use App\Http\Resources\PortfolioResource;
use App\Http\Requests\StorePortfolioRequest;
use App\Http\Requests\UpdatePortfolioRequest;
use App\Http\ApiControllers\Controller as ApiController; use App\Http\ApiControllers\Controller as ApiController;
class PortfolioController extends ApiController class PortfolioController extends ApiController
{ {
public function index(FilterModels $filters) public function index(FilterModels $filters)
{ {
$filters->setQuery(Portfolio::query()); $filters->setQuery(Portfolio::query());
$filters->setScopes(['myPortfolios']); $filters->setScopes(['myPortfolios']);
$filters->setEagerRelations(['users', 'transactions', 'holdings']); $filters->setEagerRelations(['users', 'transactions', 'holdings']);
$filters->setFilterableRelations(['holdings' => 'symbol', 'transactions' => 'symbol']); $filters->setFilterableRelations(['holdings.symbol']);
$filters->setSearchableColumns(['title', 'notes']); $filters->setSearchableColumns(['title', 'notes']);
return PortfolioResource::collection($filters->paginated()); 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 [ return [
'id' => $this->id, 'id' => $this->id,
'title' => $this->title, 'title' => $this->title,
'notes' => $this->notes,
'wishlist' => $this->wishlist, 'wishlist' => $this->wishlist,
'owner' => UserResource::make($this->owner), 'owner' => UserResource::make($this->owner),
'transactions' => TransactionResource::collection($this->whenLoaded('transactions')), 'transactions' => TransactionResource::collection($this->whenLoaded('transactions')),
Generated
+4 -4
View File
@@ -1733,12 +1733,12 @@
"source": { "source": {
"type": "git", "type": "git",
"url": "https://github.com/hackerESQ/filter-models.git", "url": "https://github.com/hackerESQ/filter-models.git",
"reference": "4ddba2483dc3987dcdf3f637be7edb8a2c96606c" "reference": "565537120ea01bd73f49051ecde90d05e4127c6b"
}, },
"dist": { "dist": {
"type": "zip", "type": "zip",
"url": "https://api.github.com/repos/hackerESQ/filter-models/zipball/4ddba2483dc3987dcdf3f637be7edb8a2c96606c", "url": "https://api.github.com/repos/hackerESQ/filter-models/zipball/565537120ea01bd73f49051ecde90d05e4127c6b",
"reference": "4ddba2483dc3987dcdf3f637be7edb8a2c96606c", "reference": "565537120ea01bd73f49051ecde90d05e4127c6b",
"shasum": "" "shasum": ""
}, },
"require": { "require": {
@@ -1764,7 +1764,7 @@
"source": "https://github.com/hackerESQ/filter-models/tree/main", "source": "https://github.com/hackerESQ/filter-models/tree/main",
"issues": "https://github.com/hackerESQ/filter-models/issues" "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", "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']); Route::get('/me', [UserController::class, 'me']);
// portfolio // portfolio
Route::get('/portfolio', [PortfolioController::class, 'index']); Route::apiResource('/portfolio', PortfolioController::class);
// transaction // transaction
Route::get('/transaction', [TransactionController::class, 'index']); Route::get('/transaction', [TransactionController::class, 'index']);