Skip to content
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
37 changes: 28 additions & 9 deletions pygelf/handlers.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,12 @@

from logging.handlers import SocketHandler, DatagramHandler
from logging import Handler as LoggingHandler
from base64 import b64encode
from pygelf import gelf

def get_basic_auth_header(username, password):
token = b64encode(f"{username}:{password}".encode('utf-8')).decode("ascii")
return f'Basic {token}'

class BaseHandler(object):
def __init__(self, debug=False, version='1.1', include_extra_fields=False, compress=False,
Expand Down Expand Up @@ -135,7 +139,7 @@ def makeSocket(self, timeout=1):

class GelfHttpHandler(BaseHandler, LoggingHandler):

def __init__(self, host, port, compress=True, path='/gelf', timeout=5, **kwargs):
def __init__(self, host, port, username=None, password=None, compress=True, path='/gelf', timeout=5, **kwargs):
"""
Logging handler that transforms each record into GELF (graylog extended log format) and sends it over HTTP.

Expand All @@ -159,15 +163,23 @@ def __init__(self, host, port, compress=True, path='/gelf', timeout=5, **kwargs)
if compress:
self.headers['Content-Encoding'] = 'gzip,deflate'

if username and password:
self.headers['Authorization'] = get_basic_auth_header(username, password)

def emit(self, record):
data = self.convert_record_to_gelf(record)
connection = httplib.HTTPConnection(host=self.host, port=self.port, timeout=self.timeout)
connection.request('POST', self.path, data, self.headers)
try:
data = self.convert_record_to_gelf(record)
connection = httplib.HTTPConnection(host=self.host, port=self.port, timeout=self.timeout)
connection.request('POST', self.path, data, self.headers)
res = connection.getresponse()
assert res.status == httplib.ACCEPTED
except:
self.handleError(record)


class GelfHttpsHandler(BaseHandler, LoggingHandler):

def __init__(self, host, port, compress=True, path='/gelf', timeout=5, validate=False, ca_certs=None, certfile=None, keyfile=None, keyfile_password=None, **kwargs):
def __init__(self, host, port, username=None, password=None, compress=True, path='/gelf', timeout=5, validate=False, ca_certs=None, certfile=None, keyfile=None, keyfile_password=None, **kwargs):
"""
Logging handler that transforms each record into GELF (graylog extended log format) and sends it over HTTP.

Expand Down Expand Up @@ -211,11 +223,18 @@ def __init__(self, host, port, compress=True, path='/gelf', timeout=5, validate=
# Load our CA file
self.ctx.load_verify_locations(cafile=self.ca_certs)


if compress:
self.headers['Content-Encoding'] = 'gzip,deflate'

if username and password:
self.headers['Authorization'] = get_basic_auth_header(username, password)

def emit(self, record):
data = self.convert_record_to_gelf(record)
connection = httplib.HTTPSConnection(host=self.host, port=self.port, context=self.ctx, timeout=self.timeout)
connection.request('POST', self.path, data, self.headers)
try:
data = self.convert_record_to_gelf(record)
connection = httplib.HTTPSConnection(host=self.host, port=self.port, context=self.ctx, timeout=self.timeout)
connection.request('POST', self.path, data, self.headers)
res = connection.getresponse()
assert res.status == httplib.ACCEPTED
except:
self.handleError(record)