NAME

Business::SiteCatalyst::Report - Interface to Adobe SiteCatalyst's REST Report API.

VERSION

Version 1.0.0

SYNOPSIS

This module allows you to interact with Adobe SiteCatalyst, an analystics Service Provider. It encapsulates all the communications with the API provided by Adobe SiteCatalyst to offer a Perl interface for managing reports.

Please note that you will need to have purchased the Adobe SiteCatalyst product, and have web services enabled first in order to obtain a web services shared secret, as well as agree with the Terms and Conditions for using the API.

use Business::SiteCatalyst;

# Create an object to communicate with Adobe SiteCatalyst
my $site_catalyst = Business::SiteCatalyst->new(
	username        => 'dummyusername',
	shared_secret   => 'dummysecret',
);

my $report = $site_catalyst->instantiate_report(
	type            => 'report type',
	report_suite_id => 'report suite id',
);

# See SiteCatalyst API Explorer at https://developer.omniture.com/en_US/get-started/api-explorer
# for Report.Queue[Trended|Ranked|Overtime] documentation
$report->queue(
	%report_arguments, #report-dependant
);

my $results;
for ( my $tries = 0; $tries < 20; tries++ )
{
	if ( $report->is_ready() )
	{
		$results = $report->retrieve();
		last;
	}
	else
	{
		sleep 5;
	}
}

unless ( defined $results )
{
	$report->cancel();
}

METHODS

new()

Create a new Business::SiteCatalyst::Report object, which will allow retrieval of SiteCatalyst reports.

NOTE: This should not be called directly. Instead, use Business::SiteCatalyst-instantiate_report()>.

my $report = Business::SiteCatalyst::Report->new(
	$site_catalyst,
	type            => 'report type',
	report_suite_id => 'report suite id',
);

Parameters:

  • type

    The type of the report to instantiate. Acceptable values are 'Overtime', 'Ranked', and 'Trended'.

  • report_suite_id

    The Report Suite ID you want to pull data from.

queue()

Queue a Business::SiteCatalyst report.

$report->queue( %report_arguments );

$report->queue(
	dateFrom      => "2012-04-01",
	dateTo        => "2012-04-15",
	metrics       => [{"id" => "instances"}],
	elements      => [{"id" => "referrer","top" => "5"}]
);

is_ready()

Check if a queued report is completed yet.

my $boolean = $report->is_ready();

retrieve()

Retrieve report results from Adobe SiteCatalyst.

my $results = $report->retrieve();

cancel()

Cancel queued report request.

$report->cancel();

get_site_catalyst()

Get Business::SiteCatalyst object used when creating the current object.

$report->get_site_catalyst();

get_id()

Get the report ID returned by Adobe SiteCatalyst when we queued the report.

$report->get_id()

AUTHOR

Jennifer Pinkham, <jpinkham at cpan.org>.

BUGS

Please report any bugs or feature requests to bug-Business-SiteCatalyst at rt.cpan.org, or through the web interface at http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Business-SiteCatalyst. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.

SUPPORT

You can find documentation for this module with the perldoc command.

perldoc Business::SiteCatalyst::Report

You can also look for information at:

ACKNOWLEDGEMENTS

Thanks to ThinkGeek (http://www.thinkgeek.com/) and its corporate overlords at Geeknet (http://www.geek.net/), for footing the bill while I write code for them!

COPYRIGHT & LICENSE

Copyright 2012 Jennifer Pinkham.

This program is free software; you can redistribute it and/or modify it under the terms of the Artistic License.

See http://dev.perl.org/licenses/ for more information.