From 25f4ffd58b95841e0712a7e0e8b6f1dfeccff8ef Mon Sep 17 00:00:00 2001 From: mjovanovic9999 <73258168+mjovanovic9999@users.noreply.github.com> Date: Thu, 12 Sep 2024 11:54:28 +0200 Subject: [PATCH] Added support for remote syslog logging (#2312) * remote syslog output plugin * added tcp or udp support --------- Co-authored-by: mj --- etc/cowrie.cfg.dist | 8 ++++++ src/cowrie/output/remotesyslog.py | 43 +++++++++++++++++++++++++++++++ 2 files changed, 51 insertions(+) create mode 100644 src/cowrie/output/remotesyslog.py diff --git a/etc/cowrie.cfg.dist b/etc/cowrie.cfg.dist index 3f46f671..7319f02c 100644 --- a/etc/cowrie.cfg.dist +++ b/etc/cowrie.cfg.dist @@ -1085,3 +1085,11 @@ authtype = instance_principals #tenancy_ocid = ocid1.tenancy.oc1..xxx #region = eu-stockholm-1 #keyfile = /home/xx/key.pem + +[output_remotesyslog] +enabled = false +host = 127.0.0.1 +port = 514 +# protocol options: udp or tcp +# (default: udp) +protocol = udp \ No newline at end of file diff --git a/src/cowrie/output/remotesyslog.py b/src/cowrie/output/remotesyslog.py new file mode 100644 index 00000000..d1975c66 --- /dev/null +++ b/src/cowrie/output/remotesyslog.py @@ -0,0 +1,43 @@ +""" +Simple remote syslog plugin. +""" + +import cowrie.core.output + +import logging +import logging.handlers +import socket +from cowrie.core.config import CowrieConfig + + +class Output(cowrie.core.output.Output): + + def start(self): + self.host = CowrieConfig.get( + "output_remotesyslog", "host", fallback="127.0.0.1" + ) + + self.port = int(CowrieConfig.get("output_remotesyslog", "port", fallback="514")) + + protocol = CowrieConfig.get("output_remotesyslog", "protocol", fallback="udp").lower() + + self.logger = logging.getLogger("cowrieLogger") + + self.handler = logging.handlers.SysLogHandler(address = (self.host, self.port), socktype= None if protocol == 'udp' else socket.SOCK_STREAM) + + self.logger.addHandler( + self.handler + ) + + def stop(self): + self.handler.flush() + self.logger.removeHandler(self.handler) + self.handler.close() + + def write(self, event): + for i in list(event.keys()): + # Remove twisted 15 legacy keys + if i.startswith("log_") or i == "time" or i == "system": + del event[i] + + self.logger.warning(repr(event)+'\n')