代码拉取完成,页面将自动刷新
/*
Copyright IBM Corp. 2016 All Rights Reserved.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package crypto
import (
"errors"
"github.com/hyperledger/fabric/core/crypto/primitives"
"github.com/hyperledger/fabric/core/crypto/utils"
obc "github.com/hyperledger/fabric/protos"
)
type clientImpl struct {
*nodeImpl
// Chain
chainPublicKey primitives.PublicKey
queryStateKey []byte
// TCA KDFKey
tCertOwnerKDFKey []byte
tCertPool tCertPool
}
// NewChaincodeDeployTransaction is used to deploy chaincode.
func (client *clientImpl) NewChaincodeDeployTransaction(chaincodeDeploymentSpec *obc.ChaincodeDeploymentSpec, uuid string, attributes ...string) (*obc.Transaction, error) {
// Verify that the client is initialized
if !client.IsInitialized() {
return nil, utils.ErrNotInitialized
}
// Get next available (not yet used) transaction certificate
tCerts, err := client.tCertPool.GetNextTCerts(1, attributes...)
if err != nil {
client.Errorf("Failed to obtain a (not yet used) TCert for Chaincode Deploy[%s].", err.Error())
return nil, err
}
if len(tCerts) != 1 {
client.Error("Failed to obtain a (not yet used) TCert.")
return nil, errors.New("Failed to obtain a TCert for Chaincode Deploy Transaction using TCert. Expected exactly one returned TCert.")
}
// Create Transaction
return client.newChaincodeDeployUsingTCert(chaincodeDeploymentSpec, uuid, attributes, tCerts[0].tCert, nil)
}
// GetNextTCerts Gets next available (not yet used) transaction certificate.
func (client *clientImpl) GetNextTCerts(nCerts int, attributes ...string) (tCerts []tCert, err error) {
if nCerts < 1 {
return nil, errors.New("Number of requested TCerts has to be positive!")
}
// Verify that the client is initialized
if !client.IsInitialized() {
return nil, utils.ErrNotInitialized
}
// Get next available (not yet used) transaction certificate
tBlocks, err := client.tCertPool.GetNextTCerts(nCerts, attributes...)
if err != nil {
client.Errorf("Failed getting [%d] (not yet used) Transaction Certificates (TCerts) [%s].", nCerts, err.Error())
return nil, err
}
tCerts = make([]tCert, len(tBlocks))
for i, eachBlock := range tBlocks {
tCerts[i] = eachBlock.tCert
}
return tCerts, nil
}
// NewChaincodeInvokeTransaction is used to invoke chaincode's functions.
func (client *clientImpl) NewChaincodeExecute(chaincodeInvocation *obc.ChaincodeInvocationSpec, uuid string, attributes ...string) (*obc.Transaction, error) {
// Verify that the client is initialized
if !client.IsInitialized() {
return nil, utils.ErrNotInitialized
}
// Get next available (not yet used) transaction certificate
tBlocks, err := client.tCertPool.GetNextTCerts(1, attributes...)
if err != nil {
client.Errorf("Failed to obtain a (not yet used) TCert [%s].", err.Error())
return nil, err
}
if len(tBlocks) != 1 {
client.Error("Failed to obtain a (not yet used) TCert.")
return nil, errors.New("Failed to obtain a TCert for Chaincode Execution. Expected exactly one returned TCert.")
}
// Create Transaction
return client.newChaincodeExecuteUsingTCert(chaincodeInvocation, uuid, attributes, tBlocks[0].tCert, nil)
}
// NewChaincodeQuery is used to query chaincode's functions.
func (client *clientImpl) NewChaincodeQuery(chaincodeInvocation *obc.ChaincodeInvocationSpec, uuid string, attributes ...string) (*obc.Transaction, error) {
// Verify that the client is initialized
if !client.IsInitialized() {
return nil, utils.ErrNotInitialized
}
// Get next available (not yet used) transaction certificate
tBlocks, err := client.tCertPool.GetNextTCerts(1, attributes...)
if err != nil {
client.Errorf("Failed to obtain a (not yet used) TCert [%s].", err.Error())
return nil, err
}
if len(tBlocks) != 1 {
client.Error("Failed to obtain a (not yet used) TCert.")
return nil, errors.New("Failed to obtain a TCert for Chaincode Invocation. Expected exactly one returned TCert.")
}
// Create Transaction
return client.newChaincodeQueryUsingTCert(chaincodeInvocation, uuid, attributes, tBlocks[0].tCert, nil)
}
// GetEnrollmentCertHandler returns a CertificateHandler whose certificate is the enrollment certificate
func (client *clientImpl) GetEnrollmentCertificateHandler() (CertificateHandler, error) {
// Verify that the client is initialized
if !client.IsInitialized() {
return nil, utils.ErrNotInitialized
}
// Return the handler
handler := &eCertHandlerImpl{}
err := handler.init(client)
if err != nil {
client.Errorf("Failed getting handler [%s].", err.Error())
return nil, err
}
return handler, nil
}
// GetTCertHandlerNext returns a CertificateHandler whose certificate is the next available TCert
func (client *clientImpl) GetTCertificateHandlerNext(attributes ...string) (CertificateHandler, error) {
// Verify that the client is initialized
if !client.IsInitialized() {
return nil, utils.ErrNotInitialized
}
// Get next TCert
tBlocks, err := client.tCertPool.GetNextTCerts(1, attributes...)
if err != nil {
client.Errorf("Failed to obtain a (not yet used) TCert for creating a CertificateHandler [%s].", err.Error())
return nil, err
}
if len(tBlocks) != 1 {
client.Error("Failed to obtain a TCert for creating a CertificateHandler.")
return nil, errors.New("Failed to obtain a TCert for creating a CertificateHandler")
}
// Return the handler
handler := &tCertHandlerImpl{}
err = handler.init(client, tBlocks[0].tCert)
if err != nil {
client.Errorf("Failed getting handler [%s].", err.Error())
return nil, err
}
return handler, nil
}
// GetTCertHandlerFromDER returns a CertificateHandler whose certificate is the one passed
func (client *clientImpl) GetTCertificateHandlerFromDER(tCertDER []byte) (CertificateHandler, error) {
// Verify that the client is initialized
if !client.IsInitialized() {
return nil, utils.ErrNotInitialized
}
// Validate the transaction certificate
tCert, err := client.getTCertFromExternalDER(tCertDER)
if err != nil {
client.Warningf("Failed validating transaction certificate [%s].", err)
return nil, err
}
// Return the handler
handler := &tCertHandlerImpl{}
err = handler.init(client, tCert)
if err != nil {
client.Errorf("Failed getting handler [%s].", err.Error())
return nil, err
}
return handler, nil
}
func (client *clientImpl) register(id string, pwd []byte, enrollID, enrollPWD string) (err error) {
clentRegFunc := func(eType NodeType, name string, pwd []byte, enrollID, enrollPWD string) error {
client.Info("Register crypto engine...")
err = client.registerCryptoEngine()
if err != nil {
client.Errorf("Failed registering crypto engine [%s]: [%s].", enrollID, err.Error())
return nil
}
client.Info("Register crypto engine...done.")
return nil
}
if err = client.nodeImpl.register(NodeClient, id, pwd, enrollID, enrollPWD, clentRegFunc); err != nil {
client.Errorf("Failed registering client [%s]: [%s]", enrollID, err)
return err
}
return nil
}
func (client *clientImpl) init(id string, pwd []byte) error {
clientInitFunc := func(eType NodeType, name string, pwd []byte) error {
// Initialize keystore
client.Debug("Init keystore...")
err := client.initKeyStore()
if err != nil {
if err != utils.ErrKeyStoreAlreadyInitialized {
client.Error("Keystore already initialized.")
} else {
client.Errorf("Failed initiliazing keystore [%s].", err.Error())
return err
}
}
client.Debug("Init keystore...done.")
// Init crypto engine
err = client.initCryptoEngine()
if err != nil {
client.Errorf("Failed initiliazing crypto engine [%s].", err.Error())
return err
}
return nil
}
if err := client.nodeImpl.init(NodeClient, id, pwd, clientInitFunc); err != nil {
return err
}
return nil
}
func (client *clientImpl) close() (err error) {
if client.tCertPool != nil {
if err = client.tCertPool.Stop(); err != nil {
client.Errorf("Failed closing TCertPool [%s]", err)
}
}
if err = client.nodeImpl.close(); err != nil {
client.Errorf("Failed closing node [%s]", err)
}
return
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。