Add call to get user's PIREPs #192
This commit is contained in:
parent
5c58dfe1ae
commit
3d9d17d9b9
@ -2,6 +2,9 @@
|
|||||||
|
|
||||||
namespace App\Http\Controllers\Api;
|
namespace App\Http\Controllers\Api;
|
||||||
|
|
||||||
|
use App\Models\Enums\PirepState;
|
||||||
|
use App\Repositories\Criteria\WhereCriteria;
|
||||||
|
use App\Repositories\PirepRepository;
|
||||||
use App\Repositories\SubfleetRepository;
|
use App\Repositories\SubfleetRepository;
|
||||||
use App\Services\UserService;
|
use App\Services\UserService;
|
||||||
use Auth;
|
use Auth;
|
||||||
@ -11,27 +14,46 @@ use App\Repositories\UserRepository;
|
|||||||
|
|
||||||
use App\Models\UserBid;
|
use App\Models\UserBid;
|
||||||
|
|
||||||
use App\Http\Resources\Subfleet as SubfleetResource;
|
|
||||||
use App\Http\Resources\Flight as FlightResource;
|
use App\Http\Resources\Flight as FlightResource;
|
||||||
|
use App\Http\Resources\Pirep as PirepResource;
|
||||||
|
use App\Http\Resources\Subfleet as SubfleetResource;
|
||||||
use App\Http\Resources\User as UserResource;
|
use App\Http\Resources\User as UserResource;
|
||||||
|
use Prettus\Repository\Criteria\RequestCriteria;
|
||||||
|
use Prettus\Repository\Exceptions\RepositoryException;
|
||||||
|
|
||||||
|
|
||||||
class UserController extends RestController
|
class UserController extends RestController
|
||||||
{
|
{
|
||||||
protected $subfleetRepo,
|
protected $pirepRepo,
|
||||||
|
$subfleetRepo,
|
||||||
$userRepo,
|
$userRepo,
|
||||||
$userSvc;
|
$userSvc;
|
||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
|
PirepRepository $pirepRepo,
|
||||||
SubfleetRepository $subfleetRepo,
|
SubfleetRepository $subfleetRepo,
|
||||||
UserRepository $userRepo,
|
UserRepository $userRepo,
|
||||||
UserService $userSvc
|
UserService $userSvc
|
||||||
) {
|
) {
|
||||||
|
$this->pirepRepo = $pirepRepo;
|
||||||
$this->subfleetRepo = $subfleetRepo;
|
$this->subfleetRepo = $subfleetRepo;
|
||||||
$this->userRepo = $userRepo;
|
$this->userRepo = $userRepo;
|
||||||
$this->userSvc = $userSvc;
|
$this->userSvc = $userSvc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param Request $request
|
||||||
|
* @return int|mixed
|
||||||
|
*/
|
||||||
|
protected function getUserId(Request $request)
|
||||||
|
{
|
||||||
|
if ($request->id === null) {
|
||||||
|
return Auth::user()->id;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $request->id;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return the profile for the currently auth'd user
|
* Return the profile for the currently auth'd user
|
||||||
*/
|
*/
|
||||||
@ -68,16 +90,37 @@ class UserController extends RestController
|
|||||||
*/
|
*/
|
||||||
public function fleet(Request $request)
|
public function fleet(Request $request)
|
||||||
{
|
{
|
||||||
if($request->id === null) {
|
$user = $this->userRepo->find($this->getUserId($request));
|
||||||
$id = Auth::user()->id;
|
|
||||||
} else {
|
|
||||||
$id = $request->id;
|
|
||||||
}
|
|
||||||
|
|
||||||
$user = $this->userRepo->find($id);
|
|
||||||
$subfleets = $this->userSvc->getAllowableSubfleets($user);
|
$subfleets = $this->userSvc->getAllowableSubfleets($user);
|
||||||
|
|
||||||
return SubfleetResource::collection($subfleets);
|
return SubfleetResource::collection($subfleets);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param Request $request
|
||||||
|
* @return \Illuminate\Http\Resources\Json\AnonymousResourceCollection
|
||||||
|
* @throws RepositoryException
|
||||||
|
*/
|
||||||
|
public function pireps(Request $request)
|
||||||
|
{
|
||||||
|
$this->pirepRepo->pushCriteria(new RequestCriteria($request));
|
||||||
|
|
||||||
|
$where = [
|
||||||
|
'user_id' => $this->getUserId($request),
|
||||||
|
];
|
||||||
|
|
||||||
|
if(filled($request->query('state'))) {
|
||||||
|
$where['state'] = $request->query('state');
|
||||||
|
} else {
|
||||||
|
$where[] = ['state', '!=', PirepState::CANCELLED];
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->pirepRepo->pushCriteria(new WhereCriteria($request, $where));
|
||||||
|
|
||||||
|
$pireps = $this->pirepRepo
|
||||||
|
->orderBy('created_at', 'desc')
|
||||||
|
->paginate();
|
||||||
|
|
||||||
|
return PirepResource::collection($pireps);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -6,8 +6,8 @@ namespace App\Models\Enums;
|
|||||||
class PirepState extends EnumBase {
|
class PirepState extends EnumBase {
|
||||||
|
|
||||||
public const REJECTED = -1;
|
public const REJECTED = -1;
|
||||||
public const IN_PROGRESS = 0;
|
public const IN_PROGRESS = 0; // flight is ongoing
|
||||||
public const PENDING = 1;
|
public const PENDING = 1; // waiting admin approval
|
||||||
public const ACCEPTED = 2;
|
public const ACCEPTED = 2;
|
||||||
public const CANCELLED = 3;
|
public const CANCELLED = 3;
|
||||||
public const DELETED = 4;
|
public const DELETED = 4;
|
||||||
|
@ -62,9 +62,11 @@ Route::group(['middleware' => ['api.auth']], function ()
|
|||||||
# This is the info of the user whose token is in use
|
# This is the info of the user whose token is in use
|
||||||
Route::get('user', 'UserController@index');
|
Route::get('user', 'UserController@index');
|
||||||
Route::get('user/fleet', 'UserController@fleet');
|
Route::get('user/fleet', 'UserController@fleet');
|
||||||
|
Route::get('user/pireps', 'UserController@pireps');
|
||||||
|
|
||||||
Route::get('users/{id}', 'UserController@get');
|
Route::get('users/{id}', 'UserController@get');
|
||||||
Route::get('users/{id}/bids', 'UserController@bids');
|
Route::get('users/{id}/bids', 'UserController@bids');
|
||||||
Route::get('users/{id}/fleet', 'UserController@fleet');
|
Route::get('users/{id}/fleet', 'UserController@fleet');
|
||||||
|
Route::get('users/{id}/pireps', 'UserController@pireps');
|
||||||
|
|
||||||
});
|
});
|
||||||
|
@ -113,6 +113,48 @@ class PIREPTest extends TestCase
|
|||||||
$this->assertEquals($route, $saved_route);
|
$this->assertEquals($route, $saved_route);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public function testGetUserPireps()
|
||||||
|
{
|
||||||
|
$this->user = factory(App\Models\User::class)->create();
|
||||||
|
$pirep_done = factory(App\Models\Pirep::class)->create([
|
||||||
|
'user_id' => $this->user->id,
|
||||||
|
'state' => PirepState::ACCEPTED
|
||||||
|
]);
|
||||||
|
|
||||||
|
$pirep_in_progress = factory(App\Models\Pirep::class)->create([
|
||||||
|
'user_id' => $this->user->id,
|
||||||
|
'state' => PirepState::IN_PROGRESS
|
||||||
|
]);
|
||||||
|
|
||||||
|
$pirep_cancelled = factory(App\Models\Pirep::class)->create([
|
||||||
|
'user_id' => $this->user->id,
|
||||||
|
'state' => PirepState::CANCELLED
|
||||||
|
]);
|
||||||
|
|
||||||
|
$pireps = $this->get('/api/user/pireps')
|
||||||
|
->assertStatus(200)
|
||||||
|
->json();
|
||||||
|
|
||||||
|
$pirep_ids = collect($pireps['data'])->pluck('id');
|
||||||
|
|
||||||
|
$this->assertTrue($pirep_ids->contains($pirep_done->id));
|
||||||
|
$this->assertTrue($pirep_ids->contains($pirep_in_progress->id));
|
||||||
|
$this->assertFalse($pirep_ids->contains($pirep_cancelled->id));
|
||||||
|
|
||||||
|
// Get only status
|
||||||
|
$pireps = $this->get('/api/user/pireps?state='.PirepState::IN_PROGRESS)
|
||||||
|
->assertStatus(200)
|
||||||
|
->json();
|
||||||
|
|
||||||
|
$pirep_ids = collect($pireps['data'])->pluck('id');
|
||||||
|
$this->assertTrue($pirep_ids->contains($pirep_in_progress->id));
|
||||||
|
$this->assertFalse($pirep_ids->contains($pirep_done->id));
|
||||||
|
$this->assertFalse($pirep_ids->contains($pirep_cancelled->id));
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* check the stats/ranks, etc have incremented properly
|
* check the stats/ranks, etc have incremented properly
|
||||||
*/
|
*/
|
||||||
|
Loading…
Reference in New Issue
Block a user