Added endpoint Create My Speaker

Creates a default speaker profile for current member

POST /api/v1/speakers/me

required scopes

'%s/speakers/write/me'

Change-Id: I51e8c3af523c999b31a943af01cf135b42398b39
This commit is contained in:
Sebastian Marcet 2018-07-25 15:06:19 -03:00
parent 71b774bea4
commit f1c9e40a17
7 changed files with 104 additions and 3 deletions

View File

@ -356,6 +356,59 @@ final class OAuth2SummitSpeakersApiController extends OAuth2ProtectedController
}
}
/**
* @return mixed
*/
public function createMySpeaker(){
try
{
$current_member_id = $this->resource_server_context->getCurrentUserExternalId();
if(is_null($current_member_id))
return $this->error403();
$member = $this->member_repository->getById($current_member_id);
if(is_null($member))
return $this->error403();
// set data from current member ...
$speaker = $this->service->addSpeaker([
'member_id' => $member->getIdentifier(),
'first_name' => $member->getFirstName(),
'last_name' => $member->getLastName(),
'bio' => $member->getBio(),
'twitter' => $member->getTwitterHandle(),
'irc' => $member->getIrcHandle(),
]);
$serializer_type = $this->serializer_type_selector->getSerializerType();
return $this->ok
(
SerializerRegistry::getInstance()->getSerializer($speaker, $serializer_type)->serialize
(
Request::input('expand', ''),
[],
[],
[]
)
);
}
catch(ValidationException $ex1){
Log::warning($ex1);
return $this->error412($ex1->getMessages());
}
catch(EntityNotFoundException $ex2)
{
Log::warning($ex2);
return $this->error404(array('message'=> $ex2->getMessage()));
}
catch (Exception $ex) {
Log::error($ex);
return $this->error500($ex);
}
}
/**
* @param $speaker_id
* @return mixed

View File

@ -515,7 +515,12 @@ Route::group([
Route::get('', 'OAuth2SummitSpeakersApiController@getAll');
Route::post('', [ 'middleware' => 'auth.user:administrators|summit-front-end-administrators', 'uses' => 'OAuth2SummitSpeakersApiController@addSpeaker']);
Route::put('merge/{speaker_from_id}/{speaker_to_id}', 'OAuth2SummitSpeakersApiController@merge');
Route::get('me', 'OAuth2SummitSpeakersApiController@getMySpeaker');
Route::group(['prefix' => 'me'], function(){
Route::get('', 'OAuth2SummitSpeakersApiController@getMySpeaker');
Route::post('', 'OAuth2SummitSpeakersApiController@createMySpeaker');
});
Route::group(['prefix' => '{speaker_id}'], function () {
Route::put('',[ 'middleware' => 'auth.user:administrators|summit-front-end-administrators', 'uses' => 'OAuth2SummitSpeakersApiController@updateSpeaker'])->where('speaker_id', 'me|[0-9]+');
Route::delete('',[ 'middleware' => 'auth.user:administrators|summit-front-end-administrators', 'uses' => 'OAuth2SummitSpeakersApiController@deleteSpeaker'])->where('speaker_id', 'me|[0-9]+');

View File

@ -25,6 +25,7 @@ final class SummitScopes
const WriteSummitData = '%s/summits/write';
const WriteSpeakersData = '%s/speakers/write';
const WriteMySpeakersData = '%s/speakers/write/me';
const PublishEventData = '%s/summits/publish-event';
const WriteEventData = '%s/summits/write-event';

View File

@ -320,6 +320,14 @@ class ApiEndpointsSeeder extends Seeder
sprintf(SummitScopes::ReadAllSummitData, $current_realm)
],
),
array(
'name' => 'create-my-speaker',
'route' => '/api/v1/speakers/me',
'http_method' => 'POST',
'scopes' => [
sprintf(SummitScopes::WriteMySpeakersData, $current_realm),
],
),
array(
'name' => 'merge-speakers',
'route' => '/api/v1/speakers/merge/{speaker_from_id}/{speaker_to_id}',

View File

@ -113,11 +113,16 @@ final class ApiScopesSeeder extends Seeder
'short_description' => 'Write Speakers Data',
'description' => 'Grants write access for Speakers Data',
),
array(
[
'name' => sprintf(SummitScopes::WriteMySpeakersData, $current_realm),
'short_description' => 'Write My Speakers Profile Data',
'description' => 'Grants write access for My Speaker Profile Data',
],
[
'name' => sprintf(SummitScopes::WriteAttendeesData, $current_realm),
'short_description' => 'Write Attendees Data',
'description' => 'Grants write access for Attendees Data',
),
],
[
'name' => sprintf(SummitScopes::WritePromoCodeData, $current_realm),
'short_description' => 'Write Promo Codes Data',

View File

@ -446,6 +446,33 @@ final class OAuth2SpeakersApiTest extends ProtectedApiTest
$this->assertTrue(!is_null($speaker));
}
public function testCreateMySpeaker(){
$params = [
];
$headers = [
"HTTP_Authorization" => " Bearer " . $this->access_token,
"CONTENT_TYPE" => "application/json"
];
$response = $this->action(
"POST",
"OAuth2SummitSpeakersApiController@createMySpeaker",
$params,
[],
[],
[],
$headers
);
$content = $response->getContent();
$this->assertResponseStatus(412);
$error = json_decode($content);
$this->assertTrue(!is_null($error));
}
public function testMergeSpeakers(){
$params = [

View File

@ -57,6 +57,7 @@ class AccessTokenServiceStub implements IAccessTokenService
$url . '/me/summits/events/favorites/add',
$url . '/me/summits/events/favorites/delete',
sprintf(SummitScopes::WriteSpeakersData, $url),
sprintf(SummitScopes::WriteMySpeakersData, $url),
sprintf(SummitScopes::WriteAttendeesData, $url),
sprintf(SummitScopes::WriteMemberData, $url),
sprintf(SummitScopes::WritePromoCodeData, $url),
@ -105,6 +106,7 @@ class AccessTokenServiceStub2 implements IAccessTokenService
$url . '/me/summits/events/favorites/add',
$url . '/me/summits/events/favorites/delete',
sprintf(SummitScopes::WriteSpeakersData, $url),
sprintf(SummitScopes::WriteMySpeakersData, $url),
sprintf(SummitScopes::WriteAttendeesData, $url),
sprintf(SummitScopes::WriteMemberData, $url),
sprintf(SummitScopes::WritePromoCodeData, $url),