Fabric SDK не может инициализировать конфигурацию криптографии - PullRequest
0 голосов
/ 31 марта 2019

Я управляю бизнес-сетью на платформе IBM Cloud Blockchain Platform 2.0. Я загрузил профиль подключения из раздела «Инстанцированные интеллектуальные контракты» на консоли платформы и пытаюсь подключиться с помощью Fabric SDK for Go, но я сталкиваюсь с ошибкой.

Это мой текущий соответствующий код, под основной

configOpts := fabricConfig.FromFile("./profiles/flex.json")
fabSDK, err := fabsdk.New(configOpts)
if err != nil {
    entry.WithError(err).Fatal("Error setting up Fabric SDK")
}
defer fabSDK.Close()

Ожидается: подключение к экземпляру бизнес-сети.

Фактически: я получаю ошибку

FATA[0000] Error setting up Fabric SDK env=DEV 
error="failed to initialize configuration: unable to initialize cryptosuite using crypto suite config: 
failed to initialize crypto suite: Unsupported BCCSP Provider: "

1 Ответ

0 голосов
/ 16 мая 2019

Я добавляю путь "cryptoconfig" к клиенту.

BCCSP не является обязательным, и вы можете удалить.

Я добавил пример конфигурации, см. Ниже.

Более подробная конфигурация на Github go-SDK config.yaml

{
"name": "first-network-org1",
"version": "1.0.0",
"client": {
    "organization": "Org1",
    "logging": {
        "level": "info"
    },
    "cryptoconfig": {
        "path": "crypto-config"
    },
    "credentialStore": {
        "path": "/tmp/keystore",
        "cryptoStore": {
            "path": "/tmp/msp"
        }
    },
    "connection": {
        "timeout": {
            "peer": {
                "endorser": "300"
            }
        }
    }
},
"channels": {
    "mychannel": {
        "peers": {
            "peer0.org1.example.com": {}
        }
    }
},
"orderers": {
    "orderer.example.com": {
        "url": "orderer.example.com:7050",
        "grpcOptions": {
            "ssl-target-name-override": "orderer.example.com",
            "keep-alive-time": "60s",
            "keep-alive-timeout": "60s",
            "keep-alive-permit": false,
            "fail-fast": false,
            "allow-insecure": false
        },
        "tlsCACerts": {
            "path": "crypto-config/ordererOrganizations/example.com/tlsca/tlsca.example.com-cert.pem"
        }
    }
},
"organizations": {
    "Org1": {
        "mspid": "Org1MSP",
        "cryptoPath": "crypto-config/peerOrganizations/org1.example.com/users/User1@org1.example.com/msp",
        "peers": [
            "peer0.org1.example.com",
            "peer1.org1.example.com"
        ],
        "certificateAuthorities": [
            "ca.org1.example.com"
        ]
    }
},
"peers": {
    "peer0.org1.example.com": {
        "url": "grpcs://localhost:7051",
        "tlsCACerts": {
            "path": "crypto-config/peerOrganizations/org1.example.com/tlsca/tlsca.org1.example.com-cert.pem"
        },
        "grpcOptions": {
            "ssl-target-name-override": "peer0.org1.example.com"
        }
    },
    "peer1.org1.example.com": {
        "url": "grpcs://localhost:8051",
        "tlsCACerts": {
            "path": "crypto-config/peerOrganizations/org1.example.com/tlsca/tlsca.org1.example.com-cert.pem"
        },
        "grpcOptions": {
            "ssl-target-name-override": "peer1.org1.example.com"
        }
    }
},
"certificateAuthorities": {
    "ca.org1.example.com": {
        "url": "https://localhost:7054",
        "caName": "ca-org1",
        "tlsCACerts": {
            "path": "crypto-config/peerOrganizations/org1.example.com/tlsca/tlsca.org1.example.com-cert.pem"
        },
        "httpOptions": {
            "verify": false
        }
    }
}

}

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...