A python library to enable easy alerting services across multiple channels.
A library that can communicate with any alerting channel like Email, SMS, Slack etc.. A library that can generate reports by aggregating information and sending an alert when it crosses customizable thresholds.
We often raise alerts from code. Sometimes these alerts require some processing themselves which litter the actual code. Getting an aggregated alert allows us to determine if there are any major breakages in the product and act on them quickly. It also allows us to determine the severity of the alert in case we’re getting a lot of them through the day.
TBF
Simply use the following command to install the latest released version:
pip install goonj
Define channels needed for alerting
channels:
email_channels:
- name: email_channel1
to: [email protected],[email protected]
subject:
from_add: [email protected]
- name: aaaaa
to:
subject:
from_add:
slack_channels:
- name: xyz_channel
webhook: https://hooks.slack.com/services/T067891FY/B95PKS6TZ/WuDm9lYHF
- name: abc_channel
webhook: https://hooks.slack.com/services/T067891FY/B95PKS6TZ/WuDm9lYHF
sms_channels:
- name : sms1
phone_numbers: 1234567890,1234567890
- name : sms2
phone_numbers: 1234567890
Specify settings for channels
email_settings:
custom_notification_service: samples.module.CustomNotificationService
sms_settings:
custom_notification_service: samples.module.CustomNotificationService
#these are modules for custom notfication that will be called for sending email/sms which extends BaseCustomEmailNotificationService or BaseCustomSMSNotificationService
example for CustomNotificationService
class CustomNotificationService(BaseCustomEmailNotificationService,
BaseCustomSmsNotificationService):
def send_email_notification(self, from_add, to, sev, message, subject,
error_id,
error,
tag_list):
print('your logic to send email ')
def send_sms_notification(self, phone_numbers, sev, message, subject,
error_id,
error,
tag_list):
print('Your logic to send sms here ')
You can define a source ,Each source can have different sevs ( high medium low) and channels assocaited with it
source_name1:
sev:
high:
email_channels: Each sev will have diffrent channels associated with it
- sohit
slack_channels:
- xyz_channel
sms_channels:
- sms1
low:
email_channels:
- sohit
Initialize the goonj
core.Goonj(config_file_path='/path/to/config/goonj.yaml')
Get alert source , you can inject logger as well and goonj will take care of logging
smart_alert = get_smart_alert('source_name1', logger)
If you need only looging
Use .format to pass string variable instead
smart_alert.info("your genreral logging mesage {}".format("abc"))
smart_alert.error("")
smart_alert.warn()
smart_alert.exception()
smart_alert.error()
if you need alerting along with logging , pass the sev , it will send alert to channels associated with the given sev in config file
smart_alert.info("your message ",sev=Sev.HIGH,subject="subject for alert")
smart_alert.error("your message",sev=Sev.HIGH,subject="subject for alert")
smart_alert.warn("your message",sev=Sev.HIGH,subject="subject for alert")
smart_alert.exception("your message",sev=Sev.HIGH,subject="subject for alert")
smart_alert.error("your message",sev=Sev.HIGH,subject="subject for alert")
Here are the basic limitations which need to be kept in mind while using the library:
- TBF
The current limitation of the library is planed to be addressed in the future releases. also below are some of the key features which are planed for future releases:
- TBF
This project has been inspired to solve basic alerting service requirements.