Added Clone event endpoint
POST /api/v1/summits/{id}/events/{event_id}/clone scopes %s/summits/write-event Change-Id: Ifda70bae5f211a91daae047a71e922210710f6af
This commit is contained in:
parent
0ea6ebee77
commit
87e99197ed
@ -1163,4 +1163,37 @@ final class OAuth2SummitEventsApiController extends OAuth2ProtectedController
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @param $summit_id
|
||||
* @param $event_id
|
||||
* @return mixed
|
||||
*/
|
||||
public function cloneEvent($summit_id, $event_id)
|
||||
{
|
||||
try {
|
||||
$summit = SummitFinderStrategyFactory::build($this->repository, $this->resource_server_context)->find($summit_id);
|
||||
if (is_null($summit)) return $this->error404();
|
||||
|
||||
$event = $this->service->cloneEvent($summit, $event_id);
|
||||
|
||||
return $this->created(SerializerRegistry::getInstance()->getSerializer($event)->serialize());
|
||||
|
||||
}
|
||||
catch (ValidationException $ex1)
|
||||
{
|
||||
Log::warning($ex1);
|
||||
return $this->error412(array($ex1->getMessage()));
|
||||
}
|
||||
catch(EntityNotFoundException $ex2)
|
||||
{
|
||||
Log::warning($ex2);
|
||||
return $this->error404(array('message'=> $ex2->getMessage()));
|
||||
}
|
||||
catch (Exception $ex) {
|
||||
Log::error($ex);
|
||||
return $this->error500($ex);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
}
|
@ -243,6 +243,7 @@ Route::group([
|
||||
Route::post('', [ 'middleware' => 'auth.user:administrators|summit-front-end-administrators', 'uses' => 'OAuth2SummitEventsApiController@addEvent']);
|
||||
Route::group(array('prefix' => '{event_id}'), function () {
|
||||
|
||||
Route::post('/clone', [ 'middleware' => 'auth.user:administrators|summit-front-end-administrators', 'uses' => 'OAuth2SummitEventsApiController@cloneEvent']);
|
||||
Route::get('', 'OAuth2SummitEventsApiController@getEvent');
|
||||
Route::get('/published', [ 'middleware' => 'cache:'.Config::get('cache_api_response.get_published_event_response_lifetime', 300), 'uses' => 'OAuth2SummitEventsApiController@getScheduledEvent']);
|
||||
Route::put('', [ 'middleware' => 'auth.user:administrators|summit-front-end-administrators|summit-room-administrators', 'uses' => 'OAuth2SummitEventsApiController@updateEvent' ]);
|
||||
|
@ -37,6 +37,7 @@ final class SummitEventFactory
|
||||
$event = new SummitEventWithFile();
|
||||
|
||||
$event->setSummit($summit);
|
||||
$event->setType($type);
|
||||
|
||||
return $event;
|
||||
}
|
||||
|
@ -263,4 +263,14 @@ interface ISummitService
|
||||
*/
|
||||
public function removeModeratorFromPresentation($current_member_id, $speaker_id, $presentation_id);
|
||||
|
||||
|
||||
/**
|
||||
* @param Summit $summit
|
||||
* @param int $event_id
|
||||
* @return SummitEvent
|
||||
* @throws ValidationException
|
||||
* @throws EntityNotFoundException
|
||||
*/
|
||||
public function cloneEvent(Summit $summit, int $event_id):SummitEvent;
|
||||
|
||||
}
|
@ -1836,4 +1836,63 @@ final class SummitService extends AbstractService implements ISummitService
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* @param Summit $summit
|
||||
* @param int $event_id
|
||||
* @return SummitEvent
|
||||
* @throws ValidationException
|
||||
* @throws EntityNotFoundException
|
||||
*/
|
||||
public function cloneEvent(Summit $summit, int $event_id): SummitEvent
|
||||
{
|
||||
return $this->tx_service->transaction(function () use ($summit, $event_id) {
|
||||
|
||||
$event = $this->event_repository->getById($event_id);
|
||||
if(is_null($event))
|
||||
throw new EntityNotFoundException(sprintf("event %s not found!", $event_id));
|
||||
|
||||
if($event instanceof Presentation)
|
||||
throw new ValidationException(sprintf("event %s is not allowed to be cloned!", $event_id));
|
||||
|
||||
$eventClone = SummitEventFactory::build($event->getType(), $summit);
|
||||
|
||||
$eventClone->setTitle($event->getTitle());
|
||||
$eventClone->setAbstract($event->getAbstract());
|
||||
$eventClone->setLocation($event->getLocation());
|
||||
$eventClone->setAllowFeedBack($event->getAllowFeedback());
|
||||
$eventClone->setSocialSummary($event->getSocialSummary());
|
||||
$eventClone->setStartDate($event->getLocalStartDate());
|
||||
$eventClone->setEndDate($event->getLocalEndDate());
|
||||
$eventClone->setCategory($event->getCategory());
|
||||
|
||||
if($event->hasRSVPTemplate())
|
||||
{
|
||||
$eventClone->setRSVPTemplate($event->getRSVPTemplate());
|
||||
}
|
||||
|
||||
if($event->isExternalRSVP())
|
||||
{
|
||||
$eventClone->setRSVPLink($event->getRSVPLink());
|
||||
}
|
||||
|
||||
foreach($event->getSponsors() as $sponsor){
|
||||
$eventClone->addSponsor($sponsor);
|
||||
}
|
||||
|
||||
foreach($event->getTags() as $tag){
|
||||
$eventClone->addTag($tag);
|
||||
}
|
||||
|
||||
// check if SummitEventWithFile
|
||||
|
||||
if($event instanceof SummitEventWithFile && $event->hasAttachment()){
|
||||
$eventClone->setAttachment($event->getAttachment());
|
||||
}
|
||||
|
||||
$this->event_repository->add($eventClone);
|
||||
|
||||
return $eventClone;
|
||||
|
||||
});
|
||||
}
|
||||
}
|
@ -583,6 +583,12 @@ class ApiEndpointsSeeder extends Seeder
|
||||
'http_method' => 'PUT',
|
||||
'scopes' => [sprintf(SummitScopes::WriteEventData, $current_realm)],
|
||||
],
|
||||
[
|
||||
'name' => 'clone-event',
|
||||
'route' => '/api/v1/summits/{id}/events/{event_id}/clone',
|
||||
'http_method' => 'POST',
|
||||
'scopes' => [sprintf(SummitScopes::WriteEventData, $current_realm)],
|
||||
],
|
||||
[
|
||||
'name' => 'update-events',
|
||||
'route' => '/api/v1/summits/{id}/events',
|
||||
|
@ -1335,4 +1335,35 @@ final class OAuth2SummitEventsApiTest extends ProtectedApiTest
|
||||
|
||||
}
|
||||
|
||||
public function testCloneEvent($summit_id = 25, $event_id= 22943)
|
||||
{
|
||||
$params = [
|
||||
|
||||
'id' => $summit_id,
|
||||
'event_id' => $event_id,
|
||||
];
|
||||
|
||||
$headers = [
|
||||
|
||||
"HTTP_Authorization" => " Bearer " . $this->access_token,
|
||||
"CONTENT_TYPE" => "application/json"
|
||||
];
|
||||
|
||||
$response = $this->action
|
||||
(
|
||||
"POST",
|
||||
"OAuth2SummitEventsApiController@cloneEvent",
|
||||
$params,
|
||||
[], [], [],
|
||||
$headers
|
||||
);
|
||||
|
||||
$content = $response->getContent();
|
||||
$this->assertResponseStatus(201);
|
||||
$event = json_decode($content);
|
||||
$this->assertTrue($event->id > 0);
|
||||
return $event;
|
||||
}
|
||||
|
||||
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user