You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							185 lines
						
					
					
						
							6.4 KiB
						
					
					
				
			
		
		
	
	
							185 lines
						
					
					
						
							6.4 KiB
						
					
					
				<?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); | 
						|
		} | 
						|
	} | 
						|
} |