WWW::AdServer::Logger::Text - logs impressions / clickthrus to a text file


WWW-AdServer documentation Contained in the WWW-AdServer distribution.

Index


Code Index:

NAME

Top

WWW::AdServer::Logger::Text - logs impressions / clickthrus to a text file

SYNOPSIS

Top

  use WWW::AdServer::Logger::Text;

  my $logger = WWW::AdServer::Logger::Text->new( $r );

  $logger->log_impression($advert);

  $logger->log_clickthru($advert);

DESCRIPTION

Top

$logger = WWW::AdServer::Logger::Text->new( $r );

Constructor for a Logger strategy. Must be supplied with either an Apache request object or an Apache::Emulator object (if called through CGI).

$logger->log_impression($advert);

Logs a view of an advert.

$logger->log_clickthru($advert);

Logs a clickthru on an advert.

EXPORT

None by default.

AUTHOR

Top

Nigel Wetters (nwetters@cpan.org)

COPYRIGHT

Top


WWW-AdServer documentation Contained in the WWW-AdServer distribution.

package WWW::AdServer::Logger::Text;
$VERSION = '0.01';
use strict;
use vars qw ( $VERSION @ISA );
use Carp;
use WWW::AdServer::Logger;
@ISA = qw ( WWW::AdServer::Logger );

use Fcntl qw (:DEFAULT :flock);

sub log_impression
{
    my ($self, $advert) = @_;
    my $r = $$self;
    my $config = $r->dir_config('ADCONFIG');
    my $ad_log = $config.'/logs/'.$advert->get_advert.'.txt';
    my $lock   = $ad_log.'.lockfile';
    sysopen(LOGLOCK, $lock, O_RDONLY | O_CREAT)
	or croak "can't open $lock: $!";
    while (!(flock(LOGLOCK, LOCK_SH))){
	sleep 0.1;
    };
    sysopen(LOG, $ad_log, O_WRONLY | O_APPEND | O_CREAT)
	or croak "can't open log: $!";
    print LOG (time.' IMP '.$r->get_remote_host."\n");
    close LOG;
    if ((-M $lock > 1) or (-s $ad_log > 100000)){
	rename $ad_log, ($r->dir_config('ADCONFIG').'/admin/logs/'.$advert->get_advert.'.txt.'.time.'.'.int(rand 2**32));
	unlink $lock;
    }
    close LOGLOCK;
}

sub log_clickthru
{
    my ($self,$advert) = @_;
    my $r = $$self;
    my $config = $r->dir_config('ADCONFIG');
    my $ad_log = $config.'/logs/'.$advert->get_advert.'.txt';
    my $lock   = $ad_log.'.lockfile';
    sysopen(LOGLOCK, $lock, O_RDONLY | O_CREAT)
	or croak "can't open $lock: $!";
    while (!(flock(LOGLOCK, LOCK_SH))){
	sleep 0.1;
    };
    sysopen(LOG, $ad_log, O_WRONLY | O_APPEND | O_CREAT)
	or croak "can't open log: $!";
    print LOG (time.' CKT '.$r->get_remote_host."\n");
    close LOG;
    if ((-M $lock > 1) or (-s $ad_log > 100000)){
	rename $ad_log, ($r->dir_config('ADCONFIG').'/admin/logs/'.$advert->get_advert.'.txt.'.time.'.'.int(rand 2**32));
	unlink $lock;
    }
    close LOGLOCK;
}

1;
__END__