|  |  |  | <?php
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @link http://www.yiiframework.com/
 | 
					
						
							|  |  |  |  * @copyright Copyright (c) 2008 Yii Software LLC
 | 
					
						
							|  |  |  |  * @license http://www.yiiframework.com/license/
 | 
					
						
							|  |  |  |  */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace yii\mongo\file;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use Yii;
 | 
					
						
							|  |  |  | use yii\helpers\Json;
 | 
					
						
							|  |  |  | use yii\mongo\Exception;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Query represents Mongo "find" operation for GridFS collection.
 | 
					
						
							|  |  |  |  *
 | 
					
						
							|  |  |  |  * Query behaves exactly as regular [[\yii\mongo\Query]].
 | 
					
						
							|  |  |  |  * Found files will be represented as arrays of file document attributes with
 | 
					
						
							|  |  |  |  * additional 'file' key, which stores [[\MongoGridFSFile]] instance.
 | 
					
						
							|  |  |  |  *
 | 
					
						
							|  |  |  |  * @author Paul Klimov <klimov.paul@gmail.com>
 | 
					
						
							|  |  |  |  * @since 2.0
 | 
					
						
							|  |  |  |  */
 | 
					
						
							|  |  |  | class Query extends \yii\mongo\Query
 | 
					
						
							|  |  |  | {
 | 
					
						
							|  |  |  | 	/**
 | 
					
						
							|  |  |  | 	 * Returns the Mongo collection for this query.
 | 
					
						
							|  |  |  | 	 * @param \yii\mongo\Connection $db Mongo connection.
 | 
					
						
							|  |  |  | 	 * @return Collection collection instance.
 | 
					
						
							|  |  |  | 	 */
 | 
					
						
							|  |  |  | 	public function getCollection($db = null)
 | 
					
						
							|  |  |  | 	{
 | 
					
						
							|  |  |  | 		if ($db === null) {
 | 
					
						
							|  |  |  | 			$db = Yii::$app->getComponent('mongo');
 | 
					
						
							|  |  |  | 		}
 | 
					
						
							|  |  |  | 		return $db->getFileCollection($this->from);
 | 
					
						
							|  |  |  | 	}
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/**
 | 
					
						
							|  |  |  | 	 * @param \MongoGridFSCursor $cursor Mongo cursor instance to fetch data from.
 | 
					
						
							|  |  |  | 	 * @param boolean $all whether to fetch all rows or only first one.
 | 
					
						
							|  |  |  | 	 * @param string|callable $indexBy value to index by.
 | 
					
						
							|  |  |  | 	 * @return array|boolean result.
 | 
					
						
							|  |  |  | 	 * @see Query::fetchRows()
 | 
					
						
							|  |  |  | 	 */
 | 
					
						
							|  |  |  | 	protected function fetchRowsInternal($cursor, $all, $indexBy)
 | 
					
						
							|  |  |  | 	{
 | 
					
						
							|  |  |  | 		$result = [];
 | 
					
						
							|  |  |  | 		if ($all) {
 | 
					
						
							|  |  |  | 			foreach ($cursor as $file) {
 | 
					
						
							|  |  |  | 				$row = $file->file;
 | 
					
						
							|  |  |  | 				$row['file'] = $file;
 | 
					
						
							|  |  |  | 				if ($indexBy !== null) {
 | 
					
						
							|  |  |  | 					if (is_string($indexBy)) {
 | 
					
						
							|  |  |  | 						$key = $row[$indexBy];
 | 
					
						
							|  |  |  | 					} else {
 | 
					
						
							|  |  |  | 						$key = call_user_func($indexBy, $row);
 | 
					
						
							|  |  |  | 					}
 | 
					
						
							|  |  |  | 					$result[$key] = $row;
 | 
					
						
							|  |  |  | 				} else {
 | 
					
						
							|  |  |  | 					$result[] = $row;
 | 
					
						
							|  |  |  | 				}
 | 
					
						
							|  |  |  | 			}
 | 
					
						
							|  |  |  | 		} else {
 | 
					
						
							|  |  |  | 			if ($cursor->hasNext()) {
 | 
					
						
							|  |  |  | 				$file = $cursor->getNext();
 | 
					
						
							|  |  |  | 				$result = $file->file;
 | 
					
						
							|  |  |  | 				$result['file'] = $file;
 | 
					
						
							|  |  |  | 			} else {
 | 
					
						
							|  |  |  | 				$result = false;
 | 
					
						
							|  |  |  | 			}
 | 
					
						
							|  |  |  | 		}
 | 
					
						
							|  |  |  | 		return $result;
 | 
					
						
							|  |  |  | 	}
 | 
					
						
							|  |  |  | }
 |