mirror of
				https://github.com/alchemy-fr/Phraseanet.git
				synced 2025-10-25 02:43:11 +00:00 
			
		
		
		
	 0c75189a64
			
		
	
	0c75189a64
	
	
	
		
			
			- refactor : acl strings changed to ACL class constants - code cleanup - wip but try to merge for bc break test
		
			
				
	
	
		
			275 lines
		
	
	
		
			7.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			275 lines
		
	
	
		
			7.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| /*
 | |
|  * This file is part of Phraseanet
 | |
|  *
 | |
|  * (c) 2005-2016 Alchemy
 | |
|  *
 | |
|  * For the full copyright and license information, please view the LICENSE
 | |
|  * file that was distributed with this source code.
 | |
|  */
 | |
| 
 | |
| namespace Alchemy\Phrasea\Controller;
 | |
| 
 | |
| use Alchemy\Phrasea\Model\Entities\Basket;
 | |
| use Doctrine\Common\Collections\ArrayCollection;
 | |
| use Alchemy\Phrasea\Application;
 | |
| use record_adapter;
 | |
| use Symfony\Component\HttpFoundation\Request;
 | |
| use Symfony\Component\HttpKernel\Exception\NotFoundHttpException;
 | |
| 
 | |
| class RecordsRequest extends ArrayCollection
 | |
| {
 | |
|     protected $isSingleStory = false;
 | |
|     protected $received;
 | |
|     protected $basket;
 | |
|     protected $databoxes;
 | |
|     protected $collections;
 | |
| 
 | |
|     const FLATTEN_NO = false;
 | |
|     const FLATTEN_YES = true;
 | |
|     const FLATTEN_YES_PRESERVE_STORIES = 'preserve';
 | |
| 
 | |
|     /**
 | |
|      * Constructor
 | |
|      *
 | |
|      * @param array           $elements
 | |
|      * @param ArrayCollection $received
 | |
|      * @param Basket          $basket
 | |
|      * @param Boolean         $flatten
 | |
|      */
 | |
|     public function __construct(array $elements, ArrayCollection $received, Basket $basket = null, $flatten = self::FLATTEN_NO)
 | |
|     {
 | |
|         parent::__construct($elements);
 | |
|         $this->received = $received;
 | |
|         $this->basket = $basket;
 | |
|         $this->isSingleStory = ($flatten !== self::FLATTEN_YES && 1 === count($this) && $this->first()->isStory());
 | |
| 
 | |
|         if (self::FLATTEN_NO !== $flatten) {
 | |
|             $to_remove = [];
 | |
|             /** @var record_adapter $record */
 | |
|             foreach ($this as $key => $record) {
 | |
|                 if ($record->isStory()) {
 | |
|                     if (self::FLATTEN_YES === $flatten) {
 | |
|                         $to_remove[] = $key;
 | |
|                     }
 | |
|                     foreach ($record->getChildren() as $child) {
 | |
|                         $this->set($child->getId(), $child);
 | |
|                     }
 | |
|                 }
 | |
|             }
 | |
| 
 | |
|             foreach ($to_remove as $key) {
 | |
|                 $this->remove($key);
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         $i = 0;
 | |
|         $records = $this->toArray();
 | |
|         array_walk($records, function (\record_adapter $record) use (&$i) {
 | |
|             $record->setNumber($i++);
 | |
|         });
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return all distinct databoxes related to the contained records
 | |
|      *
 | |
|      * @return \databox[]
 | |
|      */
 | |
|     public function databoxes()
 | |
|     {
 | |
|         if (!$this->databoxes) {
 | |
|             $this->databoxes = [];
 | |
| 
 | |
|             foreach ($this as $record) {
 | |
|                 if (false === array_key_exists($record->get_databox()->get_sbas_id(), $this->databoxes)) {
 | |
|                     $this->databoxes[$record->get_databox()->get_sbas_id()] = $record->get_databox();
 | |
|                 }
 | |
|             }
 | |
| 
 | |
|             $this->databoxes = array_values($this->databoxes);
 | |
|         }
 | |
| 
 | |
|         return $this->databoxes;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return all distinct collections related to the contained records
 | |
|      *
 | |
|      * @return \collection[]
 | |
|      */
 | |
|     public function collections()
 | |
|     {
 | |
|         if (!$this->collections) {
 | |
|             $this->collections = [];
 | |
| 
 | |
|             /** @var \record_adapter $record */
 | |
|             foreach ($this as $record) {
 | |
|                 if (! isset($this->collections[$record->getBaseId()])) {
 | |
|                     $this->collections[$record->getBaseId()] = $record->get_collection();
 | |
|                 }
 | |
|             }
 | |
| 
 | |
|             $this->collections = array_values($this->collections);
 | |
|         }
 | |
| 
 | |
|         return $this->collections;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return all received records
 | |
|      *
 | |
|      * @return \record_adapter[]|ArrayCollection
 | |
|      */
 | |
|     public function received()
 | |
|     {
 | |
|         return $this->received;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return basket entity if provided, null otherwise
 | |
|      *
 | |
|      * @return Basket|null
 | |
|      */
 | |
|     public function basket()
 | |
|     {
 | |
|         return $this->basket;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Filter contents and return only stories
 | |
|      *
 | |
|      * @return ArrayCollection
 | |
|      */
 | |
|     public function stories()
 | |
|     {
 | |
|         return new ArrayCollection(
 | |
|                 array_filter($this->toArray(), function (\record_adapter $record) {
 | |
|                         return $record->isStory();
 | |
|                     })
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return true if the request contains a single story
 | |
|      *
 | |
|      * @return Boolean
 | |
|      */
 | |
|     public function isSingleStory()
 | |
|     {
 | |
|         return $this->isSingleStory;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return the first story if a single story is contained, null otherwise
 | |
|      *
 | |
|      * @return \record_adapter|null
 | |
|      */
 | |
|     public function singleStory()
 | |
|     {
 | |
|         if ($this->isSingleStory()) {
 | |
|             return $this->first();
 | |
|         }
 | |
| 
 | |
|         return null;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return a serialized list of elements
 | |
|      *
 | |
|      * @return string
 | |
|      */
 | |
|     public function serializedList()
 | |
|     {
 | |
|         if ($this->isSingleStory()) {
 | |
|             return $this->singleStory()->getId();
 | |
|         }
 | |
| 
 | |
|         $basrec = [];
 | |
|         foreach ($this as $record) {
 | |
|             $basrec[] = $record->get_serialize_key();
 | |
|         }
 | |
| 
 | |
|         return implode(';', $basrec);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Create a new RecordRequest from current request
 | |
|      *
 | |
|      * @param  Application    $app
 | |
|      * @param  Request        $request
 | |
|      * @param  boolean        $flattenStories
 | |
|      * @param  array          $rightsColl
 | |
|      * @param  array          $rightsDatabox
 | |
|      * @return RecordsRequest|\record_adapter[]
 | |
|      */
 | |
|     public static function fromRequest(Application $app, Request $request, $flattenStories = self::FLATTEN_NO, array $rightsColl = [], array $rightsDatabox = [])
 | |
|     {
 | |
|         $elements = $received = [];
 | |
|         $basket = null;
 | |
| 
 | |
|         if ($request->get('ssel')) {
 | |
|             $basket = $app['converter.basket']->convert($request->get('ssel'));
 | |
|             $app['acl.basket']->hasAccess($basket, $app->getAuthenticatedUser());
 | |
| 
 | |
|             foreach ($basket->getElements() as $basket_element) {
 | |
|                 $received[$basket_element->getRecord($app)->getId()] = $basket_element->getRecord($app);
 | |
|             }
 | |
|         } elseif ($request->get('story')) {
 | |
|             $repository = $app['repo.story-wz'];
 | |
| 
 | |
|             $storyWZ = $repository->findByUserAndId(
 | |
|                 $app, $app->getAuthenticatedUser(),
 | |
|                 $request->get('story')
 | |
|             );
 | |
| 
 | |
|             $received[$storyWZ->getRecord($app)->get_serialize_key()] = $storyWZ->getRecord($app);
 | |
|         } else {
 | |
|             foreach (explode(";", $request->get('lst')) as $bas_rec) {
 | |
|                 $basrec = explode('_', $bas_rec);
 | |
|                 if (count($basrec) != 2) {
 | |
|                     continue;
 | |
|                 }
 | |
|                 try {
 | |
|                     $record = new \record_adapter($app, (int) $basrec[0], (int) $basrec[1]);
 | |
|                     $received[$record->getId()] = $record;
 | |
|                     unset($record);
 | |
|                 } catch (NotFoundHttpException $e) {
 | |
|                     continue;
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         $elements = $received;
 | |
| 
 | |
|         $to_remove = [];
 | |
| 
 | |
|         foreach ($elements as $id => $record) {
 | |
|             if (!$app->getAclForUser($app->getAuthenticatedUser())->has_access_to_record($record)) {
 | |
|                 $to_remove[] = $id;
 | |
|                 continue;
 | |
|             }
 | |
| 
 | |
|             foreach ($rightsColl as $right) {
 | |
|                 if (!$app->getAclForUser($app->getAuthenticatedUser())->has_right_on_base($record->get_base_id(), $right)) {
 | |
|                     $to_remove[] = $id;
 | |
|                     continue;
 | |
|                 }
 | |
|             }
 | |
| 
 | |
|             foreach ($rightsDatabox as $right) {
 | |
|                 if (!$app->getAclForUser($app->getAuthenticatedUser())->has_right_on_sbas($record->get_sbas_id(), $right)) {
 | |
|                     $to_remove[] = $id;
 | |
|                     continue;
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         foreach ($to_remove as $id) {
 | |
|             unset($elements[$id]);
 | |
|         }
 | |
| 
 | |
|         return new static($elements, new ArrayCollection($received), $basket, $flattenStories);
 | |
|     }
 | |
| }
 |