Create common db package. Move original message to fetch to db.
This commit is contained in:
@@ -1,47 +1,19 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"database/sql"
|
||||
"flag"
|
||||
"fmt"
|
||||
"os"
|
||||
"xinu.tv/email/db"
|
||||
|
||||
"github.com/golang/glog"
|
||||
_ "github.com/lib/pq"
|
||||
)
|
||||
|
||||
func fetchMessage(db *sql.DB, hash string) error {
|
||||
rows, err := db.Query(`
|
||||
SELECT
|
||||
blob
|
||||
FROM
|
||||
original
|
||||
WHERE
|
||||
hash = $1
|
||||
`, hash)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
var b []byte
|
||||
|
||||
for rows.Next() {
|
||||
if err := rows.Scan(&b); err != nil {
|
||||
return err
|
||||
}
|
||||
fmt.Println(string(b))
|
||||
}
|
||||
if err := rows.Err(); err != nil {
|
||||
return err
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
func main() {
|
||||
defer glog.Flush()
|
||||
flag.Parse()
|
||||
|
||||
// TODO(wathiede): make a set of flags.
|
||||
db, err := sql.Open("postgres", "user=gomail dbname=gomail sslmode=disable")
|
||||
c, err := db.NewConn("")
|
||||
if err != nil {
|
||||
glog.Fatal(err)
|
||||
}
|
||||
@@ -51,9 +23,11 @@ func main() {
|
||||
os.Exit(1)
|
||||
}
|
||||
|
||||
var blob []byte
|
||||
for _, hash := range flag.Args() {
|
||||
if err := fetchMessage(db, hash); err != nil {
|
||||
if err := c.OriginalBlobByHash(hash, &blob); err != nil {
|
||||
glog.Fatal(err)
|
||||
}
|
||||
fmt.Println(string(blob))
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user