forked from hyperledger/fabric
-
Notifications
You must be signed in to change notification settings - Fork 0
/
sysccprovider.go
65 lines (52 loc) · 2.37 KB
/
sysccprovider.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
/*
Copyright IBM Corp. 2017 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 sysccprovider
import (
"github.com/hyperledger/fabric/common/channelconfig"
"github.com/hyperledger/fabric/common/policies"
"github.com/hyperledger/fabric/core/ledger"
)
// SystemChaincodeProvider provides an abstraction layer that is
// used for different packages to interact with code in the
// system chaincode package without importing it; more methods
// should be added below if necessary
type SystemChaincodeProvider interface {
// IsSysCC returns true if the supplied chaincode is a system chaincode
IsSysCC(name string) bool
// IsSysCCAndNotInvokableCC2CC returns true if the supplied chaincode
// is a system chaincode and is not invokable through a cc2cc invocation
IsSysCCAndNotInvokableCC2CC(name string) bool
// IsSysCCAndNotInvokable returns true if the supplied chaincode
// is a system chaincode and is not invokable through a proposal
IsSysCCAndNotInvokableExternal(name string) bool
// GetQueryExecutorForLedger returns a query executor for the
// ledger of the supplied channel.
// That's useful for system chaincodes that require unfettered
// access to the ledger
GetQueryExecutorForLedger(cid string) (ledger.QueryExecutor, error)
// GetApplicationConfig returns the configtxapplication.SharedConfig for the channel
// and whether the Application config exists
GetApplicationConfig(cid string) (channelconfig.Application, bool)
// Returns the policy manager associated to the passed channel
// and whether the policy manager exists
PolicyManager(channelID string) (policies.Manager, bool)
}
// ChaincodeInstance is unique identifier of chaincode instance
type ChaincodeInstance struct {
ChainID string
ChaincodeName string
ChaincodeVersion string
}
func (ci *ChaincodeInstance) String() string {
return ci.ChainID + "." + ci.ChaincodeName + "#" + ci.ChaincodeVersion
}