GrowthForecast-Aggregator-Declare

 view release on metacpan or  search on metacpan

lib/GrowthForecast/Aggregator/DBMulti.pm  view on Meta::CPAN

package GrowthForecast::Aggregator::DBMulti;
use strict;
use warnings;
use utf8;
use Encode qw(encode_utf8);
use HTTP::Request::Common;

use Mouse;

has names => (
    is => 'ro',
    isa => 'ArrayRef[Str]',
    required => 1,
);

has descriptions => (
    is => 'ro',
    isa => 'ArrayRef[Str]',
    required => 1,
);

has section => (
    is => 'ro',
    isa => 'Str',
    required => 1,
);

has query => (
    is => 'rw',
    isa => 'Str',
    required => 1,
);

has binds => (
    is => 'rw',
    isa => 'ArrayRef',
    default => sub { +[ ] },
);

no Mouse;

sub run {
    my $self = shift;
    my %args = @_;
    my $dbh = $args{dbh} // die "Missing mandatory parameter: dbh";
    my $service = $args{service} // die "Missing mandatory parameter: service";
    my $endpoint = $args{endpoint} // die "Missing mandatory parameter: endpoint";
    my $ua = $args{ua} // die "Missing mandatory parameter: ua";

    $endpoint =~ s!/$!!;

    my @numbers = $dbh->selectrow_array($self->query, {}, @{$self->binds});

    my @res;
    for (my $i=0; $i<@{$self->names}; $i++) {
        my $name = $self->names->[$i];

        my $url = "$endpoint/$service/$self->{section}/$name";

        my $req = POST $url, [
            number => $numbers[$i],
            description => encode_utf8($self->descriptions->[$i]),
        ];
        my $res = $ua->request($req);
        push @res, $res;
    }
    return @res;
}

1;
__END__

=head1 NAME

GrwothForecast::Aggregator::DB - Aggregate from RDBMS

=head1 SYNOPSIS

    my $aggregator = GrowthForecast::Aggregator::DBMulti->new(
        names        => ['count',                'count_unique'],
        descriptions => ['Total count of posts', 'Posted bloggers'],
        query => 'SELECT COUNT(*), COUNT(DISTINCT member_id) FROM entry',
    );
    my $res = $aggregator->run();

=head1 DESCRIPTION

This aggregator aggregates data from RDBMS, and post it to GrowthForecast.

=head1 CONSTRUCTOR ARGUMENTS

=over 4

=item section: Str, required

Section name.

This module send request to "/api/$service/$section/$name"

=item names : ArrayRef[Str], required

Names of the metrics.

This module send request to "/api/$service/$section/$name->[0]", "/api/$service/$section/$name->[1]", ....

=item descriptions: ArrayRef[Str], required

Description of the query. The module post it as 'description' parameter.

=item query: Str, required

This is a SQL query, to execute.

=item binds: ArrayRef, optional

Bind parameters for the query.

=back

=head1 ARGUMENTS FOR 'run' METHOD

=over 4

=item dbh

Data source database handle.

=item service

Service name.

This module send request to "/api/$service/$section/$name"

=item endpoint

Endpoint URL, contains '/api'.

E.g. http://example.com/api/

=item ua

Instance of HTTP client. I tested on L<Furl>.

=back



( run in 1.810 second using v1.01-cache-2.11-cpan-0bb4e1dffa6 )