# log_parser.pl
# Functions for parsing this module's logs
do 'user-lib.pl';
# parse_webmin_log(user, script, action, type, object, ¶ms)
# Converts logged information from this module into human-readable form
sub parse_webmin_log
{
local ($user, $script, $action, $type, $object, $p, $long) = @_;
$object = &html_escape($object);
if ($type eq 'user') {
if ($action eq 'modify' && $p->{'old'} ne $object) {
return &text('log_urename',
"".&html_escape($p->{'old'})."",
"$object");
}
elsif ($action eq 'modify') {
return &text('log_umodify', "$object");
}
elsif ($action eq 'create') {
return &text('log_ucreate', "$object");
}
elsif ($action eq 'delete' && $p->{'delhome'}) {
return &text('log_udeletehome', "$object",
"".&html_escape($p->{'home'})."");
}
elsif ($action eq 'delete') {
return &text('log_udelete', "$object");
}
}
elsif ($type eq 'group') {
if ($action eq 'modify') {
return &text('log_gmodify', "$object");
}
elsif ($action eq 'create') {
return &text('log_gcreate', "$object");
}
elsif ($action eq 'delete') {
return &text('log_gdelete', "$object");
}
}
elsif ($action eq 'batch') {
if ($object =~ /^\//) {
return &text($long ? 'log_batch_l' : 'log_batch',
"$object", $p->{'created'},
$p->{'modified'}, $p->{'deleted'});
}
else {
return &text($long ? 'log_ubatch_l' : 'log_ubatch',
$p->{'created'}, $p->{'modified'},$p->{'deleted'});
}
}
return undef;
}