notify logo ![GitHub tag (latest SemVer)](https://img.shields.io/github/v/tag/nikoksr/notify?color=success&label=version&sort=semver) [![Go Report Card](https://goreportcard.com/badge/github.com/nikoksr/notify)](https://goreportcard.com/report/github.com/nikoksr/notify) [![Codacy Badge](https://app.codacy.com/project/badge/Grade/37fdff3c275c4a72a3a061f2d0ec5553)](https://www.codacy.com/gh/nikoksr/notify/dashboard?utm_source=github.com&utm_medium=referral&utm_content=nikoksr/notify&utm_campaign=Badge_Grade) [![Maintainability](https://api.codeclimate.com/v1/badges/b3afd7bf115341995077/maintainability)](https://codeclimate.com/github/nikoksr/notify/maintainability) [![FOSSA Status](https://app.fossa.com/api/projects/git%2Bgithub.com%2Fnikoksr%2Fnotify.svg?type=shield)](https://app.fossa.com/projects/git%2Bgithub.com%2Fnikoksr%2Fnotify?ref=badge_shield) [![go.dev reference](https://img.shields.io/badge/go.dev-reference-007d9c?logo=go&logoColor=white&style=flat)](https://pkg.go.dev/github.com/nikoksr/notify)
>

A dead simple Go library for sending notifications to various messaging services.

## About *Notify* was born out of my own need to have my API servers running in production be able to notify me when critical errors occur. Of course, _Notify_ can be used for any other purpose as well. The library is kept as simple as possible for quick integration and ease of use. ## Disclaimer Any misuse of this library is your own liability and responsibility and cannot be attributed to the authors of this library. See [license](LICENSE) for more. Spamming through the use of this library **may get you permanently banned** on most supported platforms. ## Install ```sh go get -u github.com/nikoksr/notify ``` ## Example usage ```go // Create our notifications distributor. notifier := notify.New() // Create a telegram service. Ignoring error for demo simplicity. telegramService, _ := telegram.New("your_telegram_api_token") // Passing a telegram chat id as receiver for our messages. // Basically where should our message be sent? telegramService.AddReceivers(-1234567890) // Tell our notifier to use the telegram service. You can repeat the above process // for as many services as you like and just tell the notifier to use them. // Inspired by http middlewares used in higher level libraries. notifier.UseServices(telegramService) // Send a test message. _ = notifier.Send( context.Background(), "Subject/Title", "The actual message - Hello, you awesome gophers! :)", ) ``` ## Supported services > Please create feature requests for missing services (see #3 for example) - *Amazon SES* - *Discord* - *Email* - *Line* - *Mailgun* - *Microsoft Teams* - *Plivo* - *Pushbullet* - *RocketChat* - *SendGrid* - *Slack* - *Telegram* - *Twitter* - *WhatsApp* - *WeChat* ## Credits - Amazon SES support: [aws/aws-sdk-go](https://github.com/aws/aws-sdk-go) - Discord support: [bwmarrin/discordgo](https://github.com/bwmarrin/discordgo) - Email support: [jordan-wright/email](https://github.com/jordan-wright/email) - Line support: [line/line-bot-sdk-go](https://github.com/line/line-bot-sdk-go) - Logo: [MariaLetta/free-gophers-pack](https://github.com/MariaLetta/free-gophers-pack) - Mailgun support: [mailgun/mailgun-go](https://github.com/mailgun/mailgun-go) - Microsoft Teams support: [atc0005/go-teams-notify](https://github.com/atc0005/go-teams-notify) - Plivo support: [plivo/plivo-go](https://github.com/plivo/plivo-go) - Pushbullet support: [cschomburg/go-pushbullet](https://github.com/cschomburg/go-pushbullet) - RocketChat Support: [RocketChat/Rocket.Chat.Go.SDK](https://github.com/RocketChat/Rocket.Chat.Go.SDK) - SendGrid support: [sendgrid/sendgrid-go](https://github.com/sendgrid/sendgrid-go) - Slack support: [slack-go/slack](https://github.com/slack-go/slack) - Telegram support: [go-telegram-bot-api/telegram-bot-api](https://github.com/go-telegram-bot-api/telegram-bot-api) - Twitter: [dghubble/go-twitter](https://github.com/dghubble/go-twitter) - WeChat: [silenceper/wechat](https://github.com/silenceper/wechat) - WhatsApp: [Rhymen/go-whatsapp](https://github.com/Rhymen/go-whatsapp) ## Author **Niko Köser** * Twitter: [@nikoksr](https://twitter.com/nikoksr) * Github: [@nikoksr](https://github.com/nikoksr) ## Contributing Contributions, issues and feature requests are welcome!
Feel free to check [issues page](https://github.com/nikoksr/notify/issues). You can also take a look at the [contributing guide](https://github.com/nikoksr/notify/blob/main/CONTRIBUTING.md). ## Show your support Give a ⭐️ if you like this project! ## License [![FOSSA Status](https://app.fossa.com/api/projects/git%2Bgithub.com%2Fnikoksr%2Fnotify.svg?type=large)](https://app.fossa.com/projects/git%2Bgithub.com%2Fnikoksr%2Fnotify?ref=badge_large)