ogvt/main.go

62 lines
1.1 KiB
Go
Raw Normal View History

2020-02-06 15:09:47 +00:00
package main
import (
"flag"
"fmt"
"io"
"os"
"strings"
2020-02-06 15:09:47 +00:00
"golang.org/x/crypto/openpgp"
)
func open(path string) io.Reader {
f, err := os.Open(path)
if err != nil {
fmt.Println(err)
os.Exit(1)
}
return f
}
func main() {
var sig, file, pub string
flag.StringVar(&sig, "sig", "", "path to signature file")
flag.StringVar(&file, "file", "", "path to file")
flag.StringVar(&pub, "pub", "", "path to pub file")
flag.Parse()
pledge("stdio tty unveil rpath")
unveil(sig, "r")
unveil(file, "r")
unveil(pub, "r")
unveilBlock()
2020-02-06 15:09:47 +00:00
kr, err := openpgp.ReadArmoredKeyRing(open(pub))
if err != nil {
fmt.Println(err)
os.Exit(1)
}
var ent *openpgp.Entity
switch {
case strings.HasSuffix(sig, ".sig"):
case strings.HasSuffix(sig, ".gpg"):
2020-02-06 23:59:46 +00:00
ent, err = openpgp.CheckDetachedSignature(kr, open(file), open(sig))
case strings.HasSuffix(sig, ".asc"):
2020-02-06 23:59:46 +00:00
ent, err = openpgp.CheckArmoredDetachedSignature(kr, open(file), open(sig))
}
2020-02-06 15:09:47 +00:00
if err != nil {
fmt.Println(err)
os.Exit(1)
}
for _, id := range ent.Identities {
fmt.Printf("%s\n", id.Name)
}
fmt.Println("Signature OK.")
}