在Hyperledger Fabric中,我已在同一链码中加载了两个合同(两个控制器)。在对等CLI上,我只能调用在代码中加载的第一个协定方法。
“正在调用链码Invoke()返回错误响应[错误:您已要求调用不存在的函数:createPost]。将错误消息发送回同位体”
我的index.ts(打字稿): 导出const合同:any [] = [stController,PostController];
2019-03-25T21:11:23.217Z INFO [contracts-spi/chaincodefromcontract.js] Metadata is :
{ contracts:
{ stController:
{ name: 'stController',
contractInstance: { name: 'stController', default: true },
transactions:
[ { name: 'initLedger' },
{ name: 'queryStDoc' },
{ name: 'createStDoc' },
{ name: 'queryAllStDocs' },
{ name: 'queryStByOwner' },
{ name: 'changeStOwner' },
{ name: 'cancel' } ],
info: { title: '', version: '' } },
PostController:
{ name: 'PostController',
contractInstance: { name: 'PostController' },
transactions: [ { name: 'createPost' }, { name: 'deletePost' } ],
info: { title: '', version: '' } },
'org.hyperledger.fabric':
{ name: 'org.hyperledger.fabric',
contractInstance: { name: 'org.hyperledger.fabric' },
transactions: [ { name: 'GetMetadata' } ],
info: { title: '', version: '' } } },
info: { version: '1.0.0', title: 'sget' },
components: { schemas: {} } }
答案 0 :(得分:0)
我没有在Typescript中做到这一点,但是我在JavaScript中做了同样的事情-我在两个协定中都使用了一个超类型来获得一个命名空间来区分这些协定。 (在我的示例中,我有重复的函数名称-Fabcar的2个副本。)
constructor() {
super('org.example.car');
}
constructor() {
super('org.example.rob');
}
然后,我从cli调用如下函数:
peer chaincode invoke -o orderer.example.com:7050 -C mychannel -c '{"Args":["org.example.car:queryCar","CAR2"]}' -n fcnstest
和
peer chaincode invoke -o orderer.example.com:7050 -C mychannel -c '{"Args":["org.example.rob:changeCarOwner","CAR2","Rob"]}' -n fcnstest
Commercial Paper tutorial有一个使用命名空间/超类型的示例。但这也是Javascript而不是打字稿。