mirror of
https://github.com/fhem/fhem-mirror.git
synced 2025-03-13 17:26:34 +00:00
93_Log2Syslog.pm: new to contrib
git-svn-id: https://svn.fhem.de/fhem/trunk@14910 2b470e98-0d58-463d-a4d8-8e2adae1ed80
This commit is contained in:
parent
beb9f9c5aa
commit
0d46928274
@ -495,7 +495,8 @@ FHEM/GPUtils.pm ntruchsess http://forum.fhem.de FHEM Deve
|
||||
|
||||
contrib/23_WEBTHERM.pm betateilchen/sachag http://forum.fhem.de Sonstiges
|
||||
contrib/70_ONKYO_AVR_PULL.pm loredo http://forum.fhem.de Multimedia
|
||||
contrib/92_rsyslog.pm DS_Starter
|
||||
contrib/92_rsyslog.pm DS_Starter http://forum.fhem.de Automatisierung
|
||||
contrib/93_Log2Syslog.pm DS_Starter http://forum.fhem.de Automatisierung
|
||||
contrib/98_exportdevice.pm loredo http://forum.fhem.de Sonstiges
|
||||
contrib/betateilchen/* betateilchen http://forum.fhem.de Sonstiges
|
||||
contrib/holiday betateilchen http://forum.fhem.de Sonstiges
|
||||
|
572
fhem/contrib/93_Log2Syslog.pm
Normal file
572
fhem/contrib/93_Log2Syslog.pm
Normal file
@ -0,0 +1,572 @@
|
||||
#######################################################################################################
|
||||
# $Id: $
|
||||
#######################################################################################################
|
||||
# 93_Log2Syslog.pm
|
||||
#
|
||||
# (c) 2017 by Heiko Maaz
|
||||
# e-mail: Heiko dot Maaz at t-online dot de
|
||||
#
|
||||
# This script is part of fhem.
|
||||
#
|
||||
# Fhem is free software: you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
# the Free Software Foundation, either version 2 of the License, or
|
||||
# (at your option) any later version.
|
||||
#
|
||||
# Fhem is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with fhem. If not, see <http://www.gnu.org/licenses/>.
|
||||
#
|
||||
# The module based on idea and input from betateilchen 92_rsyslog.pm
|
||||
# Implements the Syslog Protocol of RFC 5424 (https://tools.ietf.org/html/rfc5424)
|
||||
#
|
||||
#######################################################################################################
|
||||
# Versions History:
|
||||
#
|
||||
# 2.0.0 16.08.2017 create syslog without SYS::SYSLOG
|
||||
# 1.1.1 13.08.2017 registrate fhemlog_log to %loginform in case of sending fhem-log
|
||||
# attribute timeout, commandref revised
|
||||
# 1.1.0 26.07.2017 add regex search to sub fhemlog_Log
|
||||
# 1.0.0 25.07.2017 initial version
|
||||
|
||||
package main;
|
||||
|
||||
use strict;
|
||||
use warnings;
|
||||
eval "use IO::Socket::INET;1" or my $MissModulSocket = "IO::Socket::INET";
|
||||
eval "use Net::Domain qw(hostfqdn);1" or my $MissModulNDom = "Net::Domain";
|
||||
|
||||
my $Log2SyslogVn = "2.0.0";
|
||||
|
||||
# Mappinghash BSD-Formatierung Monat
|
||||
my %Log2Syslog_BSDMonth = (
|
||||
"01" => "Jan",
|
||||
"02" => "Feb",
|
||||
"03" => "Mar",
|
||||
"04" => "Apr",
|
||||
"05" => "May",
|
||||
"06" => "Jun",
|
||||
"07" => "Jul",
|
||||
"08" => "Aug",
|
||||
"09" => "Sep",
|
||||
"10" => "Oct",
|
||||
"11" => "Nov",
|
||||
"12" => "Dec"
|
||||
);
|
||||
|
||||
#####################################
|
||||
sub Log2Syslog_Initialize($) {
|
||||
my ($hash) = @_;
|
||||
|
||||
$hash->{DefFn} = "Log2Syslog_Define";
|
||||
$hash->{UndefFn} = "Log2Syslog_Undef";
|
||||
$hash->{DeleteFn} = "Log2Syslog_Delete";
|
||||
$hash->{AttrFn} = "Log2Syslog_Attr";
|
||||
$hash->{NotifyFn} = "Log2Syslog_Main";
|
||||
|
||||
$hash->{AttrList} = "addStateEvent:1,0 ".
|
||||
"disable:1,0 ".
|
||||
"addTimestamp:0,1 ".
|
||||
"logFormat:BSD,IETF ".
|
||||
"type:UDP,TCP ".
|
||||
"port "
|
||||
;
|
||||
return undef;
|
||||
}
|
||||
|
||||
##############################################################
|
||||
sub Log2Syslog_Define($@) {
|
||||
my ($hash, $def) = @_;
|
||||
my @a = split("[ \t][ \t]*", $def);
|
||||
|
||||
return "Error: Perl module ".$MissModulSocket." is missing. Install it on Debian with: sudo apt-get install libio-socket-multicast-perl" if($MissModulSocket);
|
||||
return "Error: Perl module ".$MissModulNDom." is missing." if($MissModulNDom);
|
||||
|
||||
if (int(devspec2array('TYPE=Log2Syslog')) > 1) {
|
||||
my @ldvs = devspec2array('TYPE=Log2Syslog');
|
||||
my $ldvs = shift(@ldvs);
|
||||
return "Log2Syslog device '$ldvs' is already defined. Only one device can be defined ! ";
|
||||
}
|
||||
|
||||
# Example: define splunklog Log2Syslog splunk.myds.me event:.* fhem:.*
|
||||
return "wrong syntax, use: define <name> Log2Syslog <host> [event:<regexp>] [fhem:<regexp>] "
|
||||
if(int(@a)-3 < 0);
|
||||
|
||||
delete($hash->{HELPER}{EVNTLOG});
|
||||
delete($hash->{HELPER}{FHEMLOG});
|
||||
|
||||
if ($a[3]) {
|
||||
$hash->{HELPER}{EVNTLOG} = (split("event:",$a[3]))[1] if(lc($a[3]) =~ m/^event:.*/);
|
||||
$hash->{HELPER}{FHEMLOG} = (split("fhem:",$a[3]))[1] if(lc($a[3]) =~ m/^fhem:.*/);
|
||||
}
|
||||
if ($a[4]) {
|
||||
$hash->{HELPER}{EVNTLOG} = (split("event:",$a[4]))[1] if(lc($a[4]) =~ m/^event:.*/);
|
||||
$hash->{HELPER}{FHEMLOG} = (split("fhem:",$a[4]))[1] if(lc($a[4]) =~ m/^fhem:.*/);
|
||||
}
|
||||
return "Bad regexp: starting with *"
|
||||
if((defined($hash->{HELPER}{EVNTLOG}) && $hash->{HELPER}{EVNTLOG} =~ m/^\*/) || (defined($hash->{HELPER}{FHEMLOG}) && $hash->{HELPER}{FHEMLOG} =~ m/^\*/));
|
||||
eval { "Hallo" =~ m/^$hash->{HELPER}{EVNTLOG}$/ } if($hash->{HELPER}{EVNTLOG});
|
||||
return "Bad regexp: $@" if($@);
|
||||
eval { "Hallo" =~ m/^$hash->{HELPER}{FHEMLOG}$/ } if($hash->{HELPER}{FHEMLOG});
|
||||
return "Bad regexp: $@" if($@);
|
||||
|
||||
$hash->{PEERHOST} = $a[2]; # Destination Host (Syslog Server)
|
||||
$hash->{MYHOST} = hostfqdn (); # FQDN eigener Host
|
||||
$hash->{HELPER}{PID} = $$; # PROCID in IETF
|
||||
$hash->{VERSION} = $Log2SyslogVn;
|
||||
$logInform{$hash->{NAME}} = "Log2Syslog_Main"; # Funktion die in hash %loginform für $name eingetragen wird
|
||||
|
||||
readingsSingleUpdate($hash, "state", "initialized", 1);
|
||||
|
||||
return undef;
|
||||
}
|
||||
|
||||
sub Log2Syslog_Undef($$) {
|
||||
my ($hash, $name) = @_;
|
||||
$hash->{HELPER}{SOCK}->close() if($hash->{HELPER}{SOCK});
|
||||
return undef;
|
||||
}
|
||||
|
||||
sub Log2Syslog_Delete($$) {
|
||||
my ($hash, $arg) = @_;
|
||||
$hash->{HELPER}{SOCK}->close() if($hash->{HELPER}{SOCK});
|
||||
delete $logInform{$hash->{NAME}};
|
||||
return undef;
|
||||
}
|
||||
|
||||
################################################################
|
||||
sub Log2Syslog_Attr {
|
||||
my ($cmd,$name,$aName,$aVal) = @_;
|
||||
my $hash = $defs{$name};
|
||||
my $do;
|
||||
|
||||
# $cmd can be "del" or "set"
|
||||
# $name is device name
|
||||
# aName and aVal are Attribute name and value
|
||||
|
||||
if ($aName eq "disable") {
|
||||
if($cmd eq "set") {
|
||||
$do = ($aVal) ? 1 : 0;
|
||||
}
|
||||
$do = 0 if($cmd eq "del");
|
||||
my $val = ($do == 1 ? "disabled" : "active");
|
||||
|
||||
readingsSingleUpdate($hash, "state", $val, 1);
|
||||
}
|
||||
|
||||
if ($cmd eq "set" && $aName eq "port") {
|
||||
if($aVal !~ m/^\d+$/) { return " The Value of \"$aName\" is not valid. Use only figures !";}
|
||||
}
|
||||
|
||||
if ($aName =~ m/^.*logFilter$/) {
|
||||
return "Bad regexp: starting with *" if($aVal =~ m/^\*/);
|
||||
eval { "Hallo" =~ m/^$aVal$/ };
|
||||
return "Bad regexp: $@" if($@);
|
||||
}
|
||||
|
||||
return undef;
|
||||
}
|
||||
|
||||
#################################################################################
|
||||
# Main sub
|
||||
#################################################################################
|
||||
sub Log2Syslog_Main ($$) {
|
||||
my ($a,$b) = @_;
|
||||
my ($hash,$name,$dev,$raw);
|
||||
my $call = "init";
|
||||
my $ret;
|
||||
|
||||
if (ref($a) eq "HASH") {
|
||||
# call from notifyFn
|
||||
# $hash is my entry, $dev is the entry of the changed device
|
||||
$hash = $a;
|
||||
$name = $hash->{NAME};
|
||||
$dev = $b;
|
||||
$call = "evt";
|
||||
} else {
|
||||
# call from %loginform
|
||||
$name = $a;
|
||||
$hash = $defs{$name};
|
||||
$raw = $b;
|
||||
$call = "log";
|
||||
}
|
||||
return if(IsDisabled($name));
|
||||
|
||||
my $host = $hash->{PEERHOST};
|
||||
my $port = AttrVal($name, "port", 514);
|
||||
my $type = lc(AttrVal($name, "type", "udp"));
|
||||
my $st = "active";
|
||||
|
||||
# Create Socket and check if successful
|
||||
$hash->{HELPER}{SOCK} = new IO::Socket::INET (PeerHost => $host, PeerPort => $port, Proto => $type);
|
||||
|
||||
if ($hash->{HELPER}{SOCK}) {
|
||||
if($call eq "log" && defined($hash->{HELPER}{FHEMLOG})) {
|
||||
# FHEM System-Logs
|
||||
$ret = fhemlog_Log($name,$raw);
|
||||
}
|
||||
if ($call eq "evt" && defined($hash->{HELPER}{EVNTLOG})) {
|
||||
# FHEM Eventlogs
|
||||
$ret = event_Log($hash,$dev);
|
||||
}
|
||||
} else {
|
||||
$st = "unable for open socket for $host, $type, $port";
|
||||
}
|
||||
readingsSingleUpdate($hash, "state", $st, 1) if($st ne OldValue($name));
|
||||
$hash->{HELPER}{SOCK}->close() if($hash->{HELPER}{SOCK});
|
||||
delete $hash->{HELPER}{SOCK};
|
||||
|
||||
return $ret;
|
||||
}
|
||||
|
||||
#################################################################################
|
||||
# Eventlogging
|
||||
#################################################################################
|
||||
sub event_Log($$) {
|
||||
# $hash is my entry, $dev is the entry of the changed device
|
||||
my ($hash,$dev) = @_;
|
||||
my $name = $hash->{NAME};
|
||||
my $rex = $hash->{HELPER}{EVNTLOG};
|
||||
my $sock = $hash->{HELPER}{SOCK};
|
||||
my ($prival);
|
||||
|
||||
return if(!$rex);
|
||||
my $events = deviceEvents($dev, AttrVal($name, "addStateEvent", 0));
|
||||
return if(!$events);
|
||||
|
||||
my $n = $dev->{NAME};
|
||||
my $max = int(@{$events});
|
||||
my $tn = $dev->{NTFY_TRIGGERTIME};
|
||||
my $ct = $dev->{CHANGETIME};
|
||||
|
||||
for (my $i = 0; $i < $max; $i++) {
|
||||
my $s = $events->[$i];
|
||||
$s = "" if(!defined($s));
|
||||
|
||||
my $tim = (($ct && $ct->[$i]) ? $ct->[$i] : $tn);
|
||||
my ($date,$time) = split(" ",$tim);
|
||||
|
||||
if($n =~ m/^$rex$/ || "$n:$s" =~ m/^$rex$/ || "$tim:$n:$s" =~ m/^$rex$/) {
|
||||
my $otp = "$n -> $s";
|
||||
$otp = "$tim $otp" if AttrVal($name,'addTimestamp',0);
|
||||
$prival = setprival($s);
|
||||
|
||||
my $data = setpayload($hash,$prival,$date,$time,$otp,"event");
|
||||
eval {$sock->send($data);};
|
||||
}
|
||||
}
|
||||
|
||||
return "";
|
||||
}
|
||||
|
||||
#################################################################################
|
||||
# FHEM system logging
|
||||
#################################################################################
|
||||
sub fhemlog_Log($$) {
|
||||
my ($name,$raw) = @_;
|
||||
my $hash = $defs{$name};
|
||||
my $rex = $hash->{HELPER}{FHEMLOG};
|
||||
my $sock = $hash->{HELPER}{SOCK};
|
||||
my ($prival);
|
||||
|
||||
return if(!$rex);
|
||||
|
||||
my ($date,$time,$vbose,undef,$text) = split(" ",$raw,5);
|
||||
$date =~ s/\./-/g;
|
||||
my $tim = $date." ".$time;
|
||||
if($text =~ m/^$rex$/ || "$vbose: $text" =~ m/^$rex$/) {
|
||||
my $otp = "$vbose: $text";
|
||||
$otp = "$tim $otp" if AttrVal($name,'addTimestamp',0);
|
||||
$prival = setprival($text,$vbose);
|
||||
|
||||
my $data = setpayload($hash,$prival,$date,$time,$otp,"fhem");
|
||||
eval {$sock->send($data);};
|
||||
}
|
||||
|
||||
return "";
|
||||
}
|
||||
|
||||
###############################################################################
|
||||
# set PRIVAL (severity & facility)
|
||||
###############################################################################
|
||||
sub setprival ($;$$) {
|
||||
my ($text,$vbose)= @_;
|
||||
my $prival;
|
||||
|
||||
# Priority = (facility * 8) + severity
|
||||
# https://tools.ietf.org/html/rfc5424
|
||||
|
||||
# determine facility
|
||||
my $fac = 5; # facility by syslogd
|
||||
|
||||
# calculate severity
|
||||
# mapping verbose level to severity
|
||||
# 0: Critical -> 2
|
||||
# 1: Error -> 3
|
||||
# 2: Warning -> 4
|
||||
# 3: Notice -> 5
|
||||
# 4: Informational -> 6
|
||||
# 5: Debug -> 7
|
||||
|
||||
my $sv = 5; # notice (default)
|
||||
|
||||
if ($vbose) {
|
||||
# map verbose to severity
|
||||
$sv = 2 if ($vbose == 0);
|
||||
$sv = 3 if ($vbose == 1);
|
||||
$sv = 4 if ($vbose == 2);
|
||||
$sv = 5 if ($vbose == 3);
|
||||
$sv = 6 if ($vbose == 4);
|
||||
$sv = 7 if ($vbose == 5);
|
||||
}
|
||||
|
||||
$sv = 3 if (lc($text) =~ m/error/); # error condition
|
||||
$sv = 4 if (lc($text) =~ m/warning/); # warning conditions
|
||||
|
||||
$prival = ($fac*8)+$sv;
|
||||
|
||||
return($prival);
|
||||
}
|
||||
|
||||
###############################################################################
|
||||
# create Payload for Syslog
|
||||
###############################################################################
|
||||
sub setpayload ($$$$$$) {
|
||||
my ($hash,$prival,$date,$time,$otp,$lt)= @_;
|
||||
my $name = $hash->{NAME};
|
||||
my $ident = $name."_".$lt;
|
||||
my $myhost = $hash->{MYHOST}?$hash->{MYHOST}:"0.0.0.0";
|
||||
my $lf = AttrVal($name, "logFormat", "IETF");
|
||||
my $data;
|
||||
|
||||
my ($year,$month,$day) = split("-",$date);
|
||||
|
||||
if ($lf eq "BSD") {
|
||||
# BSD Protokollformat https://tools.ietf.org/html/rfc3164
|
||||
$time = (split(".",$time))[0]; # msec ist nicht erlaubt
|
||||
$month = $Log2Syslog_BSDMonth{$month}; # Monatsmapping z.B. 01 -> Jan
|
||||
$day =~ s/0/ /; # in Tagen < 10 muss 0 durch Space ersetzt werden
|
||||
no warnings 'uninitialized';
|
||||
$data = "<$prival>$month $day $time $myhost $ident :$otp";
|
||||
use warnings;
|
||||
}
|
||||
|
||||
if ($lf eq "IETF") {
|
||||
# IETF Protokollformat https://tools.ietf.org/html/rfc5424
|
||||
my $pid = $hash->{HELPER}{PID};
|
||||
my $mid = "FHEM"; # message ID, identify type of message, e.g. for firewalls
|
||||
my $tim = $date."T".$time."Z";
|
||||
no warnings 'uninitialized';
|
||||
$data = "<$prival>1 $tim $myhost $ident $pid $mid - :$otp";
|
||||
use warnings;
|
||||
}
|
||||
|
||||
return($data);
|
||||
}
|
||||
|
||||
1;
|
||||
|
||||
=pod
|
||||
=item helper
|
||||
=item summary send FHEM system logs and/or events to a syslog server.
|
||||
=item summary_DE leitet FHEM Systemlogs und/oder Events an einen Syslog-Server weiter
|
||||
|
||||
=begin html
|
||||
|
||||
<a name="Log2Syslog"></a>
|
||||
<h3>Log2Syslog</h3>
|
||||
<ul>
|
||||
Send FHEM system log entries and/or FHEM events to an external syslog server. <br><br>
|
||||
|
||||
<b>Prerequisits</b>
|
||||
<ul>
|
||||
<br/>
|
||||
The additional perl module "IO::Socket::INET" must be installed on your system. <br>
|
||||
Install this package from cpan or by <br><br>
|
||||
|
||||
<code>apt-get install libio-socket-multicast-perl (only on Debian based installations) </code><br>
|
||||
</ul>
|
||||
<br>
|
||||
|
||||
<a name="Log2Syslogdefine"></a>
|
||||
<b>Define</b>
|
||||
<ul>
|
||||
<br>
|
||||
<code>define <name> Log2Syslog <destination host> [event:<regexp>] [fhem:<regexp>]</code><br>
|
||||
<br>
|
||||
|
||||
<destination host> = host where the syslog server is running <br>
|
||||
[event:<regexp>] = optional regex to filter events for logging <br>
|
||||
[fhem:<regexp>] = optional regex to filter fhem system log for logging <br><br>
|
||||
|
||||
After definition the new device sends all new appearing fhem systemlog entries and events to the destination host,
|
||||
port=514/UDP format:IETF, immediately without further settings if the regex for fhem or event were set. <br>
|
||||
Without setting regex no fhem system log or event log will be forwarded. <br>
|
||||
The module uses functions of Perls SYS::SYSLOG module. If you want know more, see for detailed descriptions
|
||||
on <a href="http://perldoc.perl.org/Sys/Syslog.html">perldoc</a>. <br>
|
||||
|
||||
<br>
|
||||
Example to log anything: <br>
|
||||
<br/>
|
||||
<code>define splunklog Log2Syslog fhemtest 192.168.2.49 event:.* fhem:.* </code><br>
|
||||
<br/>
|
||||
will produce output like:<br/>
|
||||
<pre>Mar 20 15:25:22 fhem-vm-8 fhem: global: SAVE
|
||||
Mar 20 15:25:44 fhem-vm-8 fhem: global: SHUTDOWN
|
||||
Mar 20 15:25:57 fhem-vm-8 fhem: global: INITIALIZED
|
||||
Mar 20 15:26:05 fhem-vm-8 fhem: PegelCux: Niedrigwasser-1: 20.03.2016 18:03
|
||||
Mar 20 15:26:05 fhem-vm-8 fhem: PegelCux: Hochwasser-1: 20.03.2016 23:45</pre>
|
||||
</ul>
|
||||
<br/>
|
||||
|
||||
|
||||
<a name="Log2Syslogattr"></a>
|
||||
<b>Attributes</b>
|
||||
<ul>
|
||||
<br/>
|
||||
<a name="addTimestamp"></a>
|
||||
<li><code>addTimestamp [0|1]</code><br>
|
||||
<br/>
|
||||
If set to 1, fhem timestamps will be logged too.<br/>
|
||||
Default behavior is to not log these timestamps, because syslog uses own timestamps.<br/>
|
||||
Maybe useful if mseclog is activated in fhem.<br/>
|
||||
<br/>
|
||||
Example output:<br/>
|
||||
<pre>Mar 20 15:47:42 fhem-vm-8 fhem: 2016-03-20_15:47:42 global: SAVE
|
||||
Mar 20 15:47:46 fhem-vm-8 fhem: 2016-03-20_15:47:46 global: SHUTDOWN
|
||||
Mar 20 15:47:53 fhem-vm-8 fhem: 2016-03-20_15:47:53 global: INITIALIZED</pre>
|
||||
</li><br>
|
||||
|
||||
<li><code>addStateEvent [0|1]</code><br>
|
||||
<br>
|
||||
If set to 1, events will be completed with "state" if a state-event appears.<br/>
|
||||
Default behavior is without getting "state".
|
||||
</li><br>
|
||||
|
||||
<li><code>logFormat [BSD|IETF]</code><br>
|
||||
<br>
|
||||
Set the syslog protocol format. <br>
|
||||
Default value is "IETF" if not specified.
|
||||
</li><br>
|
||||
|
||||
<li><code>type [TCP|UDP]</code><br>
|
||||
<br>
|
||||
Sets the socket type which should be used. You can choose UDP or TCP. <br>
|
||||
Default value is "UDP" if not specified.
|
||||
</li><br>
|
||||
|
||||
<li><code>port</code><br>
|
||||
<br>
|
||||
The port of the syslog server is listening. Default port is 514 if not specified.
|
||||
</li><br>
|
||||
|
||||
</ul>
|
||||
<br/>
|
||||
|
||||
</ul>
|
||||
|
||||
=end html
|
||||
=begin html_DE
|
||||
|
||||
<a name="Log2Syslog"></a>
|
||||
<h3>Log2Syslog</h3>
|
||||
<ul>
|
||||
Sendet FHEM Systemlog Einträge und/oder Events an einen externen Syslog-Server weiter. <br/>
|
||||
<br/>
|
||||
|
||||
<b>Voraussetzungen</b>
|
||||
<ul>
|
||||
<br/>
|
||||
Es wird das Perl Modul "IO::Socket::INET" benötigt und muss installiert sein. <br>
|
||||
Das Modul kann über CPAN oder mit <br><br>
|
||||
|
||||
<code>apt-get install libio-socket-multicast-perl (auf Debian Linux Systemen) </code><br><br>
|
||||
|
||||
installiert werden.
|
||||
</ul>
|
||||
<br/>
|
||||
|
||||
<a name="Log2Syslogdefine"></a>
|
||||
<b>Definition</b>
|
||||
<ul>
|
||||
<br>
|
||||
<code>define <name> Log2Syslog <destination host> [event:<regexp>] [fhem:<regexp>] </code><br>
|
||||
<br>
|
||||
|
||||
<Zielhost> = Host (Name oder IP-Adresse) auf dem der Syslog-Server läuft <br>
|
||||
[event:<regexp>] = optionaler regulärer Ausdruck zur Filterung von Events zur Weiterleitung <br>
|
||||
[fhem:<regexp>] = optionaler regulärer Ausdruck zur Filterung von FHEM Logs zur Weiterleitung <br><br>
|
||||
|
||||
Direkt nach der Definition sendet das neue Device alle neu auftretenden FHEM Systemlog Einträge und Events ohne weitere
|
||||
Einstellungen an den Zielhost, Port=514/UDP Format:IETF, wenn reguläre Ausdrücke für Events/FHEM angegeben wurden. <br>
|
||||
Wurde kein Regex gesetzt, erfolgt keine Weiterleitung von Events oder FHEM Systemlogs. <br>
|
||||
Das Modul verwendet Funktionen des Perl-Moduls SYS::SYSLOG. Weitere Informationen dazu sind auf
|
||||
<a href="http://perldoc.perl.org/Sys/Syslog.html">perldoc</a> zu finden. <br>
|
||||
|
||||
<br>
|
||||
Beispiel:<br/>
|
||||
<br/>
|
||||
<code>define splunklog Log2Syslog fhemtest 192.168.2.49 </code><br/>
|
||||
<br/>
|
||||
Es werden alle Events weitergeleitet:<br/>
|
||||
<pre>Mar 20 15:25:22 fhem-vm-8 fhem: global: SAVE
|
||||
Mar 20 15:25:44 fhem-vm-8 fhem: global: SHUTDOWN
|
||||
Mar 20 15:25:57 fhem-vm-8 fhem: global: INITIALIZED
|
||||
Mar 20 15:26:05 fhem-vm-8 fhem: PegelCux: Niedrigwasser-1: 20.03.2016 18:03
|
||||
Mar 20 15:26:05 fhem-vm-8 fhem: PegelCux: Hochwasser-1: 20.03.2016 23:45</pre>
|
||||
</ul>
|
||||
<br/>
|
||||
|
||||
|
||||
<a name="Log2Syslogattr"></a>
|
||||
<b>Attribute</b>
|
||||
<ul>
|
||||
<br>
|
||||
|
||||
<a name="addTimestamp"></a>
|
||||
<li><code>addTimestamp [0|1]</code><br>
|
||||
<br/>
|
||||
Wenn gesetzt, werden FHEM Timestamps im Datensatz mit übertragen.<br/>
|
||||
Per default werden die Timestamps nicht mit übertragen, da der Syslog-Server eigene Timestamps verwendet.<br/>
|
||||
Die Einstellung kann hilfeich sein wenn mseclog in FHEM aktiviert ist.<br/>
|
||||
<br/>
|
||||
|
||||
Beispielausgabe:<br/>
|
||||
<pre>Mar 20 15:47:42 fhem-vm-8 fhem: 2016-03-20_15:47:42 global: SAVE
|
||||
Mar 20 15:47:46 fhem-vm-8 fhem: 2016-03-20_15:47:46 global: SHUTDOWN
|
||||
Mar 20 15:47:53 fhem-vm-8 fhem: 2016-03-20_15:47:53 global: INITIALIZED</pre>
|
||||
</li><br>
|
||||
|
||||
<li><code>addStateEvent [0|1]</code><br>
|
||||
<br>
|
||||
Wenn gesetzt, werden state-events mit dem Reading "state" ergänzt.<br/>
|
||||
Die Standardeinstellung ist ohne state-Ergänzung.
|
||||
</li><br>
|
||||
|
||||
<li><code>logFormat [BSD|IETF]</code><br>
|
||||
<br>
|
||||
Stellt das Protokollformat ein. <br>
|
||||
Der Standardwert ist "IETF".
|
||||
</li><br>
|
||||
|
||||
<li><code>type [TCP|UDP]</code><br>
|
||||
<br>
|
||||
Setzt den Protokolltyp der verwendet werden soll. Es kann UDP oder TCP gewählt werden. <br>
|
||||
Standard ist "UDP" wenn nichts spezifiziert ist.
|
||||
</li><br>
|
||||
|
||||
<li><code>port</code><br>
|
||||
<br>
|
||||
Der verwendete Port des Syslog-Servers. Default Port ist 514 wenn nicht gesetzt.
|
||||
</li><br>
|
||||
|
||||
</ul>
|
||||
<br/>
|
||||
|
||||
</ul>
|
||||
=end html_DE
|
||||
=cut
|
Loading…
x
Reference in New Issue
Block a user