Mango::GridFS::Reader(3) GridFS reader

SYNOPSIS


use Mango::GridFS::Reader;
my $reader = Mango::GridFS::Reader->new(gridfs => $gridfs);

DESCRIPTION

Mango::GridFS::Reader reads files from GridFS.

ATTRIBUTES

Mango::GridFS::Reader implements the following attributes.

gridfs

  my $gridfs = $reader->gridfs;
  $reader    = $reader->gridfs(Mango::GridFS->new);

Mango::GridFS object this reader belongs to.

METHODS

Mango::GridFS::Reader inherits all methods from Mojo::Base and implements the following new ones.

chunk_size

  my $size = $reader->chunk_size;

Chunk size in bytes.

content_type

  my $type = $reader->content_type;

Content type of file.

filename

  my $name = $reader->filename;

Name of file.

md5

  my $checksum = $reader->md5;

MD5 checksum for file.

metadata

  my $data = $reader->metadata;

Additional information.

open

  $reader = $reader->open($oid);

Open file. You can also append a callback to perform operation non-blocking.

  $reader->open($oid => sub {
    my ($reader, $err) = @_;
    ...
  });
  Mojo::IOLoop->start unless Mojo::IOLoop->is_running;

read

  my $chunk = $reader->read;

Read chunk. You can also append a callback to perform operation non-blocking.

  $reader->read(sub {
    my ($reader, $err, $chunk) = @_;
    ...
  });
  Mojo::IOLoop->start unless Mojo::IOLoop->is_running;

seek

  $reader = $reader->seek(13);

Change current position.

size

  my $size = $reader->size;

Size of entire file in bytes.

slurp

  my $data = $reader->slurp;

Slurp all remaining data from file. You can also append a callback to perform operation non-blocking.

  $reader->slurp(sub {
    my ($reader, $err, $data) = @_;
    ...
  });
  Mojo::IOLoop->start unless Mojo::IOLoop->is_running;

tell

  my $pos = $reader->tell;

Current position.

upload_date

  my $time = $reader->upload_date;

Date file was uploaded.