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  }