openstackid-resources/app/Http/Controllers/Apis/Protected/Summit/Strategies/CheckMyOwnAttendeeStrategy.php
smarcet f1b4ce63ff Updated Resource Server Context to retrive User
by external user

this is a change required after this update

https://review.opendev.org/#/c/661661/

Change-Id: I13283c0a491ffb924d67bdeac84b5adcf3afe45c
2019-07-28 18:14:19 -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());
$current_member = $this->resource_server_context->getCurrentUser();
if(is_null($current_member) || ($attendee_member_id !== $current_member->getId()))
throw new \HTTP401UnauthorizedException;
return $attendee;
}
}