代码拉取完成,页面将自动刷新
/*
Copyright IBM Corp. 2016 All Rights Reserved.
SPDX-License-Identifier: Apache-2.0
*/
package chaincode
import (
"fmt"
"io/ioutil"
"github.com/hyperledger/fabric/bccsp"
"github.com/hyperledger/fabric/core/common/ccpackage"
"github.com/hyperledger/fabric/protoutil"
"github.com/spf13/cobra"
)
// signpackageCmd returns the cobra command for signing a package
func signpackageCmd(cf *ChaincodeCmdFactory, cryptoProvider bccsp.BCCSP) *cobra.Command {
spCmd := &cobra.Command{
Use: "signpackage",
Short: "Sign the specified chaincode package",
Long: "Sign the specified chaincode package",
ValidArgs: []string{"2"},
RunE: func(cmd *cobra.Command, args []string) error {
if len(args) < 2 {
return fmt.Errorf("peer chaincode signpackage <inputpackage> <outputpackage>")
}
return signpackage(cmd, args[0], args[1], cf, cryptoProvider)
},
}
return spCmd
}
func signpackage(cmd *cobra.Command, ipackageFile string, opackageFile string, cf *ChaincodeCmdFactory, cryptoProvider bccsp.BCCSP) error {
// Parsing of the command line is done so silence cmd usage
cmd.SilenceUsage = true
var err error
if cf == nil {
cf, err = InitCmdFactory(cmd.Name(), false, false, cryptoProvider)
if err != nil {
return err
}
}
b, err := ioutil.ReadFile(ipackageFile)
if err != nil {
return err
}
env := protoutil.UnmarshalEnvelopeOrPanic(b)
env, err = ccpackage.SignExistingPackage(env, cf.Signer)
if err != nil {
return err
}
b = protoutil.MarshalOrPanic(env)
err = ioutil.WriteFile(opackageFile, b, 0700)
if err != nil {
return err
}
fmt.Printf("Wrote signed package to %s successfully\n", opackageFile)
return nil
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。