Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add SSL support #47

Open
wants to merge 2 commits into
base: master
Choose a base branch
from
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
39 changes: 37 additions & 2 deletions logstash/handler_tcp.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
from logging.handlers import DatagramHandler, SocketHandler
import ssl
from logging.handlers import SocketHandler
from logstash import formatter


Expand All @@ -12,14 +13,48 @@ class TCPLogstashHandler(SocketHandler, object):
:param fqdn; Indicates whether to show fully qualified domain name or not (default False).
:param version: version of logstash event schema (default is 0).
:param tags: list of tags for a logger (default is None).
:param ssl: Should SSL be enabled for the connection? Default is True.
:param ssl_verify: Should the server's SSL certificate be verified?
:param keyfile: The path to client side SSL key file (default is None).
:param certfile: The path to client side SSL certificate file (default is None).
:param ca_certs: The path to the file containing recognised CA certificates. System wide CA certs are used if omitted.
"""

def __init__(self, host, port=5959, message_type='logstash', tags=None, fqdn=False, version=0):
def __init__(self, host, port=5959, message_type='logstash', tags=None, fqdn=False, version=0, ssl=True, ssl_verify=True, keyfile=None, certfile=None, ca_certs=None):
super(TCPLogstashHandler, self).__init__(host, port)

self.ssl = ssl
self.ssl_verify = ssl_verify
self.keyfile = keyfile
self.certfile = certfile
self.ca_certs = ca_certs

if version == 1:
self.formatter = formatter.LogstashFormatterVersion1(message_type, tags, fqdn)
else:
self.formatter = formatter.LogstashFormatterVersion0(message_type, tags, fqdn)

def makePickle(self, record):
return self.formatter.format(record) + b'\n'


def makeSocket(self, timeout=1):
s = super(TCPLogstashHandler, self).makeSocket(timeout)

if not self.ssl:
return s

context = ssl.create_default_context(cafile=self.ca_certs)
context.verify_mode = ssl.CERT_REQUIRED
if not self.ssl_verify:
if self.ca_certs:
context.verify_mode = ssl.CERT_OPTIONAL
else:
context.check_hostname = False
context.verify_mode = ssl.CERT_NONE

# Client side certificate auth.
if self.certfile and self.keyfile:
context.load_cert_chain(self.certfile, keyfile=self.keyfile)

return context.wrap_socket(s, server_hostname=self.host)