Added endpoint to delete banners per location
DELETE /api/v1/summits/{id}/locations/{location_id}/banners/{banner_id} Required scopes * '%s/summits/write' * '%s/locations/write' * '%s/locations/banners/write' Change-Id: Ie5624461efed22419c8c4b39f529ea6805c4e448
This commit is contained in:
parent
3f91069e57
commit
dc8a44a14d
@ -29,7 +29,7 @@ final class HTMLCleaner
|
|||||||
{
|
{
|
||||||
$config = \HTMLPurifier_Config::createDefault();
|
$config = \HTMLPurifier_Config::createDefault();
|
||||||
// Remove any CSS or inline styles
|
// Remove any CSS or inline styles
|
||||||
$config->set('CSS.AllowedProperties', array());
|
$config->set('CSS.AllowedProperties', []);
|
||||||
$purifier = new \HTMLPurifier($config);
|
$purifier = new \HTMLPurifier($config);
|
||||||
foreach($fields as $field){
|
foreach($fields as $field){
|
||||||
if(!isset($data[$field])) continue;
|
if(!isset($data[$field])) continue;
|
||||||
|
@ -121,36 +121,6 @@ final class OAuth2SummitLocationsApiController extends OAuth2ProtectedController
|
|||||||
$this->summit_service = $summit_service;
|
$this->summit_service = $summit_service;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @param $filter_element
|
|
||||||
* @return bool
|
|
||||||
*/
|
|
||||||
private function validateClassName($filter_element){
|
|
||||||
if($filter_element instanceof FilterElement){
|
|
||||||
return in_array($filter_element->getValue(), SummitLocationConstants::$valid_class_names);
|
|
||||||
}
|
|
||||||
$valid = true;
|
|
||||||
foreach($filter_element[0] as $elem){
|
|
||||||
$valid = $valid && in_array($elem->getValue(), SummitLocationConstants::$valid_class_names);
|
|
||||||
}
|
|
||||||
return $valid;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param $filter_element
|
|
||||||
* @return bool
|
|
||||||
*/
|
|
||||||
private function validateBannerClassName($filter_element){
|
|
||||||
if($filter_element instanceof FilterElement){
|
|
||||||
return in_array($filter_element->getValue(), SummitLocationBannerConstants::$valid_class_names);
|
|
||||||
}
|
|
||||||
$valid = true;
|
|
||||||
foreach($filter_element[0] as $elem){
|
|
||||||
$valid = $valid && in_array($elem->getValue(), SummitLocationBannerConstants::$valid_class_names);
|
|
||||||
}
|
|
||||||
return $valid;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param $summit_id
|
* @param $summit_id
|
||||||
* @return mixed
|
* @return mixed
|
||||||
@ -202,6 +172,27 @@ final class OAuth2SummitLocationsApiController extends OAuth2ProtectedController
|
|||||||
'is_main' => ['=='],
|
'is_main' => ['=='],
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
if(is_null($filter)) $filter = new Filter();
|
||||||
|
|
||||||
|
$filter->validate([
|
||||||
|
'class_name' => sprintf('sometimes|in:%s',implode(',', SummitLocationConstants::$valid_class_names)),
|
||||||
|
'name' => 'sometimes|string',
|
||||||
|
'description' => 'sometimes|string',
|
||||||
|
'address_1' => 'sometimes|string',
|
||||||
|
'address_2' => 'sometimes|string',
|
||||||
|
'zip_code' => 'sometimes|string',
|
||||||
|
'city' => 'sometimes|string',
|
||||||
|
'state' => 'sometimes|string',
|
||||||
|
'country' => 'sometimes|string',
|
||||||
|
'sold_out' => 'sometimes|boolean',
|
||||||
|
'is_main' => 'sometimes|boolean',
|
||||||
|
], [
|
||||||
|
'class_name.in' => sprintf
|
||||||
|
(
|
||||||
|
":attribute has an invalid value ( valid values are %s )",
|
||||||
|
implode(", ", SummitLocationConstants::$valid_class_names)
|
||||||
|
)
|
||||||
|
]);
|
||||||
|
|
||||||
$order = null;
|
$order = null;
|
||||||
|
|
||||||
@ -214,18 +205,6 @@ final class OAuth2SummitLocationsApiController extends OAuth2ProtectedController
|
|||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(is_null($filter)) $filter = new Filter();
|
|
||||||
|
|
||||||
if($filter->hasFilter("class_name") && !$this->validateClassName($filter->getFilter("class_name"))){
|
|
||||||
throw new ValidationException(
|
|
||||||
sprintf
|
|
||||||
(
|
|
||||||
"class_name filter has an invalid value ( valid values are %s",
|
|
||||||
implode(", ", SummitLocationConstants::$valid_class_names)
|
|
||||||
)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
$data = $this->location_repository->getBySummit($summit, new PagingInfo($page, $per_page), $filter, $order);
|
$data = $this->location_repository->getBySummit($summit, new PagingInfo($page, $per_page), $filter, $order);
|
||||||
|
|
||||||
return $this->ok
|
return $this->ok
|
||||||
@ -278,7 +257,6 @@ final class OAuth2SummitLocationsApiController extends OAuth2ProtectedController
|
|||||||
$locations[] = SerializerRegistry::getInstance()->getSerializer($location)->serialize();
|
$locations[] = SerializerRegistry::getInstance()->getSerializer($location)->serialize();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
$response = new PagingResponse
|
$response = new PagingResponse
|
||||||
(
|
(
|
||||||
count($locations),
|
count($locations),
|
||||||
@ -769,16 +747,6 @@ final class OAuth2SummitLocationsApiController extends OAuth2ProtectedController
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!in_array($payload["class_name"], SummitLocationConstants::$valid_class_names) ){
|
|
||||||
throw new ValidationException(
|
|
||||||
sprintf
|
|
||||||
(
|
|
||||||
"class_name has an invalid value ( valid values are %s",
|
|
||||||
implode(", ", SummitLocationConstants::$valid_class_names)
|
|
||||||
)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
$location = $this->location_service->addLocation($summit, $payload);
|
$location = $this->location_service->addLocation($summit, $payload);
|
||||||
|
|
||||||
return $this->created(SerializerRegistry::getInstance()->getSerializer($location)->serialize());
|
return $this->created(SerializerRegistry::getInstance()->getSerializer($location)->serialize());
|
||||||
@ -1139,16 +1107,6 @@ final class OAuth2SummitLocationsApiController extends OAuth2ProtectedController
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!in_array($payload["class_name"], SummitLocationConstants::$valid_class_names) ){
|
|
||||||
throw new ValidationException(
|
|
||||||
sprintf
|
|
||||||
(
|
|
||||||
"class_name has an invalid value ( valid values are %s",
|
|
||||||
implode(", ", SummitLocationConstants::$valid_class_names)
|
|
||||||
)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
$location = $this->location_service->updateLocation($summit, $location_id, $payload);
|
$location = $this->location_service->updateLocation($summit, $location_id, $payload);
|
||||||
|
|
||||||
return $this->updated(SerializerRegistry::getInstance()->getSerializer($location)->serialize());
|
return $this->updated(SerializerRegistry::getInstance()->getSerializer($location)->serialize());
|
||||||
@ -1634,6 +1592,24 @@ final class OAuth2SummitLocationsApiController extends OAuth2ProtectedController
|
|||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(is_null($filter)) $filter = new Filter();
|
||||||
|
|
||||||
|
$filter->validate([
|
||||||
|
'class_name' => sprintf('sometimes|in:%s',implode(',', SummitLocationBannerConstants::$valid_class_names)),
|
||||||
|
'title' => 'sometimes|string',
|
||||||
|
'content' => 'sometimes|string',
|
||||||
|
'type' => sprintf('sometimes|in:%s',implode(',', SummitLocationBannerConstants::$valid_types)),
|
||||||
|
'enabled' => 'sometimes|boolean',
|
||||||
|
'start_date' => 'sometimes|date_format:U',
|
||||||
|
'end_date' => 'sometimes|date_format:U',
|
||||||
|
], [
|
||||||
|
'class_name.in' => sprintf
|
||||||
|
(
|
||||||
|
":attribute has an invalid value ( valid values are %s )",
|
||||||
|
implode(", ", SummitLocationBannerConstants::$valid_class_names)
|
||||||
|
)
|
||||||
|
]);
|
||||||
|
|
||||||
$order = null;
|
$order = null;
|
||||||
|
|
||||||
if (Input::has('order'))
|
if (Input::has('order'))
|
||||||
@ -1646,18 +1622,6 @@ final class OAuth2SummitLocationsApiController extends OAuth2ProtectedController
|
|||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(is_null($filter)) $filter = new Filter();
|
|
||||||
|
|
||||||
if($filter->hasFilter("class_name") && !$this->validateBannerClassName($filter->getFilter("class_name"))){
|
|
||||||
throw new ValidationException(
|
|
||||||
sprintf
|
|
||||||
(
|
|
||||||
"class_name filter has an invalid value ( valid values are %s",
|
|
||||||
implode(", ", SummitLocationBannerConstants::$valid_class_names)
|
|
||||||
)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
$data = $this->location_banners_repository->getBySummitLocation($location, new PagingInfo($page, $per_page), $filter, $order);
|
$data = $this->location_banners_repository->getBySummitLocation($location, new PagingInfo($page, $per_page), $filter, $order);
|
||||||
|
|
||||||
return $this->ok
|
return $this->ok
|
||||||
@ -1708,7 +1672,14 @@ final class OAuth2SummitLocationsApiController extends OAuth2ProtectedController
|
|||||||
|
|
||||||
$rules = SummitLocationBannerValidationRulesFactory::build($payload);
|
$rules = SummitLocationBannerValidationRulesFactory::build($payload);
|
||||||
// Creates a Validator instance and validates the data.
|
// Creates a Validator instance and validates the data.
|
||||||
$validation = Validator::make($payload, $rules);
|
$messages = [
|
||||||
|
'class_name.in' => sprintf
|
||||||
|
(
|
||||||
|
":attribute has an invalid value ( valid values are %s )",
|
||||||
|
implode(", ", SummitLocationBannerConstants::$valid_class_names)
|
||||||
|
)
|
||||||
|
];
|
||||||
|
$validation = Validator::make($payload, $rules, $messages);
|
||||||
|
|
||||||
if ($validation->fails()) {
|
if ($validation->fails()) {
|
||||||
$messages = $validation->messages()->toArray();
|
$messages = $validation->messages()->toArray();
|
||||||
@ -1719,17 +1690,15 @@ final class OAuth2SummitLocationsApiController extends OAuth2ProtectedController
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!in_array($payload["class_name"], SummitLocationBannerConstants::$valid_class_names) ){
|
$banner = $this->location_service->addLocationBanner
|
||||||
throw new ValidationException(
|
(
|
||||||
sprintf
|
$summit,
|
||||||
(
|
$location_id,
|
||||||
"class_name has an invalid value ( valid values are %s",
|
HTMLCleaner::cleanData
|
||||||
implode(", ", SummitLocationBannerConstants::$valid_class_names)
|
(
|
||||||
)
|
$payload, ['title', 'content']
|
||||||
);
|
)
|
||||||
}
|
);
|
||||||
|
|
||||||
$banner = $this->location_service->addLocationBanner($summit, $location_id, HTMLCleaner::cleanData($payload, ['title', 'content']));
|
|
||||||
|
|
||||||
return $this->created(SerializerRegistry::getInstance()->getSerializer($banner)->serialize());
|
return $this->created(SerializerRegistry::getInstance()->getSerializer($banner)->serialize());
|
||||||
}
|
}
|
||||||
@ -1747,4 +1716,39 @@ final class OAuth2SummitLocationsApiController extends OAuth2ProtectedController
|
|||||||
return $this->error500($ex);
|
return $this->error500($ex);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param $summit_id
|
||||||
|
* @param $location_id
|
||||||
|
* @param $banner_id
|
||||||
|
* @return mixed
|
||||||
|
*/
|
||||||
|
public function deleteLocationBanner($summit_id, $location_id, $banner_id){
|
||||||
|
try {
|
||||||
|
|
||||||
|
$summit = SummitFinderStrategyFactory::build($this->repository, $this->resource_server_context)->find($summit_id);
|
||||||
|
if (is_null($summit)) return $this->error404();
|
||||||
|
|
||||||
|
$this->location_service->deleteLocationBanner($summit, $location_id, $banner_id);
|
||||||
|
|
||||||
|
return $this->deleted();
|
||||||
|
}
|
||||||
|
catch (ValidationException $ex1) {
|
||||||
|
Log::warning($ex1);
|
||||||
|
return $this->error412([$ex1->getMessage()]);
|
||||||
|
}
|
||||||
|
catch(EntityNotFoundException $ex2)
|
||||||
|
{
|
||||||
|
Log::warning($ex2);
|
||||||
|
return $this->error404(['message'=> $ex2->getMessage()]);
|
||||||
|
}
|
||||||
|
catch (Exception $ex) {
|
||||||
|
Log::error($ex);
|
||||||
|
return $this->error500($ex);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function updateLocationBanner($summit, $location_id, $banner_id){
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
@ -33,18 +33,20 @@ final class SummitLocationBannerValidationRulesFactory
|
|||||||
throw new ValidationException('class_name is not set');
|
throw new ValidationException('class_name is not set');
|
||||||
|
|
||||||
$base_rules = [
|
$base_rules = [
|
||||||
'title' => 'required|string',
|
'class_name' => sprintf('required|in%s', implode(", ", SummitLocationBannerConstants::$valid_class_names)),
|
||||||
'content' => 'required|string',
|
'title' => 'required|string',
|
||||||
'type' => sprintf('required|in:%s', implode(",", SummitLocationBannerConstants::$valid_types)),
|
'content' => 'required|string',
|
||||||
'enabled' => 'required|boolean'
|
'type' => sprintf('required|in:%s', implode(",", SummitLocationBannerConstants::$valid_types)),
|
||||||
|
'enabled' => 'required|boolean'
|
||||||
];
|
];
|
||||||
|
|
||||||
if($update){
|
if($update){
|
||||||
$base_rules = [
|
$base_rules = [
|
||||||
'title' => 'sometimes|string',
|
'class_name' => sprintf('required|in%s', implode(", ", SummitLocationBannerConstants::$valid_class_names)),
|
||||||
'content' => 'sometimes|string',
|
'title' => 'sometimes|string',
|
||||||
'type' => sprintf('sometimes|in:%s', implode(",", SummitLocationBannerConstants::$valid_types)),
|
'content' => 'sometimes|string',
|
||||||
'enabled' => 'sometimes|boolean'
|
'type' => sprintf('sometimes|in:%s', implode(",", SummitLocationBannerConstants::$valid_types)),
|
||||||
|
'enabled' => 'sometimes|boolean'
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -11,6 +11,7 @@
|
|||||||
* See the License for the specific language governing permissions and
|
* See the License for the specific language governing permissions and
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
**/
|
**/
|
||||||
|
use App\Models\Foundation\Summit\Locations\SummitLocationConstants;
|
||||||
use models\exceptions\ValidationException;
|
use models\exceptions\ValidationException;
|
||||||
use models\summit\SummitAirport;
|
use models\summit\SummitAirport;
|
||||||
use models\summit\SummitExternalLocation;
|
use models\summit\SummitExternalLocation;
|
||||||
@ -32,26 +33,30 @@ final class SummitLocationValidationRulesFactory
|
|||||||
public static function build(array $data, $update = false){
|
public static function build(array $data, $update = false){
|
||||||
|
|
||||||
if(!isset($data['class_name']))
|
if(!isset($data['class_name']))
|
||||||
throw new ValidationException('class_name is not set');
|
throw new ValidationException('class_name is required');
|
||||||
|
|
||||||
|
$base_rules = [
|
||||||
|
'class_name' => sprintf('required|in:%s', implode(", ", SummitLocationConstants::$valid_class_names))
|
||||||
|
];
|
||||||
|
|
||||||
switch($data['class_name']){
|
switch($data['class_name']){
|
||||||
case SummitVenue::ClassName: {
|
case SummitVenue::ClassName: {
|
||||||
return SummitVenueValidationRulesFactory::build($data, $update);
|
return array_merge($base_rules, SummitVenueValidationRulesFactory::build($data, $update));
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case SummitAirport::ClassName: {
|
case SummitAirport::ClassName: {
|
||||||
return SummitAirportValidationRulesFactory::build($data, $update);
|
return array_merge($base_rules, SummitAirportValidationRulesFactory::build($data, $update));
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case SummitHotel::ClassName: {
|
case SummitHotel::ClassName: {
|
||||||
return SummitHotelValidationRulesFactory::build($data, $update);
|
return array_merge($base_rules, SummitHotelValidationRulesFactory::build($data, $update));
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case SummitExternalLocation::ClassName: {
|
case SummitExternalLocation::ClassName: {
|
||||||
return SummitExternalLocationValidationRulesFactory::build($data, $update);
|
return array_merge(SummitExternalLocationValidationRulesFactory::build($data, $update));
|
||||||
}
|
}
|
||||||
case SummitVenueRoom::ClassName: {
|
case SummitVenueRoom::ClassName: {
|
||||||
return SummitVenueRoomValidationRulesFactory::build($data, $update);
|
return array_merge(SummitVenueRoomValidationRulesFactory::build($data, $update));
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:{
|
default:{
|
||||||
|
@ -15,6 +15,8 @@
|
|||||||
|
|
||||||
use Doctrine\Common\Collections\Criteria;
|
use Doctrine\Common\Collections\Criteria;
|
||||||
use Doctrine\ORM\QueryBuilder;
|
use Doctrine\ORM\QueryBuilder;
|
||||||
|
use Illuminate\Support\Facades\Validator;
|
||||||
|
use models\exceptions\ValidationException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class Filter
|
* Class Filter
|
||||||
@ -25,12 +27,12 @@ final class Filter
|
|||||||
/**
|
/**
|
||||||
* @var array
|
* @var array
|
||||||
*/
|
*/
|
||||||
private $filters = array();
|
private $filters = [];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @var array
|
* @var array
|
||||||
*/
|
*/
|
||||||
private $bindings = array();
|
private $bindings = [];
|
||||||
|
|
||||||
public function __construct(array $filters = [])
|
public function __construct(array $filters = [])
|
||||||
{
|
{
|
||||||
@ -98,7 +100,7 @@ final class Filter
|
|||||||
*/
|
*/
|
||||||
public function getFlatFilter($field)
|
public function getFlatFilter($field)
|
||||||
{
|
{
|
||||||
$res = array();
|
$res = [];
|
||||||
foreach ($this->filters as $filter) {
|
foreach ($this->filters as $filter) {
|
||||||
|
|
||||||
if ($filter instanceof FilterElement && $filter->getField() === $field) {
|
if ($filter instanceof FilterElement && $filter->getField() === $field) {
|
||||||
@ -117,6 +119,55 @@ final class Filter
|
|||||||
return $res;
|
return $res;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public function getFiltersKeyValues(){
|
||||||
|
$res = [];
|
||||||
|
foreach ($this->filters as $filter) {
|
||||||
|
|
||||||
|
if ($filter instanceof FilterElement) {
|
||||||
|
$res[$filter->getField()] = $filter->getValue();
|
||||||
|
}
|
||||||
|
else if (is_array($filter)) {
|
||||||
|
// OR
|
||||||
|
foreach ($filter as $e) {
|
||||||
|
if ($e instanceof FilterElement) {
|
||||||
|
if(!isset($res[$e->getField()])) $res[$e->getField()] = [];
|
||||||
|
$res[$e->getField()][] = $e->getValue();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return $res;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array $rules
|
||||||
|
* @param array $messages
|
||||||
|
* @throws ValidationException
|
||||||
|
*/
|
||||||
|
public function validate(array $rules, array $messages){
|
||||||
|
$filter_key_values = $this->getFiltersKeyValues();
|
||||||
|
foreach($rules as $field => $rule) {
|
||||||
|
if(!isset($filter_key_values[$field])) continue;
|
||||||
|
$values = $filter_key_values[$field];
|
||||||
|
if(!is_array($values)) $values = [$values];
|
||||||
|
foreach ($values as $val) {
|
||||||
|
$validation = Validator::make
|
||||||
|
(
|
||||||
|
[$field => $val],
|
||||||
|
[$field => $rule],
|
||||||
|
$messages
|
||||||
|
);
|
||||||
|
if ($validation->fails()) {
|
||||||
|
$ex = new ValidationException();
|
||||||
|
throw $ex->setMessages($validation->messages()->toArray());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param Criteria $criteria
|
* @param Criteria $criteria
|
||||||
* @param array $mappings
|
* @param array $mappings
|
||||||
|
@ -1148,6 +1148,8 @@ final class OAuth2SummitLocationsApiTest extends ProtectedApiTest
|
|||||||
|
|
||||||
$banners = json_decode($content);
|
$banners = json_decode($content);
|
||||||
$this->assertTrue(!is_null($banners));
|
$this->assertTrue(!is_null($banners));
|
||||||
|
|
||||||
|
return $banners;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testGetLocationBannersFilterByClassName($summit_id = 23, $location_id = 315)
|
public function testGetLocationBannersFilterByClassName($summit_id = 23, $location_id = 315)
|
||||||
@ -1184,4 +1186,67 @@ final class OAuth2SummitLocationsApiTest extends ProtectedApiTest
|
|||||||
$banners = json_decode($content);
|
$banners = json_decode($content);
|
||||||
$this->assertTrue(!is_null($banners));
|
$this->assertTrue(!is_null($banners));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testGetLocationBannersFilterByInvalidClassName($summit_id = 23, $location_id = 315)
|
||||||
|
{
|
||||||
|
$params = [
|
||||||
|
'id' => $summit_id,
|
||||||
|
'location_id' => $location_id,
|
||||||
|
'page' => 1,
|
||||||
|
'per_page' => 5,
|
||||||
|
'order' => '-id',
|
||||||
|
'filter' => 'class_name==test,class_name==test2'
|
||||||
|
];
|
||||||
|
|
||||||
|
$headers =
|
||||||
|
[
|
||||||
|
"HTTP_Authorization" => " Bearer " . $this->access_token,
|
||||||
|
"CONTENT_TYPE" => "application/json"
|
||||||
|
];
|
||||||
|
|
||||||
|
$response = $this->action
|
||||||
|
(
|
||||||
|
"GET",
|
||||||
|
"OAuth2SummitLocationsApiController@getLocationBanners",
|
||||||
|
$params,
|
||||||
|
[],
|
||||||
|
[],
|
||||||
|
[],
|
||||||
|
$headers
|
||||||
|
);
|
||||||
|
|
||||||
|
$content = $response->getContent();
|
||||||
|
$this->assertResponseStatus(200);
|
||||||
|
|
||||||
|
$banners = json_decode($content);
|
||||||
|
$this->assertTrue(!is_null($banners));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testDeleteLocationBanner($summit_id = 23, $location_id = 315){
|
||||||
|
$banners = $this->testGetLocationBanners($summit_id, $location_id);
|
||||||
|
|
||||||
|
$params = [
|
||||||
|
'id' => $summit_id,
|
||||||
|
'location_id' => $location_id,
|
||||||
|
'banner_id' => $banners->data[0]->id
|
||||||
|
];
|
||||||
|
|
||||||
|
$headers = [
|
||||||
|
"HTTP_Authorization" => " Bearer " . $this->access_token,
|
||||||
|
"CONTENT_TYPE" => "application/json"
|
||||||
|
];
|
||||||
|
|
||||||
|
$response = $this->action(
|
||||||
|
"DELETE",
|
||||||
|
"OAuth2SummitLocationsApiController@deleteLocationBanner",
|
||||||
|
$params,
|
||||||
|
[],
|
||||||
|
[],
|
||||||
|
[],
|
||||||
|
$headers
|
||||||
|
);
|
||||||
|
|
||||||
|
$content = $response->getContent();
|
||||||
|
$this->assertResponseStatus(204);
|
||||||
|
}
|
||||||
}
|
}
|
Loading…
x
Reference in New Issue
Block a user