Sebastian Marcet 2306382478 Added new endpoint for admin get attendee by id
GET /api/v1/summits/{id}/attendees/{attendee_id}

expand

* member,schedule,tickets,affiliations,groups

Change-Id: I62546e427f723271de563a72676d46b075c34461
2018-01-12 01:05:38 -03:00

40 lines
1.5 KiB
PHP

<?php namespace App\Http\Controllers;
/**
* Copyright 2015 OpenStack Foundation
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
* http://www.apache.org/licenses/LICENSE-2.0
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
**/
use models\oauth2\IResourceServerContext;
use models\summit\Summit;
use models\summit\SummitAttendee;
/**
* Class CheckMyOwnAttendeeStrategy
* @package App\Http\Controllers
*/
final class CheckMyOwnAttendeeStrategy extends CheckMeAttendeeStrategy implements ICheckAttendeeStrategy
{
/**
* @param int $attendee_id
* @param Summit $summit
* @return null|SummitAttendee
* @throws \HTTP401UnauthorizedException
*/
public function check($attendee_id, Summit $summit)
{
$attendee = parent::check($attendee_id, $summit);
if(!$attendee) return null;
$attendee_member_id = intval($attendee->getMember()->getId());
$member_id = $this->resource_server_context->getCurrentUserExternalId();
if(is_null($member_id) || ($attendee_member_id !== $member_id))
throw new \HTTP401UnauthorizedException;
return $attendee;
}
}