Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/camdram/email-webtools
A tiny micro-service to ensure that Camdram can send & receive emails 24/7/365
https://github.com/camdram/email-webtools
cambridge devops email go micro-service
Last synced: 2 months ago
JSON representation
A tiny micro-service to ensure that Camdram can send & receive emails 24/7/365
- Host: GitHub
- URL: https://github.com/camdram/email-webtools
- Owner: camdram
- License: mit
- Created: 2019-06-02T18:07:23.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2023-08-31T22:21:42.000Z (over 1 year ago)
- Last Synced: 2024-08-03T23:26:58.749Z (6 months ago)
- Topics: cambridge, devops, email, go, micro-service
- Language: Go
- Size: 641 KB
- Stars: 2
- Watchers: 7
- Forks: 0
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-golang-repositories - email-webtools - service to ensure that Camdram can send & receive emails 24/7/365 (Repositories)
README
# Camdram Email Web Tools
`email-webtools` is a small micro-service written in Go that we at Camdram use to monitor our Email systems and ensure that email receipt and delivery is functioning as expected.
## How does it work?
At Camdram we use [Postal](https://postal.atech.media/) for the sending and receiving of emails. This service connects to the Postal database in MySQL (technically MariaDB) and, when a correctly authenticated HTTP request is made, executes queries to determine the length of the mail queue and the volume of held mail.
Queued messages are messages that are actively awaiting delivery. Held messages are those that have been put to one side and will not be delivered, needing manual intervention.
## Compiling
We compile the project down to a single statically-linked executable which avoids having to install the entire Go toolchain on our server. Both of the methods detailed below produce a single `email-webtools` binary file in your working directory.
### Docker
First [install Docker](https://docs.docker.com/install/) and then run the following in a terminal window:
```bash
docker build -t camdram/email-webtools:latest .
docker run --rm -v ${PWD}:/app camdram/email-webtools:latest
```### Old School
You will need to install version 1.21.0 of the Go programming language (see [here](https://golang.org/doc/install#install) for details). Then run the build using the included Makefile:
```bash
make clean
make all
```## Deploying
You'll need to create a `.env` config file to house the authentication settings. This should contain something along the following lines:
```
HTTP_SERVER: hostname
HTTP_PORT: 8080
HTTP_AUTH_TOKEN: yourauthtoken
MYSQL_USER: username
MYSQL_PASSWORD: password
MAIN_DB: postal
SERVER_DB: postal-server-1
SMTP_TO: [email protected],[email protected]
```---
### Copyright
The code in this Git repository is released under the [MIT License](https://en.wikipedia.org/wiki/MIT_License).
Copyright (c) 2019 various members of the Camdram Web Team and other contributors.