-
-
Save sylm87/ccc55315d33b558b71dccaabd918766a to your computer and use it in GitHub Desktop.
Golang encrypt file using GPG openpgp. Use standard go libs.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
package main | |
/** | |
Example hack to encrypt a file using a GPG encryption key. Works with GPG v2.x. | |
The encrypted file e.g. /tmp/data.txt.gpg can then be decrypted using the standard command | |
gpg /tmp/data.txt.gpg | |
Assumes you have **created** an encryption key and exported armored version. | |
You have to read the armored key directly as Go cannot read pubring.kbx (yet). | |
Export your key using command: | |
gpg2 --export --armor [KEY ID] > /tmp/pubKey.asc | |
*/ | |
import ( | |
"fmt" | |
"golang.org/x/crypto/openpgp" | |
"golang.org/x/crypto/openpgp/armor" | |
"golang.org/x/crypto/openpgp/packet" | |
"io" | |
"log" | |
"os" | |
) | |
// change as required | |
const pubKey = "/tmp/pubKey.asc" | |
const fileToEnc = "/tmp/data.txt" | |
func main() { | |
log.Println("Public key:", pubKey) | |
// Read in public key | |
recipient, err := readEntity(pubKey) | |
if err != nil { | |
fmt.Println(err) | |
return | |
} | |
f, err := os.Open(fileToEnc) | |
if err != nil { | |
fmt.Println(err) | |
return | |
} | |
defer f.Close() | |
dst, err := os.Create(fileToEnc + ".gpg") | |
if err != nil { | |
fmt.Println(err) | |
return | |
} | |
defer dst.Close() | |
encrypt([]*openpgp.Entity{recipient}, nil, f, dst) | |
} | |
func encrypt(recip []*openpgp.Entity, signer *openpgp.Entity, r io.Reader, w io.Writer) error { | |
wc, err := openpgp.Encrypt(w, recip, signer, &openpgp.FileHints{IsBinary: true}, nil) | |
if err != nil { | |
return err | |
} | |
if _, err := io.Copy(wc, r); err != nil { | |
return err | |
} | |
return wc.Close() | |
} | |
func readEntity(name string) (*openpgp.Entity, error) { | |
f, err := os.Open(name) | |
if err != nil { | |
return nil, err | |
} | |
defer f.Close() | |
block, err := armor.Decode(f) | |
if err != nil { | |
return nil, err | |
} | |
return openpgp.ReadEntity(packet.NewReader(block.Body)) | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment