-
Notifications
You must be signed in to change notification settings - Fork 0
/
orderer.go
95 lines (79 loc) · 3 KB
/
orderer.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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
/*
Copyright IBM Corp. All Rights Reserved.
SPDX-License-Identifier: Apache-2.0
*/
package capabilities
import (
cb "github.com/hyperledger/fabric-protos-go/common"
)
const (
ordererTypeName = "Orderer"
// OrdererV1_1 is the capabilities string for standard new non-backwards compatible Fabric v1.1 orderer capabilities.
OrdererV1_1 = "V1_1"
// OrdererV1_4_2 is the capabilities string for standard new non-backwards compatible Fabric v1.4.2 orderer capabilities.
OrdererV1_4_2 = "V1_4_2"
// OrdererV2_0 is the capabilities string that defines new Fabric v2.0 orderer capabilities.
OrdererV2_0 = "V2_0"
)
// OrdererProvider provides capabilities information for orderer level config.
type OrdererProvider struct {
*registry
v11BugFixes bool
v142 bool
V20 bool
}
// NewOrdererProvider creates an orderer capabilities provider.
func NewOrdererProvider(capabilities map[string]*cb.Capability) *OrdererProvider {
cp := &OrdererProvider{}
cp.registry = newRegistry(cp, capabilities)
_, cp.v11BugFixes = capabilities[OrdererV1_1]
_, cp.v142 = capabilities[OrdererV1_4_2]
_, cp.V20 = capabilities[OrdererV2_0]
return cp
}
// Type returns a descriptive string for logging purposes.
func (cp *OrdererProvider) Type() string {
return ordererTypeName
}
// HasCapability returns true if the capability is supported by this binary.
func (cp *OrdererProvider) HasCapability(capability string) bool {
switch capability {
// Add new capability names here
case OrdererV1_1:
return true
case OrdererV1_4_2:
return true
case OrdererV2_0:
return true
default:
return false
}
}
// PredictableChannelTemplate specifies whether the v1.0 undesirable behavior of setting the /Channel
// group's mod_policy to "" and copying versions from the channel config should be fixed or not.
func (cp *OrdererProvider) PredictableChannelTemplate() bool {
return cp.v11BugFixes || cp.v142 || cp.V20
}
// Resubmission specifies whether the v1.0 non-deterministic commitment of tx should be fixed by re-submitting
// the re-validated tx.
func (cp *OrdererProvider) Resubmission() bool {
return cp.v11BugFixes || cp.v142 || cp.V20
}
// ExpirationCheck specifies whether the orderer checks for identity expiration checks
// when validating messages
func (cp *OrdererProvider) ExpirationCheck() bool {
return cp.v11BugFixes || cp.v142 || cp.V20
}
// ConsensusTypeMigration checks whether the orderer permits a consensus-type migration.
//
// A Kafka-based Ordering Service Node requires these capabilities in order to receive and process a config update
// with consensus-type migration change. Migration is supported from Kafka to Raft only.
// If not present, these config updates will be rejected.
func (cp *OrdererProvider) ConsensusTypeMigration() bool {
return cp.v142 || cp.V20
}
// UseChannelCreationPolicyAsAdmins determines whether the orderer should use the name
// "Admins" instead of "ChannelCreationPolicy" in the new channel config template.
func (cp *OrdererProvider) UseChannelCreationPolicyAsAdmins() bool {
return cp.V20
}