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.
		
		
		
		
		
			
		
			
				
					
					
						
							172 lines
						
					
					
						
							4.9 KiB
						
					
					
				
			
		
		
	
	
							172 lines
						
					
					
						
							4.9 KiB
						
					
					
				| <?php | |
| /** | |
|  * @link http://www.yiiframework.com/ | |
|  * @copyright Copyright (c) 2008 Yii Software LLC | |
|  * @license http://www.yiiframework.com/license/ | |
|  */ | |
|  | |
| namespace yii\mongodb; | |
|  | |
| use yii\base\Object; | |
| use Yii; | |
| use yii\helpers\Json; | |
|  | |
| /** | |
|  * Database represents the Mongo database information. | |
|  * | |
|  * @property string $name name of this database. This property is read-only. | |
|  * | |
|  * @author Paul Klimov <klimov.paul@gmail.com> | |
|  * @since 2.0 | |
|  */ | |
| class Database extends Object | |
| { | |
| 	/** | |
| 	 * @var \MongoDB Mongo database instance. | |
| 	 */ | |
| 	public $mongoDb; | |
| 	/** | |
| 	 * @var Collection[] list of collections. | |
| 	 */ | |
| 	private $_collections = []; | |
| 	/** | |
| 	 * @var file\Collection[] list of GridFS collections. | |
| 	 */ | |
| 	private $_fileCollections = []; | |
|  | |
| 	/** | |
| 	 * @return string name of this database. | |
| 	 */ | |
| 	public function getName() | |
| 	{ | |
| 		return $this->mongoDb->__toString(); | |
| 	} | |
|  | |
| 	/** | |
| 	 * Returns the Mongo collection with the given name. | |
| 	 * @param string $name collection name | |
| 	 * @param boolean $refresh whether to reload the collection instance even if it is found in the cache. | |
| 	 * @return Collection Mongo collection instance. | |
| 	 */ | |
| 	public function getCollection($name, $refresh = false) | |
| 	{ | |
| 		if ($refresh || !array_key_exists($name, $this->_collections)) { | |
| 			$this->_collections[$name] = $this->selectCollection($name); | |
| 		} | |
| 		return $this->_collections[$name]; | |
| 	} | |
|  | |
| 	/** | |
| 	 * Returns Mongo GridFS collection with given prefix. | |
| 	 * @param string $prefix collection prefix. | |
| 	 * @param boolean $refresh whether to reload the collection instance even if it is found in the cache. | |
| 	 * @return file\Collection Mongo GridFS collection. | |
| 	 */ | |
| 	public function getFileCollection($prefix = 'fs', $refresh = false) | |
| 	{ | |
| 		if ($refresh || !array_key_exists($prefix, $this->_fileCollections)) { | |
| 			$this->_fileCollections[$prefix] = $this->selectFileCollection($prefix); | |
| 		} | |
| 		return $this->_fileCollections[$prefix]; | |
| 	} | |
|  | |
| 	/** | |
| 	 * Selects collection with given name. | |
| 	 * @param string $name collection name. | |
| 	 * @return Collection collection instance. | |
| 	 */ | |
| 	protected function selectCollection($name) | |
| 	{ | |
| 		return Yii::createObject([ | |
| 			'class' => 'yii\mongodb\Collection', | |
| 			'mongoCollection' => $this->mongoDb->selectCollection($name) | |
| 		]); | |
| 	} | |
|  | |
| 	/** | |
| 	 * Selects GridFS collection with given prefix. | |
| 	 * @param string $prefix file collection prefix. | |
| 	 * @return file\Collection file collection instance. | |
| 	 */ | |
| 	protected function selectFileCollection($prefix) | |
| 	{ | |
| 		return Yii::createObject([ | |
| 			'class' => 'yii\mongodb\file\Collection', | |
| 			'mongoCollection' => $this->mongoDb->getGridFS($prefix) | |
| 		]); | |
| 	} | |
|  | |
| 	/** | |
| 	 * Creates new collection. | |
| 	 * Note: Mongo creates new collections automatically on the first demand, | |
| 	 * this method makes sense only for the migration script or for the case | |
| 	 * you need to create collection with the specific options. | |
| 	 * @param string $name name of the collection | |
| 	 * @param array $options collection options in format: "name" => "value" | |
| 	 * @return \MongoCollection new Mongo collection instance. | |
| 	 * @throws Exception on failure. | |
| 	 */ | |
| 	public function createCollection($name, $options = []) | |
| 	{ | |
| 		$token = $this->getName() . '.create(' . $name . ', ' . Json::encode($options) . ')'; | |
| 		Yii::info($token, __METHOD__); | |
| 		try { | |
| 			Yii::beginProfile($token, __METHOD__); | |
| 			$result = $this->mongoDb->createCollection($name, $options); | |
| 			Yii::endProfile($token, __METHOD__); | |
| 			return $result; | |
| 		} catch (\Exception $e) { | |
| 			Yii::endProfile($token, __METHOD__); | |
| 			throw new Exception($e->getMessage(), (int)$e->getCode(), $e); | |
| 		} | |
| 	} | |
|  | |
| 	/** | |
| 	 * Executes Mongo command. | |
| 	 * @param array $command command specification. | |
| 	 * @param array $options options in format: "name" => "value" | |
| 	 * @return array database response. | |
| 	 * @throws Exception on failure. | |
| 	 */ | |
| 	public function executeCommand($command, $options = []) | |
| 	{ | |
| 		$token = $this->getName() . '.$cmd(' . Json::encode($command) . ', ' . Json::encode($options) . ')'; | |
| 		Yii::info($token, __METHOD__); | |
| 		try { | |
| 			Yii::beginProfile($token, __METHOD__); | |
| 			$result = $this->mongoDb->command($command, $options); | |
| 			$this->tryResultError($result); | |
| 			Yii::endProfile($token, __METHOD__); | |
| 			return $result; | |
| 		} catch (\Exception $e) { | |
| 			Yii::endProfile($token, __METHOD__); | |
| 			throw new Exception($e->getMessage(), (int)$e->getCode(), $e); | |
| 		} | |
| 	} | |
|  | |
| 	/** | |
| 	 * Checks if command execution result ended with an error. | |
| 	 * @param mixed $result raw command execution result. | |
| 	 * @throws Exception if an error occurred. | |
| 	 */ | |
| 	protected function tryResultError($result) | |
| 	{ | |
| 		if (is_array($result)) { | |
| 			if (!empty($result['errmsg'])) { | |
| 				$errorMessage = $result['errmsg']; | |
| 			} elseif (!empty($result['err'])) { | |
| 				$errorMessage = $result['err']; | |
| 			} | |
| 			if (isset($errorMessage)) { | |
| 				if (array_key_exists('ok', $result)) { | |
| 					$errorCode = (int)$result['ok']; | |
| 				} else { | |
| 					$errorCode = 0; | |
| 				} | |
| 				throw new Exception($errorMessage, $errorCode); | |
| 			} | |
| 		} elseif (!$result) { | |
| 			throw new Exception('Unknown error, use "w=1" option to enable error tracking'); | |
| 		} | |
| 	} | |
| } |