MongoGridFSCursor.php 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. <?php
  2. /*
  3. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  4. * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  5. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  6. * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
  7. * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  8. * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  9. * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  10. * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  11. * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  12. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  13. * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  14. */
  15. class MongoGridFSCursor extends MongoCursor
  16. {
  17. /**
  18. * @static
  19. * @var $slaveOkay
  20. */
  21. public static $slaveOkay;
  22. /**
  23. * @link http://php.net/manual/en/class.mongogridfscursor.php#mongogridfscursor.props.gridfs
  24. * @var $gridfs
  25. */
  26. protected $gridfs;
  27. /**
  28. * Create a new cursor
  29. *
  30. * @link http://php.net/manual/en/mongogridfscursor.construct.php
  31. * @param MongoGridFS $gridfs Related GridFS collection
  32. * @param MongoClient $connection Database connection
  33. * @param string $ns Full name of database and collection
  34. * @param array $query Database query
  35. * @param array $fields Fields to return
  36. * @return MongoGridFSCursor Returns the new cursor
  37. */
  38. public function __construct(MongoGridFS $gridfs, MongoClient $connection, $ns, array $query = array(), array $fields = array())
  39. {
  40. $this->gridfs = $gridfs;
  41. parent::__construct($connection, $ns, $query, $fields);
  42. }
  43. /**
  44. * Returns the current file
  45. *
  46. * @link http://php.net/manual/en/mongogridfscursor.current.php
  47. * @return MongoGridFSFile The current file
  48. */
  49. public function current()
  50. {
  51. $file = parent::current();
  52. return ($file !== null) ? new MongoGridFSFile($this->gridfs, $file) : null;
  53. }
  54. /**
  55. * Returns the current result's filename
  56. *
  57. * @link http://php.net/manual/en/mongogridfscursor.key.php
  58. * @return string The current results filename
  59. */
  60. public function key()
  61. {
  62. $file = $this->current();
  63. return ($file !== null) ? $file->getFilename() : null;
  64. }
  65. }