go-pgp-tool/main.go

147 lines
2.7 KiB
Go
Raw Normal View History

2018-03-07 15:36:24 +00:00
package main
import (
2018-03-09 06:04:27 +00:00
"errors"
2018-03-08 10:24:33 +00:00
"flag"
2018-03-07 15:36:24 +00:00
"io"
"log"
"os"
"path"
2018-03-08 10:24:33 +00:00
"git.trj.tw/root/go-pgp-tool/pgpcrypt"
2018-03-07 15:36:24 +00:00
"golang.org/x/crypto/openpgp"
2018-03-08 10:24:33 +00:00
"git.trj.tw/root/go-pgp-tool/libs"
"git.trj.tw/root/go-pgp-tool/tools"
)
var (
flags *libs.Flags
2018-03-07 15:36:24 +00:00
)
2018-03-08 10:24:33 +00:00
func init() {
flags = new(libs.Flags)
libs.RegFlag(flags)
flag.Parse()
}
2018-03-07 15:36:24 +00:00
// args [0] is this
func main() {
2018-03-08 10:24:33 +00:00
// check flags value
if !flags.Encrypt && !flags.Decrypt {
showUsage()
return
}
if flags.Decrypt && flags.Encrypt {
showUsage()
return
}
if len(flags.KeyFile) == 0 {
log.Fatal("please input KeyFile path")
}
if len(flags.SrcFile) == 0 {
log.Fatal("please input SrcFile path")
}
if len(flags.DstFile) == 0 {
log.Fatal("please input DstFile path")
2018-03-07 15:36:24 +00:00
}
2018-03-08 10:24:33 +00:00
// check file exists
if !tools.CheckExists(flags.KeyFile, false) {
log.Fatal("KeyFile not exists")
}
if !tools.CheckExists(flags.SrcFile, false) {
log.Fatal("SrcFile not exists")
}
dir := path.Dir(flags.DstFile)
if !tools.CheckExists(dir, true) {
log.Fatal("DstFile parent directory not exists")
}
if !flags.Override && tools.CheckExists(flags.DstFile, false) {
log.Fatal("DstFile has Exists if override add flag -y ")
}
2018-03-09 06:04:27 +00:00
flags.KeyFile = tools.ParsePath(flags.KeyFile)
flags.SrcFile = tools.ParsePath(flags.SrcFile)
flags.DstFile = tools.ParsePath(flags.DstFile)
2018-03-08 10:24:33 +00:00
if flags.Encrypt {
// encryptAction()
encrypt()
}
2018-03-09 06:04:27 +00:00
if flags.Decrypt {
decrypt()
2018-03-08 10:24:33 +00:00
}
2018-03-09 06:04:27 +00:00
}
2018-03-08 10:24:33 +00:00
2018-03-09 06:04:27 +00:00
func handleError(err error) {
if err != nil {
log.Fatal(err)
2018-03-07 15:36:24 +00:00
}
2018-03-09 06:04:27 +00:00
}
2018-03-07 15:36:24 +00:00
2018-03-09 06:04:27 +00:00
func showUsage() {
flag.Usage()
2018-03-08 10:24:33 +00:00
}
2018-03-09 06:04:27 +00:00
func decrypt() {
2018-03-08 10:24:33 +00:00
keyFile, err := os.Open(flags.KeyFile)
handleError(err)
defer keyFile.Close()
2018-03-07 15:36:24 +00:00
2018-03-09 06:04:27 +00:00
keyList, err := pgpcrypt.ReadKeyFile(keyFile)
2018-03-08 10:24:33 +00:00
handleError(err)
2018-03-09 06:04:27 +00:00
if len(keyList) == 0 {
handleError(errors.New("key not found"))
2018-03-07 15:36:24 +00:00
}
2018-03-09 06:04:27 +00:00
key := keyList[0]
passphraseByte := []byte(flags.Password)
key.PrivateKey.Decrypt(passphraseByte)
for _, sub := range key.Subkeys {
sub.PrivateKey.Decrypt(passphraseByte)
}
2018-03-08 10:24:33 +00:00
dstFile, err := os.Create(flags.DstFile)
handleError(err)
defer dstFile.Close()
2018-03-09 06:04:27 +00:00
srcFile, err := os.Open(flags.SrcFile)
2018-03-08 10:24:33 +00:00
handleError(err)
2018-03-09 06:04:27 +00:00
defer srcFile.Close()
2018-03-08 10:24:33 +00:00
2018-03-09 06:04:27 +00:00
md, err := openpgp.ReadMessage(srcFile, keyList, nil, nil)
2018-03-07 15:36:24 +00:00
2018-03-09 06:04:27 +00:00
_, err = io.Copy(dstFile, md.UnverifiedBody)
handleError(err)
2018-03-07 15:36:24 +00:00
}
2018-03-08 10:24:33 +00:00
func encrypt() {
keyFile, err := os.Open(flags.KeyFile)
2018-03-09 06:04:27 +00:00
handleError(err)
2018-03-07 15:36:24 +00:00
defer keyFile.Close()
2018-03-09 06:04:27 +00:00
keyList, err := pgpcrypt.ReadKeyFile(keyFile)
handleError(err)
2018-03-07 15:36:24 +00:00
2018-03-08 10:24:33 +00:00
distFile, err := os.Create(flags.DstFile)
2018-03-09 06:04:27 +00:00
handleError(err)
2018-03-07 15:36:24 +00:00
defer distFile.Close()
2018-03-08 10:24:33 +00:00
srcFile, err := os.Open(flags.SrcFile)
2018-03-09 06:04:27 +00:00
handleError(err)
2018-03-07 15:36:24 +00:00
defer srcFile.Close()
fhint := &openpgp.FileHints{}
fhint.IsBinary = true
tmpWriter, err := openpgp.Encrypt(distFile, keyList, nil, fhint, nil)
2018-03-09 06:04:27 +00:00
handleError(err)
2018-03-07 15:36:24 +00:00
defer tmpWriter.Close()
_, err = io.Copy(tmpWriter, srcFile)
2018-03-09 06:04:27 +00:00
handleError(err)
2018-03-07 15:36:24 +00:00
}