#!/usr/bin/perl

use strict;
use warnings;

$|++;    # OUTPUT_AUTOFLUSH

use Cwd;
use Data::Dumper;
use File::Tail;

my $dir = get_qp_dir() or die "unable to find QP home dir";
my $file = "$dir/log/main/current";
my $fh = File::Tail->new(
                         name        => $file,
                         interval    => 1,
                         maxinterval => 1,
                         debug       => 1,
                         tail        => 300
                        );

while (defined(my $line = $fh->read)) {
    my (undef, $line) = split /\s/, $line, 2;    # strip off tai timestamps
    print $line;
}

sub get_qp_dir {
    foreach my $user (qw/ qpsmtpd smtpd /) {
        my ($homedir) = (getpwnam($user))[7] or next;

        if (-d "$homedir/plugins") {
            return "$homedir";
        }
        foreach my $s (qw/ smtpd qpsmtpd qpsmtpd-dev /) {
            if (-d "$homedir/$s/plugins") {
                return "$homedir/$s";
            }
        }
    }
    if (-d "./plugins") {
        return Cwd::getcwd();
    }
}