gostfix is simple go-based mail-manager for postfix with web interface

Alexey Edelev 3a8d9b2846 Add setup scenario and fix annoying bugs 1 year ago
auth 3a8d9b2846 Add setup scenario and fix annoying bugs 1 year ago
common 4afce80e73 Various fixes 1 year ago
config 3a8d9b2846 Add setup scenario and fix annoying bugs 1 year ago
db 4afce80e73 Various fixes 1 year ago
sasl 83a3c0ce19 Add configurable server ports 3 years ago
scanner 3a8d9b2846 Add setup scenario and fix annoying bugs 1 year ago
setup 3a8d9b2846 Add setup scenario and fix annoying bugs 1 year ago
utils 813cf48034 Simplify mailbox handling 3 years ago
web 3a8d9b2846 Add setup scenario and fix annoying bugs 1 year ago
.gitignore 3a8d9b2846 Add setup scenario and fix annoying bugs 1 year ago
LICENSE 4174b9f7ad Implement basic project structure 4 years ago
README.md 74e9777f1b Refactor mail notifications 3 years ago
build.sh 3a8d9b2846 Add setup scenario and fix annoying bugs 1 year ago
go.mod 3a8d9b2846 Add setup scenario and fix annoying bugs 1 year ago
go.sum 3a8d9b2846 Add setup scenario and fix annoying bugs 1 year ago
main.go 3a8d9b2846 Add setup scenario and fix annoying bugs 1 year ago
views 4afce80e73 Various fixes 1 year ago

README.md

gostfix

gostfix is simple go-based mail-manager for postfix with web interface

Supported features:

  • ~Web admin interface~
  • Web mail interface
  • ~gRPC admin interface~
  • ~POP3 inteface~
  • ~IMAP interface~
  • SASL authentication

Prerequesties

gostfix only works on Linux-like operating systems

  • go 1.13 or higher
  • mongo 3.6 or higher
  • protobuf 3.6.1 or higher
  • nginx 1.18.0 or higher with websockets support

Installation and setup

TODO: Will be described later

Nginx

    listen 443 ssl;
    server_name mail.example.com;

    # Add proxy micro-web services
    location / {
        proxy_pass http://localhost:65200;
    }

    # Add web sockets proxy
    location ~ ^/m/[\d]+/notifierSubscribe$ {
        proxy_pass http://localhost:65200;
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "Upgrade";
        proxy_set_header Host $host;
    }


    # SSL configuration
    ssl_certificate /path/to/cert.pem;
    ssl_certificate_key /path/to/privkey.pem;