Added configuration files and TLS listening option
This commit is contained in:
parent
dafe3096ca
commit
0143977eb0
4 changed files with 132 additions and 20 deletions
59
cmd/server/config.go
Normal file
59
cmd/server/config.go
Normal file
|
@ -0,0 +1,59 @@
|
|||
/* diodemail - send-only smtp server
|
||||
* Copyright (c) 2024 Gnarwhal
|
||||
*
|
||||
* This file is part of SSHare.
|
||||
*
|
||||
* SSHare is free software: you can redistribute it and/or modify it under the terms of
|
||||
* the GNU General Public License as published by the Free Software Foundation,
|
||||
* either version 3 of the License, or (at your option) any later version.
|
||||
*
|
||||
* SSHare is distributed in the hope that it will be useful, but WITHOUT ANY
|
||||
* WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||
* more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License along with
|
||||
* SSHare. If not, see <https://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
package main
|
||||
|
||||
import (
|
||||
"os"
|
||||
"encoding/json"
|
||||
)
|
||||
|
||||
type Config struct {
|
||||
Host string
|
||||
Plain PlainConfig
|
||||
TLS TLSConfig
|
||||
}
|
||||
|
||||
type PlainConfig struct {
|
||||
Enabled bool
|
||||
Port string
|
||||
}
|
||||
|
||||
type TLSConfig struct {
|
||||
Enabled bool
|
||||
Port string
|
||||
CertPath string
|
||||
PrivateKeyPath string
|
||||
}
|
||||
|
||||
func LoadConfig(path string) (*Config, error) {
|
||||
contents, err := os.ReadFile(path)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
var config Config
|
||||
config.Plain.Enabled = false
|
||||
config.Plain.Port = "25"
|
||||
config.TLS.Enabled = false
|
||||
config.TLS.Port = "465"
|
||||
err = json.Unmarshal(contents, &config)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return &config, nil
|
||||
}
|
|
@ -20,15 +20,48 @@ package main
|
|||
|
||||
import (
|
||||
"log"
|
||||
"flag"
|
||||
"crypto/tls"
|
||||
|
||||
"forge.monodon.me/Gnarwhal/diodemail/smtp"
|
||||
)
|
||||
|
||||
func main() {
|
||||
err := smtp.Run(
|
||||
"localhost",
|
||||
"4650",
|
||||
false,
|
||||
var cert_path string
|
||||
flag.StringVar(&cert_path, "config", "/etc/diodemail/config.json", "Path to config file")
|
||||
flag.Parse()
|
||||
config, err := LoadConfig(cert_path)
|
||||
if err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
var plain_config *smtp.PlainConfig
|
||||
if config.Plain.Enabled {
|
||||
plain_config = &smtp.PlainConfig {
|
||||
config.Plain.Port,
|
||||
}
|
||||
}
|
||||
|
||||
var tls_config *smtp.TLSConfig
|
||||
if config.TLS.Enabled {
|
||||
certificate, err := tls.LoadX509KeyPair(
|
||||
config.TLS.CertPath,
|
||||
config.TLS.PrivateKeyPath,
|
||||
)
|
||||
if err != nil {
|
||||
log.Println(err)
|
||||
} else {
|
||||
tls_config = &smtp.TLSConfig {
|
||||
config.TLS.Port,
|
||||
tls.Config{Certificates: []tls.Certificate{certificate}},
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
err = smtp.Run(
|
||||
config.Host,
|
||||
plain_config,
|
||||
tls_config,
|
||||
)
|
||||
if err != nil {
|
||||
log.Fatal(err)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue