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