github.com/yinchengtsinghua/golang-Eos-dpos-Ethereum@v0.0.0-20190121132951-92cc4225ed8e/internal/build/pgp.go (about) 1 2 //此源码被清华学神尹成大魔王专业翻译分析并修改 3 //尹成QQ77025077 4 //尹成微信18510341407 5 //尹成所在QQ群721929980 6 //尹成邮箱 yinc13@mails.tsinghua.edu.cn 7 //尹成毕业于清华大学,微软区块链领域全球最有价值专家 8 //https://mvp.microsoft.com/zh-cn/PublicProfile/4033620 9 //版权所有2016 Go Ethereum作者 10 //此文件是Go以太坊库的一部分。 11 // 12 //Go-Ethereum库是免费软件:您可以重新分发它和/或修改 13 //根据GNU发布的较低通用公共许可证的条款 14 //自由软件基金会,或者许可证的第3版,或者 15 //(由您选择)任何更高版本。 16 // 17 //Go以太坊图书馆的发行目的是希望它会有用, 18 //但没有任何保证;甚至没有 19 //适销性或特定用途的适用性。见 20 //GNU较低的通用公共许可证,了解更多详细信息。 21 // 22 //你应该收到一份GNU较低级别的公共许可证副本 23 //以及Go以太坊图书馆。如果没有,请参见<http://www.gnu.org/licenses/>。 24 25 //signfile读取输入文件的内容并对其进行签名(装甲格式) 26 //在提供密钥的情况下,将签名放入输出文件。 27 28 package build 29 30 import ( 31 "bytes" 32 "fmt" 33 "os" 34 35 "golang.org/x/crypto/openpgp" 36 ) 37 38 //pgpsignfile从指定的字符串分析pgp私钥并创建 39 //在输入文件的输出参数中输入签名文件。 40 // 41 //注意,此方法假定一个键将是pgpkey参数中的容器, 42 //此外,它是装甲格式。 43 func PGPSignFile(input string, output string, pgpkey string) error { 44 //解析密钥环并确保我们只有一个私钥。 45 keys, err := openpgp.ReadArmoredKeyRing(bytes.NewBufferString(pgpkey)) 46 if err != nil { 47 return err 48 } 49 if len(keys) != 1 { 50 return fmt.Errorf("key count mismatch: have %d, want %d", len(keys), 1) 51 } 52 //创建用于签名的输入和输出流 53 in, err := os.Open(input) 54 if err != nil { 55 return err 56 } 57 defer in.Close() 58 59 out, err := os.Create(output) 60 if err != nil { 61 return err 62 } 63 defer out.Close() 64 65 //生成签名并返回 66 return openpgp.ArmoredDetachSign(out, keys[0], in, nil) 67 } 68 69 //pgpkeyid解析一个装甲密钥并返回密钥ID。 70 func PGPKeyID(pgpkey string) (string, error) { 71 keys, err := openpgp.ReadArmoredKeyRing(bytes.NewBufferString(pgpkey)) 72 if err != nil { 73 return "", err 74 } 75 if len(keys) != 1 { 76 return "", fmt.Errorf("key count mismatch: have %d, want %d", len(keys), 1) 77 } 78 return keys[0].PrimaryKey.KeyIdString(), nil 79 }