Documentation ¶
Overview ¶
Package configuration holds configuration for all components in Insolar host binary It allows also helps to manage config resources using Holder
Usage:
package main import ( "github.com/insolar/insolar/configuration" "fmt" ) func main() { holder := configuration.NewHolder() fmt.Printf("Default configuration:\n %+v\n", holder.Configuration) holder.SaveAs("insolar.yml") }
Index ¶
- func ToString(in interface{}) string
- type APIRunner
- type ArtifactManager
- type BuiltIn
- type Configuration
- type ConnectionType
- type GoPlugin
- type Holder
- type HostNetwork
- type JaegerConfig
- type JetCoordinator
- type Ledger
- type Log
- type LogicRunner
- type Metrics
- type Node
- type NodeNetwork
- type Pulsar
- type PulsarNodeAddress
- type PulseManager
- type Service
- type ServiceNetwork
- type Storage
- type Tracer
- type Transport
- type VersionManager
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
Types ¶
type APIRunner ¶ added in v0.2.0
APIRunner holds configuration for api
func NewAPIRunner ¶ added in v0.2.0
func NewAPIRunner() APIRunner
NewAPIRunner creates new api config
type ArtifactManager ¶ added in v0.6.3
type ArtifactManager struct { // Maximum pulse difference (NOT number of pulses) between current and the latest replicated on heavy. // IMPORTANT: It should be the same on ALL nodes. LightChainLimit core.PulseNumber }
ArtifactManager holds configuration for ArtifactManager.
type Configuration ¶
type Configuration struct { Host HostNetwork Node NodeNetwork Service ServiceNetwork Ledger Ledger Log Log Metrics Metrics LogicRunner LogicRunner APIRunner APIRunner Pulsar Pulsar VersionManager VersionManager KeysPath string CertificatePath string Tracer Tracer }
Configuration contains configuration params for all Insolar components
func NewConfiguration ¶
func NewConfiguration() Configuration
NewConfiguration creates new default configuration
type ConnectionType ¶ added in v0.3.0
type ConnectionType string
const (
TCP ConnectionType = "tcp"
)
func (ConnectionType) String ¶ added in v0.3.0
func (ct ConnectionType) String() string
type GoPlugin ¶ added in v0.0.6
type GoPlugin struct { // RunnerListen - address Go plugins executor listens to RunnerListen string // RunnerProtocol - protocol (network) of above address, // e.g. "tcp", "unix"... see `net.Dial` RunnerProtocol string }
GoPlugin configuration
type Holder ¶
type Holder struct { Configuration Configuration // contains filtered or unexported fields }
Holder provides methods to manage configuration
func (*Holder) Init ¶ added in v0.3.0
Init init all configuration data from config file and environment.
Does not fail on not found config file if the 'required' flag set to false.
func (*Holder) LoadFromFile ¶
LoadFromFile method reads configuration from particular file path
func (*Holder) MustInit ¶ added in v0.3.0
MustInit wrapper around Init function which panics on error.
type HostNetwork ¶
type HostNetwork struct { Transport Transport ConsensusTransport Transport BootstrapHosts []string IsRelay bool // set if node must be relay explicit InfinityBootstrap bool // set true for infinity tries to bootstrap Timeout int // bootstrap reconnect timeout MajorityRule int // MajorityRule number SignMessages bool // signing a messages if true }
HostNetwork holds configuration for HostNetwork
func NewHostNetwork ¶
func NewHostNetwork() HostNetwork
NewHostNetwork creates new default HostNetwork configuration
type JaegerConfig ¶ added in v0.6.2
JaegerConfig holds Jaeger settings.
type JetCoordinator ¶ added in v0.2.0
JetCoordinator holds configuration for JetCoordinator.
type Ledger ¶
type Ledger struct { // Storage defines storage configuration. Storage Storage // JetCoordinator defines jet coordinator configuration. JetCoordinator JetCoordinator // ArtifactManager holds configuration for ArtifactManager. ArtifactManager ArtifactManager // PulseManager holds configuration for PulseManager. PulseManager PulseManager }
Ledger holds configuration for ledger.
type LogicRunner ¶
type LogicRunner struct { // RPCListen - address logic runner binds RPC API to RPCListen string // RPCProtoco - protocol (network) of above address, // e.g. "tcp", "unix"... see `net.Dial` RPCProtocol string // BuiltIn - configuration of builtin executor BuiltIn *BuiltIn // GoPlugin - configuration of executor based on Go plugins GoPlugin *GoPlugin }
LogicRunner configuration
func NewLogicRunner ¶
func NewLogicRunner() LogicRunner
NewLogicRunner - returns default config of the logic runner
type Metrics ¶ added in v0.2.0
type Metrics struct { ListenAddress string Namespace string ZpagesEnabled bool // ReportingPeriod defines exporter reporting period // if zero, exporter uses default value (1s) ReportingPeriod time.Duration }
Metrics holds configuration for metrics publishing.
func NewMetrics ¶ added in v0.2.0
func NewMetrics() Metrics
NewMetrics creates new default configuration for metrics publishing.
type NodeNetwork ¶
type NodeNetwork struct {
Node *Node
}
NodeNetwork holds configuration for NodeNetwork
func NewNodeNetwork ¶
func NewNodeNetwork() NodeNetwork
NewNodeNetwork creates new default NodeNetwork configuration
type Pulsar ¶ added in v0.0.6
type Pulsar struct { ConnectionType ConnectionType MainListenerAddress string Storage Storage PulseTime int32 // ms ReceivingSignTimeout int32 // ms ReceivingNumberTimeout int32 // ms ReceivingVectorTimeout int32 // ms ReceivingSignsForChosenTimeout int32 // ms Neighbours []PulsarNodeAddress NumberOfRandomHosts int NumberDelta uint32 BootstrapListener Transport BootstrapNodes []string }
Pulsar holds configuration for pulsar node.
type PulsarNodeAddress ¶ added in v0.3.0
type PulsarNodeAddress struct { Address string ConnectionType ConnectionType PublicKey string }
type PulseManager ¶ added in v0.6.3
type PulseManager struct { // HeavySyncEnabled enables replication to heavy (could be disabled for testing purposes) HeavySyncEnabled bool // HeavySyncMessageLimit soft limit of single message for replication to heavy. HeavySyncMessageLimit int }
PulseManager holds configuration for PulseManager.
type ServiceNetwork ¶
type ServiceNetwork struct {
Service Service
}
ServiceNetwork is configuration for ServiceNetwork.
func NewServiceNetwork ¶
func NewServiceNetwork() ServiceNetwork
NewServiceNetwork creates a new ServiceNetwork configuration.
type Storage ¶ added in v0.2.0
type Storage struct { // DataDirectory is a directory where database's files live. DataDirectory string // TxRetriesOnConflict defines how many retries on transaction conflicts // storage update methods should do. TxRetriesOnConflict int }
Storage configures Ledger's storage.
type Tracer ¶ added in v0.6.2
type Tracer struct { Jaeger JaegerConfig // TODO: add SamplingRules configuration SamplingRules struct{} }
Tracer configures tracer.
type Transport ¶
type Transport struct { // protocol type UTP or KCP Protocol string // Address to listen Address string // if true transport will use network traversal technique(like STUN) to get PublicAddress BehindNAT bool }
Transport holds transport protocol configuration for HostNetwork
type VersionManager ¶ added in v0.6.3
type VersionManager struct {
MinAlowedVersion string
}
VersionManager holds configuration for VersionManager publishing.
func NewVersionManager ¶ added in v0.6.3
func NewVersionManager() VersionManager
NewVersionManager creates new default configuration for VersionManager publishing.