|  |  |  | <?php
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @link http://www.yiiframework.com/
 | 
					
						
							|  |  |  |  * @copyright Copyright (c) 2008 Yii Software LLC
 | 
					
						
							|  |  |  |  * @license http://www.yiiframework.com/license/
 | 
					
						
							|  |  |  |  */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace yii\mongodb\file;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use yii\mongodb\Exception;
 | 
					
						
							|  |  |  | use Yii;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Collection represents the Mongo GridFS collection information.
 | 
					
						
							|  |  |  |  *
 | 
					
						
							|  |  |  |  * A file collection object is usually created by calling [[Database::getFileCollection()]] or [[Connection::getFileCollection()]].
 | 
					
						
							|  |  |  |  *
 | 
					
						
							|  |  |  |  * File collection inherits all interface from regular [[\yii\mongo\Collection]], adding methods to store files.
 | 
					
						
							|  |  |  |  *
 | 
					
						
							|  |  |  |  * @property \yii\mongodb\Collection $chunkCollection Mongo collection instance. This property is read-only.
 | 
					
						
							|  |  |  |  *
 | 
					
						
							|  |  |  |  * @author Paul Klimov <klimov.paul@gmail.com>
 | 
					
						
							|  |  |  |  * @since 2.0
 | 
					
						
							|  |  |  |  */
 | 
					
						
							|  |  |  | class Collection extends \yii\mongodb\Collection
 | 
					
						
							|  |  |  | {
 | 
					
						
							|  |  |  | 	/**
 | 
					
						
							|  |  |  | 	 * @var \MongoGridFS Mongo GridFS collection instance.
 | 
					
						
							|  |  |  | 	 */
 | 
					
						
							|  |  |  | 	public $mongoCollection;
 | 
					
						
							|  |  |  | 	/**
 | 
					
						
							|  |  |  | 	 * @var \yii\mongodb\Collection file chunks Mongo collection.
 | 
					
						
							|  |  |  | 	 */
 | 
					
						
							|  |  |  | 	private $_chunkCollection;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/**
 | 
					
						
							|  |  |  | 	 * Returns the Mongo collection for the file chunks.
 | 
					
						
							|  |  |  | 	 * @param boolean $refresh whether to reload the collection instance even if it is found in the cache.
 | 
					
						
							|  |  |  | 	 * @return \yii\mongodb\Collection mongo collection instance.
 | 
					
						
							|  |  |  | 	 */
 | 
					
						
							|  |  |  | 	public function getChunkCollection($refresh = false)
 | 
					
						
							|  |  |  | 	{
 | 
					
						
							|  |  |  | 		if ($refresh || !is_object($this->_chunkCollection)) {
 | 
					
						
							|  |  |  | 			$this->_chunkCollection = Yii::createObject([
 | 
					
						
							|  |  |  | 				'class' => 'yii\mongodb\Collection',
 | 
					
						
							|  |  |  | 				'mongoCollection' => $this->mongoCollection->chunks
 | 
					
						
							|  |  |  | 			]);
 | 
					
						
							|  |  |  | 		}
 | 
					
						
							|  |  |  | 		return $this->_chunkCollection;
 | 
					
						
							|  |  |  | 	}
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/**
 | 
					
						
							|  |  |  | 	 * Removes data from the collection.
 | 
					
						
							|  |  |  | 	 * @param array $condition description of records to remove.
 | 
					
						
							|  |  |  | 	 * @param array $options list of options in format: optionName => optionValue.
 | 
					
						
							|  |  |  | 	 * @return integer|boolean number of updated documents or whether operation was successful.
 | 
					
						
							|  |  |  | 	 * @throws Exception on failure.
 | 
					
						
							|  |  |  | 	 */
 | 
					
						
							|  |  |  | 	public function remove($condition = [], $options = [])
 | 
					
						
							|  |  |  | 	{
 | 
					
						
							|  |  |  | 		$result = parent::remove($condition, $options);
 | 
					
						
							|  |  |  | 		$this->tryLastError(); // MongoGridFS::remove will return even if the remove failed
 | 
					
						
							|  |  |  | 		return $result;
 | 
					
						
							|  |  |  | 	}
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/**
 | 
					
						
							|  |  |  | 	 * Creates new file in GridFS collection from given local filesystem file.
 | 
					
						
							|  |  |  | 	 * Additional attributes can be added file document using $metadata.
 | 
					
						
							|  |  |  | 	 * @param string $filename name of the file to store.
 | 
					
						
							|  |  |  | 	 * @param array $metadata other metadata fields to include in the file document.
 | 
					
						
							|  |  |  | 	 * @param array $options list of options in format: optionName => optionValue
 | 
					
						
							|  |  |  | 	 * @return mixed the "_id" of the saved file document. This will be a generated [[\MongoId]]
 | 
					
						
							|  |  |  | 	 * unless an "_id" was explicitly specified in the metadata.
 | 
					
						
							|  |  |  | 	 * @throws Exception on failure.
 | 
					
						
							|  |  |  | 	 */
 | 
					
						
							|  |  |  | 	public function insertFile($filename, $metadata = [], $options = [])
 | 
					
						
							|  |  |  | 	{
 | 
					
						
							|  |  |  | 		$token = 'Inserting file into ' . $this->getFullName();
 | 
					
						
							|  |  |  | 		Yii::info($token, __METHOD__);
 | 
					
						
							|  |  |  | 		try {
 | 
					
						
							|  |  |  | 			Yii::beginProfile($token, __METHOD__);
 | 
					
						
							|  |  |  | 			$options = array_merge(['w' => 1], $options);
 | 
					
						
							|  |  |  | 			$result = $this->mongoCollection->storeFile($filename, $metadata, $options);
 | 
					
						
							|  |  |  | 			Yii::endProfile($token, __METHOD__);
 | 
					
						
							|  |  |  | 			return $result;
 | 
					
						
							|  |  |  | 		} catch (\Exception $e) {
 | 
					
						
							|  |  |  | 			Yii::endProfile($token, __METHOD__);
 | 
					
						
							|  |  |  | 			throw new Exception($e->getMessage(), (int)$e->getCode(), $e);
 | 
					
						
							|  |  |  | 		}
 | 
					
						
							|  |  |  | 	}
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/**
 | 
					
						
							|  |  |  | 	 * Creates new file in GridFS collection with specified content.
 | 
					
						
							|  |  |  | 	 * Additional attributes can be added file document using $metadata.
 | 
					
						
							|  |  |  | 	 * @param string $bytes string of bytes to store.
 | 
					
						
							|  |  |  | 	 * @param array $metadata other metadata fields to include in the file document.
 | 
					
						
							|  |  |  | 	 * @param array $options list of options in format: optionName => optionValue
 | 
					
						
							|  |  |  | 	 * @return mixed the "_id" of the saved file document. This will be a generated [[\MongoId]]
 | 
					
						
							|  |  |  | 	 * unless an "_id" was explicitly specified in the metadata.
 | 
					
						
							|  |  |  | 	 * @throws Exception on failure.
 | 
					
						
							|  |  |  | 	 */
 | 
					
						
							|  |  |  | 	public function insertFileContent($bytes, $metadata = [], $options = [])
 | 
					
						
							|  |  |  | 	{
 | 
					
						
							|  |  |  | 		$token = 'Inserting file content into ' . $this->getFullName();
 | 
					
						
							|  |  |  | 		Yii::info($token, __METHOD__);
 | 
					
						
							|  |  |  | 		try {
 | 
					
						
							|  |  |  | 			Yii::beginProfile($token, __METHOD__);
 | 
					
						
							|  |  |  | 			$options = array_merge(['w' => 1], $options);
 | 
					
						
							|  |  |  | 			$result = $this->mongoCollection->storeBytes($bytes, $metadata, $options);
 | 
					
						
							|  |  |  | 			Yii::endProfile($token, __METHOD__);
 | 
					
						
							|  |  |  | 			return $result;
 | 
					
						
							|  |  |  | 		} catch (\Exception $e) {
 | 
					
						
							|  |  |  | 			Yii::endProfile($token, __METHOD__);
 | 
					
						
							|  |  |  | 			throw new Exception($e->getMessage(), (int)$e->getCode(), $e);
 | 
					
						
							|  |  |  | 		}
 | 
					
						
							|  |  |  | 	}
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/**
 | 
					
						
							|  |  |  | 	 * Creates new file in GridFS collection from uploaded file.
 | 
					
						
							|  |  |  | 	 * Additional attributes can be added file document using $metadata.
 | 
					
						
							|  |  |  | 	 * @param string $name name of the uploaded file to store. This should correspond to
 | 
					
						
							|  |  |  | 	 * the file field's name attribute in the HTML form.
 | 
					
						
							|  |  |  | 	 * @param array $metadata other metadata fields to include in the file document.
 | 
					
						
							|  |  |  | 	 * @return mixed the "_id" of the saved file document. This will be a generated [[\MongoId]]
 | 
					
						
							|  |  |  | 	 * unless an "_id" was explicitly specified in the metadata.
 | 
					
						
							|  |  |  | 	 * @throws Exception on failure.
 | 
					
						
							|  |  |  | 	 */
 | 
					
						
							|  |  |  | 	public function insertUploads($name, $metadata = [])
 | 
					
						
							|  |  |  | 	{
 | 
					
						
							|  |  |  | 		$token = 'Inserting file uploads into ' . $this->getFullName();
 | 
					
						
							|  |  |  | 		Yii::info($token, __METHOD__);
 | 
					
						
							|  |  |  | 		try {
 | 
					
						
							|  |  |  | 			Yii::beginProfile($token, __METHOD__);
 | 
					
						
							|  |  |  | 			$result = $this->mongoCollection->storeUpload($name, $metadata);
 | 
					
						
							|  |  |  | 			Yii::endProfile($token, __METHOD__);
 | 
					
						
							|  |  |  | 			return $result;
 | 
					
						
							|  |  |  | 		} catch (\Exception $e) {
 | 
					
						
							|  |  |  | 			Yii::endProfile($token, __METHOD__);
 | 
					
						
							|  |  |  | 			throw new Exception($e->getMessage(), (int)$e->getCode(), $e);
 | 
					
						
							|  |  |  | 		}
 | 
					
						
							|  |  |  | 	}
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/**
 | 
					
						
							|  |  |  | 	 * Retrieves the file with given _id.
 | 
					
						
							|  |  |  | 	 * @param mixed $id _id of the file to find.
 | 
					
						
							|  |  |  | 	 * @return \MongoGridFSFile|null found file, or null if file does not exist
 | 
					
						
							|  |  |  | 	 * @throws Exception on failure.
 | 
					
						
							|  |  |  | 	 */
 | 
					
						
							|  |  |  | 	public function get($id)
 | 
					
						
							|  |  |  | 	{
 | 
					
						
							|  |  |  | 		$token = 'Inserting file uploads into ' . $this->getFullName();
 | 
					
						
							|  |  |  | 		Yii::info($token, __METHOD__);
 | 
					
						
							|  |  |  | 		try {
 | 
					
						
							|  |  |  | 			Yii::beginProfile($token, __METHOD__);
 | 
					
						
							|  |  |  | 			$result = $this->mongoCollection->get($id);
 | 
					
						
							|  |  |  | 			Yii::endProfile($token, __METHOD__);
 | 
					
						
							|  |  |  | 			return $result;
 | 
					
						
							|  |  |  | 		} catch (\Exception $e) {
 | 
					
						
							|  |  |  | 			Yii::endProfile($token, __METHOD__);
 | 
					
						
							|  |  |  | 			throw new Exception($e->getMessage(), (int)$e->getCode(), $e);
 | 
					
						
							|  |  |  | 		}
 | 
					
						
							|  |  |  | 	}
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/**
 | 
					
						
							|  |  |  | 	 * Deletes the file with given _id.
 | 
					
						
							|  |  |  | 	 * @param mixed $id _id of the file to find.
 | 
					
						
							|  |  |  | 	 * @return boolean whether the operation was successful.
 | 
					
						
							|  |  |  | 	 * @throws Exception on failure.
 | 
					
						
							|  |  |  | 	 */
 | 
					
						
							|  |  |  | 	public function delete($id)
 | 
					
						
							|  |  |  | 	{
 | 
					
						
							|  |  |  | 		$token = 'Inserting file uploads into ' . $this->getFullName();
 | 
					
						
							|  |  |  | 		Yii::info($token, __METHOD__);
 | 
					
						
							|  |  |  | 		try {
 | 
					
						
							|  |  |  | 			Yii::beginProfile($token, __METHOD__);
 | 
					
						
							|  |  |  | 			$result = $this->mongoCollection->delete($id);
 | 
					
						
							|  |  |  | 			$this->tryResultError($result);
 | 
					
						
							|  |  |  | 			Yii::endProfile($token, __METHOD__);
 | 
					
						
							|  |  |  | 			return true;
 | 
					
						
							|  |  |  | 		} catch (\Exception $e) {
 | 
					
						
							|  |  |  | 			Yii::endProfile($token, __METHOD__);
 | 
					
						
							|  |  |  | 			throw new Exception($e->getMessage(), (int)$e->getCode(), $e);
 | 
					
						
							|  |  |  | 		}
 | 
					
						
							|  |  |  | 	}
 | 
					
						
							|  |  |  | }
 |