Net::Douban::Review - Net::Douban::Review documentation


Net-Douban documentation Contained in the Net-Douban distribution.

Index


Code Index:

NAME

Top

Net::Douban::Subject

VERSION

Top

version 1.07

SYNOPSIS

Top

	use Net::Douban::Subject;
	my $user = Net::Douban::Review->new(
		apikey => '....',
        # or
        oauth => $consumer,
	);

	$atom = $user->get_review(reviewID => 1138468);
    $atom = $user->get_user_review(userID => '2265138', start_index => 5, max_results => 10);

DESCRIPTION

Top

Interface to douban.com API Review section

METHODS

Top

Those methods return a Net::Douban::Atom object which can be use to get data conveniently

get_review
get_user_review

userID required

get_book_review
get_moview_review
get_music_review
post_review

post XML required

put_review

modify your review, reviewID and put XML required

delete_review

reviewID required

SEE ALSO

Top

Net::Douban Net::Douban::Atom Moose XML::Atom http://www.douban.com/service/apidoc/reference/review

AUTHOR

Top

woosley.xu<redicaps@gmail.com>

COPYRIGHT

Top


Net-Douban documentation Contained in the Net-Douban distribution.

package Net::Douban::Review;

BEGIN {
    $Net::Douban::Review::VERSION = '1.07';
}

use Moose;
use MooseX::StrictConstructor;
use Net::Douban::Atom;
use Carp qw/carp croak/;
with 'Net::Douban::Roles::More';

has 'reviewID' => (
    is  => 'rw',
    isa => 'Str',
);

has 'review_url' => (
    is      => 'rw',
    isa     => 'Url',
    lazy    => 1,
    default => sub { shift->base_url . '/review' }
);

sub get_review {
    my ($self, %args) = @_;
    $args{reviewID} ||= $self->reviewID;
    croak "reviewID missing" unless exists $args{reviewID};
    return Net::Douban::Atom->new(
        $self->get($self->review_url . "/$args{reviewID}"));
}

sub get_user_review {
    my ($self, %args) = @_;
    my $uid = delete $args{userID};
    croak "userID missing" unless defined $uid;
    return Net::Douban::Atom->new(
        $self->get($self->user_url . "/$uid/reviews", %args));
}

sub get_book_review {
    my ($self, %args) = @_;
    my $subjectID = delete $args{subjectID};
    my $isbnID    = delete $args{isbnID};
    my $url       = $self->base_url . "/book/subject";
    croak "Missing parameters: isbnID or subjectID needed"
      unless defined $subjectID
          or defined $isbnID;
    if ($isbnID) {
        $url .= "/isbn/$isbnID/reviews";
    } else {
        $url .= "/$subjectID/reviews";
    }
    return Net::Douban::Atom->new($self->get($url, %args));
}

sub get_movie_review {
    my ($self, %args) = @_;
    my $subjectID = delete $args{subjectID};
    my $imdbID    = delete $args{imdbID};
    my $url       = $self->base_url . "/movie/subject";
    croak "Missing parameters: imdbID or subjectID needed"
      unless defined $subjectID
          or defined $imdbID;
    if ($imdbID) {
        $url .= "/imdb/$imdbID/reviews";
    } else {
        $url .= "/$subjectID/reviews";
    }
    return Net::Douban::Atom->new($self->get($url, %args));
}

sub get_music_review {
    my ($self, %args) = @_;
    my $subjectID = delete $args{subjectID};
    croak "Missing parameters:  subjectID needed"
      unless defined $subjectID;
    return Net::Douban::Atom->new(
        $self->get(
            $self->base_url . "/music/subject/$subjectID/reviews", %args
        )
    );
}

sub post_review {
    my ($self, %args) = @_;
    croak "post xml needed!" unless $args{xml};
    return $self->post($self->review_url . 's', xml => $args{xml},);
}

sub delete_review {
    my ($self, %args) = @_;
    $args{reviewID} ||= $self->reviewID;
    croak "reviewID missing" unless $args{reviewID};
    return $self->delete($self->review_url . "/$args{reviewID}",);
}

sub put_review {
    my ($self, %args) = @_;
    $args{reviewID} ||= $self->reviewID;
    croak "reviewID missing" unless $args{reviewID};
    croak "put xml needed!"  unless $args{xml};
    return $self->put($self->review_url . "/$args{reviewID}",
        xml => $args{xml});
}

no Moose;
__PACKAGE__->meta->make_immutable;
1;

__END__