Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/seatgeek/mailroom
Framework for creating, routing, and delivering user notifications based on events from external systems
https://github.com/seatgeek/mailroom
golang notifications webhooks
Last synced: 3 days ago
JSON representation
Framework for creating, routing, and delivering user notifications based on events from external systems
- Host: GitHub
- URL: https://github.com/seatgeek/mailroom
- Owner: seatgeek
- License: apache-2.0
- Created: 2024-11-25T14:30:21.000Z (3 months ago)
- Default Branch: main
- Last Pushed: 2025-02-10T11:34:27.000Z (11 days ago)
- Last Synced: 2025-02-10T12:32:41.870Z (11 days ago)
- Topics: golang, notifications, webhooks
- Language: Go
- Homepage: https://chairnerd.seatgeek.com/mailroom-notification-framework/
- Size: 1.21 MB
- Stars: 538
- Watchers: 12
- Forks: 18
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- Contributing: .github/CONTRIBUTING.md
- License: LICENSE
- Code of conduct: .github/CODE_OF_CONDUCT.md
- Security: .github/SECURITY.md
Awesome Lists containing this project
README
# data:image/s3,"s3://crabby-images/814d3/814d3ed00cfe6a360e333f61272db44524ea0807" alt="mailroom"
[data:image/s3,"s3://crabby-images/a8b7f/a8b7f763051199b5754c7a602b03ceffc18309eb" alt="GitHub Release"](https://github.com/seatgeek/mailroom/releases)
[data:image/s3,"s3://crabby-images/768a1/768a16668bef4d1a72bd172577a4be013fac21b4" alt="Go Reference"](https://pkg.go.dev/github.com/seatgeek/mailroom)
[data:image/s3,"s3://crabby-images/55e40/55e40d2ff4d52fff470153fd0c36dff859bc6a74" alt="go.mod"](go.mod)
[data:image/s3,"s3://crabby-images/495a4/495a41d00cacc501d828238fd1315e076b26f659" alt="LICENSE"](LICENSE)
[data:image/s3,"s3://crabby-images/16253/16253903b67f3b421e47577bd07a22a9f90ceaab" alt="Build Status"](https://github.com/seatgeek/mailroom/actions?query=workflow%3Atests+branch%3Amain)
[data:image/s3,"s3://crabby-images/c8b28/c8b288fa1c965b2ae0918b522ed66bd88b77eeb4" alt="Go Report Card"](https://goreportcard.com/report/github.com/seatgeek/mailroom)
[data:image/s3,"s3://crabby-images/4fc8c/4fc8c3c9bc2d98f31c16c5381d24e30d5675583e" alt="Codecov"](https://codecov.io/gh/seatgeek/mailroom)Mailroom is a framework that simplifies the creation, routing, and delivery of user notifications based on events from external systems.
data:image/s3,"s3://crabby-images/45cab/45cab559bde28826953c42931c0742d78076a991" alt="Flow diagram"
Mailroom is designed to be flexible and extensible, allowing you to easily add new handlers and transports as your needs grow and evolve. Simply write a function to transform incoming events into notifications, and Mailroom will take care of the rest, including:
- Acting as the primary notification relay for incoming webhooks from external systems
- Sending notifications to the appropriate users based on their preferences (e.g. PR reviews go to email, but build failures go to Slack)
- Formatting notifications for different transports (e.g. email, Slack, etc.)
- Matching usernames, emails, IDs, etc. across different systems
- Logging, error handling, retries, and moreSee [`internal/example.go`](./internal/example.go) for an example of how to use mailroom.
## Documentation
- [Getting Started](./docs/getting-started.md)
- [Core Concepts](./docs/core-concepts.md)
- [Integrations](./docs/integrations.md)Also see the [GoDoc](https://pkg.go.dev/github.com/seatgeek/mailroom) for documentation.
## Stability
Mailroom is currently in alpha. It works well in production, but the API may change at any time. We will do our best to note breaking changes in the release notes.
## Contributing
See [CONTRIBUTING.md](./.github/CONTRIBUTING.md) for contribution guidelines.
Use `make` to run all linters and tests locally.