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.
109 lines
3.6 KiB
109 lines
3.6 KiB
<?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\mongo\Exception; |
|
|
|
/** |
|
* Collection represents the Mongo GridFS collection information. |
|
* |
|
* @method \MongoGridFSCursor find() returns a cursor for the search results. |
|
* |
|
* @author Paul Klimov <klimov.paul@gmail.com> |
|
* @since 2.0 |
|
*/ |
|
class Collection extends \yii\mongo\Collection |
|
{ |
|
/** |
|
* @var \MongoGridFS Mongo GridFS collection instance. |
|
*/ |
|
public $mongoCollection; |
|
|
|
/** |
|
* 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; |
|
} |
|
|
|
/** |
|
* @param string $filename name of the file to store. |
|
* @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. |
|
*/ |
|
public function put($filename, $metadata = []) |
|
{ |
|
return $this->mongoCollection->put($filename, $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. |
|
*/ |
|
public function storeBytes($bytes, $metadata = [], $options = []) |
|
{ |
|
$options = array_merge(['w' => 1], $options); |
|
return $this->mongoCollection->storeBytes($bytes, $metadata, $options); |
|
} |
|
|
|
/** |
|
* @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. |
|
*/ |
|
public function storeFile($filename, $metadata = [], $options = []) |
|
{ |
|
$options = array_merge(['w' => 1], $options); |
|
return $this->mongoCollection->storeFile($filename, $metadata, $options); |
|
} |
|
|
|
/** |
|
* @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. |
|
*/ |
|
public function storeUploads($name, $metadata = []) |
|
{ |
|
return $this->mongoCollection->storeUpload($name, $metadata); |
|
} |
|
|
|
/** |
|
* @param mixed $id _id of the file to find. |
|
* @return \MongoGridFSFile|null found file, or null if file does not exist |
|
*/ |
|
public function get($id) |
|
{ |
|
return $this->mongoCollection->get($id); |
|
} |
|
|
|
/** |
|
* @param mixed $id _id of the file to find. |
|
* @return boolean whether the operation was successful. |
|
*/ |
|
public function delete($id) |
|
{ |
|
$result = $this->mongoCollection->delete($id); |
|
$this->tryResultError($result); |
|
return true; |
|
} |
|
} |