Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/harryzcy/mailbox
Versatile email infrastructure on AWS serverless
https://github.com/harryzcy/mailbox
api aws aws-apigateway aws-dynamodb aws-lambda aws-s3 aws-ses aws-sqs go mailbox mailbox-service self-hosted serverless
Last synced: 3 months ago
JSON representation
Versatile email infrastructure on AWS serverless
- Host: GitHub
- URL: https://github.com/harryzcy/mailbox
- Owner: harryzcy
- License: mit
- Created: 2021-01-01T15:41:41.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2024-11-14T16:42:49.000Z (3 months ago)
- Last Synced: 2024-11-14T17:35:33.918Z (3 months ago)
- Topics: api, aws, aws-apigateway, aws-dynamodb, aws-lambda, aws-s3, aws-ses, aws-sqs, go, mailbox, mailbox-service, self-hosted, serverless
- Language: Go
- Homepage:
- Size: 1.16 MB
- Stars: 246
- Watchers: 4
- Forks: 15
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Security: SECURITY.md
Awesome Lists containing this project
README
# Mailbox
[data:image/s3,"s3://crabby-images/2ea83/2ea83c11fe6554659c35d21d25e8554ac8cc4dd7" alt="Tests"](https://github.com/harryzcy/mailbox/actions)
[data:image/s3,"s3://crabby-images/d8dca/d8dca20e694c1acde729b707abb62988e80f0e53" alt="codecov"](https://codecov.io/gh/harryzcy/mailbox)
[data:image/s3,"s3://crabby-images/f6669/f66699868ea7182c066f5121309a4393f9c283f5" alt="Go Report Card"](https://goreportcard.com/report/github.com/harryzcy/mailbox)
[data:image/s3,"s3://crabby-images/a44b8/a44b8e253b62dba77541978b943b922f3636448d" alt="PRs Welcome"](http://makeapullrequest.com)
[data:image/s3,"s3://crabby-images/3f8ca/3f8ca92db27ca2648daf2a002bae8ee96d06fd9c" alt="License: MIT"](https://opensource.org/licenses/MIT)Docs: [English](README.md) • [简体中文](README_zh.md)
Versatile email infrastructure that operates on AWS.
## Clients
### Web
See [mailbox-browser](https://github.com/harryzcy/mailbox-browser)
| Dark mode | Light mode |
|:---------:|:-----------:|
| data:image/s3,"s3://crabby-images/8c02e/8c02ea47f35ecbe60173eecdf7f76680eefc5a2f" alt="Screenshot Dark Mode" | data:image/s3,"s3://crabby-images/3d14d/3d14d87d139d26ad7b7ff95beb2eb83a7b0e6696" alt="Screenshot Light Mode" |### CLI
```bash
go install github.com/harryzcy/mailbox-cli
```For details, refer to [mailbox-cli](https://github.com/harryzcy/mailbox-cli)
## Deploy
1. Clone the repository.
```shell
git clone https://github.com/harryzcy/mailbox
```1. Install [serverless](https://github.com/serverless/serverless).
```shell
npm install -g serverless@v3
```1. Create an IAM user.
Create an IAM user with AdministratorAccess and export the access key as environment variables.
```shell
export AWS_ACCESS_KEY_ID=
export AWS_SECRET_ACCESS_KEY=
```In production, setup the IAM user following [this guide from serverless](https://www.serverless.com/framework/docs/providers/aws/guide/credentials).
1. Setup AWS services.
Manually create S3 buckets, and setup SES and SQS (optional) from AWS console.
1. Copy over example configurations and fill in correct fields.
```shell
cp serverless.yml.example serverless.yml
```Under `provider.environment` section, modify `REGION`, `S3_BUCKET`, `SQS_QUEUE` (optional, only if SQS should be enabled).
1. Deploy the app.
```shell
make deploy
```1. Configure email receiving.
From AWS console -> Configuration -> Email receiving -> Create rule set -> Create rule, add two actions:
1. Deliver to Amazon S3 bucket, then enter your bucket name.
2. Invoke AWS Lambda function, and select `mailbox-dev-emailReceive` or `mailbox-prod-emailReceive`.1. Deploy [mailbox-browser](https://github.com/harryzcy/mailbox-browser) or use [mailbox-cli](https://github.com/harryzcy/mailbox-cli).
## API
See [doc/API.md](doc/api.md)
## Architecture
It runs on AWS services, including SES, Lambda, API Gateway, DynamoDB, and SQS.
data:image/s3,"s3://crabby-images/540d6/540d62bb206411e4c46d0a338a0849862f5d3fb1" alt="Architecture"
## Contributing
### Development environment
- Go >= 1.22
Note that only the two most recent minor versions of Go are officially supported.