MongoGridFSCursor.php 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  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. */
  37. public function __construct(MongoGridFS $gridfs, MongoClient $connection, $ns, array $query = array(), array $fields = array())
  38. {
  39. $this->gridfs = $gridfs;
  40. parent::__construct($connection, $ns, $query, $fields);
  41. }
  42. /**
  43. * Returns the current file
  44. *
  45. * @link http://php.net/manual/en/mongogridfscursor.current.php
  46. * @return MongoGridFSFile The current file
  47. */
  48. public function current()
  49. {
  50. $file = parent::current();
  51. return ($file !== null) ? new MongoGridFSFile($this->gridfs, $file) : null;
  52. }
  53. /**
  54. * Returns the current result's filename
  55. *
  56. * @link http://php.net/manual/en/mongogridfscursor.key.php
  57. * @return string The current results filename
  58. */
  59. public function key()
  60. {
  61. $file = $this->current();
  62. return ($file !== null) ? (string)$file->file['_id'] : null;
  63. }
  64. }