代码拉取完成,页面将自动刷新
/*
Copyright SecureKey Technologies Inc. All Rights Reserved.
SPDX-License-Identifier: Apache-2.0
*/
package resource
import (
"fmt"
"io/ioutil"
"os"
"path/filepath"
"github.com/golang/protobuf/proto"
"github.com/hyperledger/fabric-protos-go/msp"
mspcfg "gitee.com/hyperledger-fabric-gm/fabric-sdk-go/internal/github.com/hyperledger/fabric/msp"
)
const (
cacerts = "cacerts"
admincerts = "admincerts"
intermediatecerts = "intermediatecerts"
crlsfolder = "crls"
tlscacerts = "tlscacerts"
tlsintermediatecerts = "tlsintermediatecerts"
)
// GenerateMspDir generates a MSP directory, using values from the provided MSP config.
// The intended usage is within the scope of creating a genesis block. This means
// private keys are currently not handled.
func GenerateMspDir(mspDir string, config *msp.MSPConfig) error {
if mspcfg.ProviderTypeToString(mspcfg.ProviderType(config.Type)) != "bccsp" {
return fmt.Errorf("Unsupported MSP config type")
}
cfg := &msp.FabricMSPConfig{}
err := proto.Unmarshal(config.Config, cfg)
if err != nil {
return err
}
type certDirDefinition struct {
dir string
certs [][]byte
}
defs := []certDirDefinition{
{cacerts, cfg.RootCerts},
{admincerts, cfg.Admins},
{intermediatecerts, cfg.IntermediateCerts},
{tlscacerts, cfg.TlsRootCerts},
{tlsintermediatecerts, cfg.TlsIntermediateCerts},
{crlsfolder, cfg.RevocationList},
}
for _, d := range defs {
errGen := generateCertDir(filepath.Join(mspDir, d.dir), d.certs)
if errGen != nil {
return errGen
}
}
return err
}
func generateCertDir(certDir string, certs [][]byte) error {
err := os.MkdirAll(certDir, 0750)
if err != nil {
return err
}
if len(certs) == 0 {
return nil
}
for counter, certBytes := range certs {
fileName := filepath.Join(certDir, "cert"+fmt.Sprintf("%d", counter)+".pem")
err = ioutil.WriteFile(fileName, certBytes, 0640)
if err != nil {
return err
}
}
return nil
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。