Log messages to email via Amazon SES
Project description
SES log handler
Log messages to email via Amazon SES
Rate limiting and bouncing are currently not supported.
If you are using Django then this is also possible using Django's AdminEmailHandler and django-ses which supports rate limiting via AWS_SES_AUTO_THROTTLE.
Quick start
Installation
pip install ses-log-handler
If you using IAM roles to get credentials for AWS or have the correct environmental variables defined (see Boto3 configuration guide) then you can simply set a sender
and recipients
addresses for the handler:
import logging
logger = logging.getLogger(__name__)
ses_handler = SESHandler(
sender='from@example.com',
recipients=['to@example.com'],
)
ses_handler.setLevel(logging.ERROR)
logger.addHandler(ses_handler)
There is an example of how to configure the log hander using dictConfig()
and fileConfig()
Note: It is advised you set the log level to either CRITICAL
or ERROR
. This will stop the reciver_mails from being spammed by logs and you incuring a large SES bill.
Configuration options
If you want to explitily set the access, secret and region this can also be when instantiating the SESHandler
.
It also possible to force the subject line to be the same for each email
mail_handler = SESHandler(
sender='from@example.com',
recipients=('to@example.com'),
access_key='<access-key>',
secret_key='<secret-key>',
region='<region>',
subject='Error: Exception raised',
)
sender
Required: Who the log email should be sent from. The domain should be added and configured as a verified sender domain
recipients
Required: A list of recipients who should recieve the log emails.
If your SES account only has "sandbox" access (see SES dashboard) these email addresses must be added as verified sender email address
access_key
Optional: The AWS access key for a user who has access to send emails via SES.
It is best practices for managing AWS access keys use instance roles instead of passing access keys to your application.
If the access_key argument is not provided then the SESHandler (which uses boto3) will fall back to getting credentials from either the instance role or environmental varibales. See the boto3 credentials guide for more information.
secret_key
Optional: The AWS secret key for a user who has access to send emails via SES.
It is best practices for managing AWS access keys use instance roles instead of passing access keys to your application.
If the access_key argument is not provided then the SESHandler (which uses boto3) will fall back to getting credentials from either the instance role or environmental varibales. See the boto3 credentials guide for more information.
region
Optional: The AWS region which should be used to send emails via SES
By default the region your application is running in will be used
subject
Optional: Force override the subject line to be the same for each email.
The default is <log_level>: <message>
Configuration examles
The below examples both create a logging config which logs everything ERROR
and above to SES and anything WARNING
and below to the console.
Dict config
import logging
LOGGING = {
'version': 1,
'disable_existing_loggers': False,
'formatters': {
'general': {
'format': '%(asctime)s %(name)s.%(funcName)s %(levelname)s [%(lineno)d] %(message)s', # NOQA: E501
}
},
'handlers': {
'console': {
'class': 'logging.StreamHandler',
'formatter': 'general',
'level': 'INFO',
},
'ses': {
'class': 'ses_log_handler.SESHandler',
'formatter': 'general',
'level': 'ERROR',
'sender': 'from@example.com',
'recipients': ['to@example.com'],
},
},
'root': {
'level': 'INFO',
'handlers': ['ses', 'console'],
}
}
logging.config.dictConfig(LOGGING)
File config
[loggers]
keys=root
[handlers]
keys=sesHandler,consoleHandler
[formatters]
keys=generalFormatter
[logger_root]
level=INFO
handlers=sesHandler,consoleHandler
[handler_consoleHandler]
class=StreamHandler
level=INFO
formatter=generalFormatter
args=(sys.stdout,)
[handler_sesHandler]
class=ses_log_handler.SESHandler
level=ERROR
formatter=generalFormatter
args=['from@example.com', ['to@example.com']]
[formatter_generalFormatter]
format=%(asctime)s %(name)s.%(funcName)s %(levelname)s [%(lineno)d] %(message)s
Then to load this config you can use
import logging
logging.config.fileConfig(
'logging.conf',
disable_existing_loggers=False
)
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for ses_log_handler-1.0.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 11c82c9a19dbfbfb7c47077ac44ef8df6c3b77ea9b6d32a4ca495e8c9c3fe35e |
|
MD5 | 46ae98c6557090a60ee86895ebeaf75e |
|
BLAKE2b-256 | 397df0f884b0ab0db5a348f6c305973091f444f9c84910f1dc588e21ba491f5a |