e5b161a997
added new parsing logic for query attribute so if user wants to expand the fields of a relations ( many 2 one, one 2 one , and so) it should add . to the name of the relation like ?expand=location,location.venue that will expand the location venue. Change-Id: I6c50d10e793f017da9146dbce5c5e86a631d9224
97 lines
3.3 KiB
PHP
97 lines
3.3 KiB
PHP
<?php namespace ModelSerializers\Locations;
|
|
/**
|
|
* Copyright 2016 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 Libs\ModelSerializers\AbstractSerializer;
|
|
use models\summit\SummitVenue;
|
|
use ModelSerializers\SerializerRegistry;
|
|
|
|
|
|
/**
|
|
* Class SummitVenueSerializer
|
|
* @package ModelSerializers\Locations
|
|
*/
|
|
final class SummitVenueSerializer extends SummitGeoLocatedLocationSerializer
|
|
{
|
|
protected static $array_mappings = array
|
|
(
|
|
'IsMain' => 'is_main::json_boolean',
|
|
);
|
|
|
|
/**
|
|
* @param null $expand
|
|
* @param array $fields
|
|
* @param array $relations
|
|
* @param array $params
|
|
* @return array
|
|
*/
|
|
public function serialize($expand = null, array $fields = array(), array $relations = array(), array $params = array() )
|
|
{
|
|
$values = parent::serialize($expand, $fields, $relations, $params);
|
|
$venue = $this->object;
|
|
if(!$venue instanceof SummitVenue) return [];
|
|
// rooms
|
|
$rooms = [];
|
|
foreach($venue->getRooms() as $room)
|
|
{
|
|
$rooms[] = $room->getId();
|
|
}
|
|
|
|
if(count($rooms) > 0)
|
|
$values['rooms'] = $rooms;
|
|
|
|
// floors
|
|
$floors = [];
|
|
foreach($venue->getFloors() as $floor)
|
|
{
|
|
$floors[] = $floor->getId();
|
|
}
|
|
|
|
if(count($floors) > 0)
|
|
$values['floors'] = $floors;
|
|
|
|
if (!empty($expand)) {
|
|
foreach (explode(',', $expand) as $relation) {
|
|
$relation = trim($relation);
|
|
switch ($relation) {
|
|
case 'rooms':
|
|
{
|
|
if($venue->hasRooms()) {
|
|
$rooms = [];
|
|
foreach ($venue->getRooms() as $room) {
|
|
$rooms[] = SerializerRegistry::getInstance()->getSerializer($room)->serialize(AbstractSerializer::filterExpandByPrefix($expand, $relation));
|
|
}
|
|
$values['rooms'] = $rooms;
|
|
}
|
|
}
|
|
break;
|
|
case 'floors':
|
|
{
|
|
if($venue->hasFloors()) {
|
|
$floors = [];
|
|
foreach ($venue->getFloors() as $floor) {
|
|
$floors[] = SerializerRegistry::getInstance()->getSerializer($floor)->serialize(AbstractSerializer::filterExpandByPrefix($expand, $relation));
|
|
}
|
|
$values['floors'] = $floors;
|
|
}
|
|
}
|
|
break;
|
|
|
|
}
|
|
}
|
|
}
|
|
|
|
return $values;
|
|
}
|
|
|
|
} |