wip
This commit is contained in:
@@ -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'],
|
||||
];
|
||||
}
|
||||
}
|
||||
@@ -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
@@ -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
@@ -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']);
|
||||
|
||||
Reference in New Issue
Block a user