implementing read emails

master
bel 2020-04-01 05:00:53 +00:00
parent 4ca33e1c7b
commit aac86fc8c1
39 changed files with 2 additions and 74 deletions

View File

@ -1,73 +0,0 @@
package main
import (
"crypto/tls"
"fmt"
"net/smtp"
"strings"
)
type Emailer struct {
From string
SMTP string
POP3 string
Password string
}
func (e *Emailer) Send(to, subj, msg string) error {
headers := e.headers(to, e.From, subj)
body := e.body(headers, msg)
smtp, err := e.smtp()
if err != nil {
return err
}
defer smtp.Quit()
if err := smtp.Mail(e.From); err != nil {
return err
}
if err := smtp.Rcpt(to); err != nil {
return err
}
w, err := smtp.Data()
if err != nil {
return err
}
if _, err := w.Write([]byte(body)); err != nil {
return err
}
return w.Close()
}
func (e *Emailer) headers(to, from, subj string) map[string]string {
return map[string]string{
"To": to,
"From": from,
"Subject": subj,
}
}
func (e *Emailer) body(headers map[string]string, body string) string {
b := ""
for k, v := range headers {
b += fmt.Sprintf("%s: %s\r\n", k, v)
}
return b + "\r\n" + body
}
func (e *Emailer) smtp() (*smtp.Client, error) {
host := strings.Split(e.SMTP, ":")[0]
auth := smtp.PlainAuth("", e.From, e.Password, host)
tlsconfig := &tls.Config{ServerName: host}
conn, err := tls.Dial("tcp", e.SMTP, tlsconfig)
if err != nil {
return nil, fmt.Errorf("cannot dial %v: %v", e.SMTP, err)
}
smtp, err := smtp.NewClient(conn, host)
if err != nil {
return nil, fmt.Errorf("cannot new client %v: %v", host, err)
}
if err := smtp.Auth(auth); err != nil {
return nil, fmt.Errorf("cannot auth client: %v", err)
}
return smtp, nil
}

3
main.go Normal file → Executable file
View File

@ -2,6 +2,7 @@ package main
import (
"local/args"
"local/sandbox/contact/contact"
)
func main() {
@ -16,7 +17,7 @@ func main() {
if err := as.Parse(); err != nil {
panic(err)
}
emailer := &Emailer{
emailer := &contact.Emailer{
From: as.Get("from").GetString(),
SMTP: as.Get("smtp").GetString(),
POP3: as.Get("pop3").GetString(),

0
vendor/github.com/taknb2nch/go-pop3/LICENSE generated vendored Normal file → Executable file
View File

0
vendor/github.com/taknb2nch/go-pop3/README.md generated vendored Normal file → Executable file
View File

0
vendor/github.com/taknb2nch/go-pop3/pop3.go generated vendored Normal file → Executable file
View File

0
vendor/github.com/taknb2nch/go-pop3/pop3proto.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/LICENSE generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/PATENTS generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/cast5/cast5.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/openpgp/armor/armor.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/openpgp/armor/encode.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/openpgp/canonical_text.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/openpgp/elgamal/elgamal.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/openpgp/errors/errors.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/openpgp/keys.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/openpgp/packet/compressed.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/openpgp/packet/config.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/openpgp/packet/encrypted_key.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/openpgp/packet/literal.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/openpgp/packet/ocfb.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/openpgp/packet/one_pass_signature.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/openpgp/packet/opaque.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/openpgp/packet/packet.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/openpgp/packet/private_key.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/openpgp/packet/public_key.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/openpgp/packet/public_key_v3.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/openpgp/packet/reader.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/openpgp/packet/signature.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/openpgp/packet/signature_v3.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/openpgp/packet/symmetric_key_encrypted.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/openpgp/packet/symmetrically_encrypted.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/openpgp/packet/userattribute.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/openpgp/packet/userid.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/openpgp/read.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/openpgp/s2k/s2k.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/openpgp/write.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/ripemd160/ripemd160.go generated vendored Normal file → Executable file
View File

0
vendor/golang.org/x/crypto/ripemd160/ripemd160block.go generated vendored Normal file → Executable file
View File

0
vendor/vendor.json vendored Normal file → Executable file
View File