NAME

Elive::Entity::Report - Elluminate Report entity instance class

DESCRIPTION

This is the entity class for server side reports. These are visible on the Elluminate server under the 'Reports' tab.

Please note that the list method (listReports command) does not return the body of the report. The report object needs to be refetched via the retrieve method.

For example, the following code snippet exports all reports for a site:

    my $reports = Elive::Entity::Report->list;
    my @report_ids = map {$_->reportId} @$reports;

    foreach my $report_id (@report_ids) {

	#
	# listed objects don't have the report body, refetch them.
	#

        my $rpt = Elive::Entity::Report->retrieve( $report_id );

	my $name = $rpt->name;
	$name =~ s/[^\w]//g; # sanitise
	my $export_file = "/tmp/report_${reportId}_${name}.xml";

	open (my $dump_fh, '>', $export_file)
	    or die "unable to open $export_file: $!";
	print $dump_fh $rpt->xml;
	close ($dump_fh);

    }

METHODS

list

my $all_reports = Elive::Entity::Report->list();

List reports.

Note: This command does not return the body of the report (xml property).

retrieve

my $report = Elive::Entity::Report->retrieve( $report_id );
my $report_xml = $report->xml;

Retrieves a report, including the body of the report (xml property).

insert

The insert method is not available for reports.

update

The update method is not available for reports.

delete

my $report = Elive::Entity::Report->retrieve( $report_id );
$report->delete if $report;

Deletes a report.