From 823d2781614e05aea97fe4f99963567611d09d70 Mon Sep 17 00:00:00 2001 From: Alastair Porter Date: Wed, 31 Mar 2021 17:47:42 +0200 Subject: [PATCH] Allow downstream apps to pass options to sentry init --- brainzutils/flask/__init__.py | 3 ++- brainzutils/flask/loggers.py | 18 ++++++++++++------ 2 files changed, 14 insertions(+), 7 deletions(-) diff --git a/brainzutils/flask/__init__.py b/brainzutils/flask/__init__.py index 68d156d..d9ad389 100644 --- a/brainzutils/flask/__init__.py +++ b/brainzutils/flask/__init__.py @@ -66,10 +66,11 @@ def init_loggers(self, { 'dsn': 'YOUR_SENTRY_DSN', + 'environment': 'production', # optional 'level': 'WARNING', # optional } """ if file_config: loggers.add_file_handler(self, **file_config) if sentry_config: - loggers.add_sentry(self, **sentry_config) + loggers.add_sentry(**sentry_config) diff --git a/brainzutils/flask/loggers.py b/brainzutils/flask/loggers.py index e82f6bc..dc37190 100644 --- a/brainzutils/flask/loggers.py +++ b/brainzutils/flask/loggers.py @@ -20,12 +20,18 @@ def add_file_handler(app, filename, max_bytes=512 * 1024, backup_count=100): app.logger.addHandler(file_handler) -def add_sentry(app, dsn, level=logging.WARNING, **options): - """Adds Sentry logging. +def add_sentry(dsn, level=logging.WARNING, **options): + """Adds Sentry event logging. - Sentry is a realtime event logging and aggregation platform. Additional - information about it is available at https://sentry.readthedocs.org/. + Sentry is a realtime event logging and aggregation platform. + By default we add integration to the python logger, flask, redis, and sqlalchemy. + + Arguments: + dsn: The sentry DSN to connect to + level: the logging level at which logging messages are sent as events to sentry + options: Any other arguments to be passed to sentry_sdk.init. + See https://docs.sentry.io/platforms/python/configuration/options/ """ - app.config["SENTRY_CONFIG"] = options sentry_sdk.init(dsn, integrations=[LoggingIntegration(level=level), FlaskIntegration(), RedisIntegration(), - SqlalchemyIntegration()]) + SqlalchemyIntegration()], + **options)