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:
parent
71b774bea4
commit
f1c9e40a17
|
@ -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
|
||||
|
|
|
@ -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]+');
|
||||
|
|
|
@ -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';
|
||||
|
|
|
@ -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}',
|
||||
|
|
|
@ -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',
|
||||
|
|
|
@ -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 = [
|
||||
|
|
|
@ -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),
|
||||
|
|
Loading…
Reference in New Issue