Documentation ¶
Index ¶
- Variables
- func Get(key RootKey) interface{}
- func GetBool(key RootKey) bool
- func GetByteSize(key RootKey) int64
- func GetConfig() fftypes.JSONObject
- func GetDuration(key RootKey) time.Duration
- func GetFloat64(key RootKey) float64
- func GetInt(key RootKey) int
- func GetInt64(key RootKey) int64
- func GetKnownKeys() []string
- func GetObject(key RootKey) fftypes.JSONObject
- func GetObjectArray(key RootKey) fftypes.JSONObjectArray
- func GetString(key RootKey) string
- func GetStringSlice(key RootKey) []string
- func GetUint(key RootKey) uint
- func MergeConfig(configRecords []*fftypes.ConfigRecord) error
- func ReadConfig(cfgFile string) error
- func Reset()
- func Set(key RootKey, value interface{})
- func SetupLogging(ctx context.Context)
- type KeySet
- type Prefix
- type PrefixArray
- type RootKey
Constants ¶
This section is empty.
Variables ¶
var ( // APIDefaultFilterLimit is the default limit that will be applied to filtered queries on the API APIDefaultFilterLimit = rootKey("api.defaultFilterLimit") // APIMaxFilterLimit is the maximum limit that can be specified by an API call APIMaxFilterLimit = rootKey("api.maxFilterLimit") // APIMaxFilterSkip is the maximum skip value that can be specified on the API APIMaxFilterSkip = rootKey("api.maxFilterLimit") // APIRequestTimeout is the server side timeout for API calls (context timeout), to avoid the server continuing processing when the client gives up APIRequestTimeout = rootKey("api.requestTimeout") // APIRequestMaxTimeout is the maximum timeout an application can set using a Request-Timeout header APIRequestMaxTimeout = rootKey("api.requestMaxTimeout") // APIShutdownTimeout is the amount of time to wait for any in-flight requests to finish before killing the HTTP server APIShutdownTimeout = rootKey("api.shutdownTimeout") // APIOASPanicOnMissingDescription controls whether the OpenAPI Spec generator will strongly enforce descriptions on every field or not APIOASPanicOnMissingDescription = rootKey("api.oas.panicOnMissingDescription") // BatchCacheSize BatchCacheSize = rootKey("batch.cache.size") // BatchCacheSize BatchCacheTTL = rootKey("batch.cache.ttl") // BatchManagerReadPageSize is the size of each page of messages read from the database into memory when assembling batches BatchManagerReadPageSize = rootKey("batch.manager.readPageSize") // BatchManagerReadPollTimeout is how long without any notifications of new messages to wait, before doing a page query BatchManagerReadPollTimeout = rootKey("batch.manager.pollTimeout") // BatchManagerMinimumPollDelay is the minimum time the batch manager waits between polls on the DB - to prevent thrashing BatchManagerMinimumPollDelay = rootKey("batch.manager.minimumPollDelay") // BatchRetryFactor is the retry backoff factor for database operations performed by the batch manager BatchRetryFactor = rootKey("batch.retry.factor") // BatchRetryInitDelay is the retry initial delay for database operations BatchRetryInitDelay = rootKey("batch.retry.initDelay") // BatchRetryMaxDelay is the maximum delay between retry attempts BatchRetryMaxDelay = rootKey("batch.retry.maxDelay") // BlobReceiverRetryInitDelay is the initial retry delay BlobReceiverRetryInitDelay = rootKey("blobreceiver.retry.initialDelay") // BlobReceiverRetryMaxDelay is the maximum retry delay BlobReceiverRetryMaxDelay = rootKey("blobreceiver.retry.maxDelay") // BlobReceiverRetryFactor is the backoff factor to use for retries BlobReceiverRetryFactor = rootKey("blobreceiver.retry.factor") // BlobReceiverWorkerCount BlobReceiverWorkerCount = rootKey("blobreceiver.worker.count") // BlobReceiverWorkerBatchTimeout BlobReceiverWorkerBatchTimeout = rootKey("blobreceiver.worker.batchTimeout") // BlobReceiverWorkerBatchMaxInserts BlobReceiverWorkerBatchMaxInserts = rootKey("blobreceiver.worker.batchMaxInserts") // BlockchainEventCacheSize size of cache for blockchain events BlockchainEventCacheSize = rootKey("blockchainevent.cache.size") // BlockchainEventCacheTTL time to live of cache for blockchain events BlockchainEventCacheTTL = rootKey("blockchainevent.cache.ttl") // BlockchainType is the name of the blockchain interface plugin being used by this firefly node BlockchainType = rootKey("blockchain.type") // BroadcastBatchAgentTimeout how long to keep around a batching agent for a sending identity before disposal BroadcastBatchAgentTimeout = rootKey("broadcast.batch.agentTimeout") // BroadcastBatchSize is the maximum number of messages that can be packed into a batch BroadcastBatchSize = rootKey("broadcast.batch.size") // BroadcastBatchPayloadLimit is the maximum payload size of a batch for broadcast messages BroadcastBatchPayloadLimit = rootKey("broadcast.batch.payloadLimit") // BroadcastBatchTimeout is the timeout to wait for a batch to fill, before sending BroadcastBatchTimeout = rootKey("broadcast.batch.timeout") // DownloadWorkerCount is the number of download workers created to pull data from shared storage to the local DX DownloadWorkerCount = rootKey("download.worker.count") // DownloadWorkerQueueLength is the length of the work queue in the channel to the workers - defaults to 2x the worker count DownloadWorkerQueueLength = rootKey("download.worker.queueLength") // DownloadRetryMaxAttempts is the maximum number of automatic attempts to make for each shared storage download before failing the operation DownloadRetryMaxAttempts = rootKey("download.retry.maxAttempts") // DownloadRetryInitDelay is the initial retry delay DownloadRetryInitDelay = rootKey("download.retry.initialDelay") // DownloadRetryMaxDelay is the maximum retry delay DownloadRetryMaxDelay = rootKey("download.retry.maxDelay") // DownloadRetryFactor is the backoff factor to use for retries DownloadRetryFactor = rootKey("download.retry.factor") // PrivateMessagingBatchAgentTimeout how long to keep around a batching agent for a sending identity before disposal PrivateMessagingBatchAgentTimeout = rootKey("privatemessaging.batch.agentTimeout") // PrivateMessagingBatchSize is the maximum size of a batch for broadcast messages PrivateMessagingBatchSize = rootKey("privatemessaging.batch.size") // PrivateMessagingBatchPayloadLimit is the maximum payload size of a private message data exchange payload PrivateMessagingBatchPayloadLimit = rootKey("privatemessaging.batch.payloadLimit") // PrivateMessagingBatchTimeout is the timeout to wait for a batch to fill, before sending PrivateMessagingBatchTimeout = rootKey("privatemessaging.batch.timeout") // PrivateMessagingOpCorrelationRetries how many times to correlate an event for an operation (such as tx submission) back to an operation. // Needed because the operation update might come back before we are finished persisting the ID of the request PrivateMessagingOpCorrelationRetries = rootKey("privatemessaging.opCorrelationRetries") // PrivateMessagingRetryFactor the backoff factor to use for retry of database operations PrivateMessagingRetryFactor = rootKey("privatemessaging.retry.factor") // PrivateMessagingRetryInitDelay the initial delay to use for retry of data base operations PrivateMessagingRetryInitDelay = rootKey("privatemessaging.retry.initDelay") // PrivateMessagingRetryMaxDelay the maximum delay to use for retry of data base operations PrivateMessagingRetryMaxDelay = rootKey("privatemessaging.retry.maxDelay") // CorsAllowCredentials CORS setting to control whether a browser allows credentials to be sent to this API CorsAllowCredentials = rootKey("cors.credentials") // CorsAllowedHeaders CORS setting to control the allowed headers CorsAllowedHeaders = rootKey("cors.headers") // CorsAllowedMethods CORS setting to control the allowed methods CorsAllowedMethods = rootKey("cors.methods") // CorsAllowedOrigins CORS setting to control the allowed origins CorsAllowedOrigins = rootKey("cors.origins") // CorsDebug is whether debug is enabled for the CORS implementation CorsDebug = rootKey("cors.debug") // CorsEnabled is whether cors is enabled CorsEnabled = rootKey("cors.enabled") // CorsMaxAge is the maximum age a browser should rely on CORS checks CorsMaxAge = rootKey("cors.maxAge") // DataexchangeType is the name of the data exchange plugin being used by this firefly node DataexchangeType = rootKey("dataexchange.type") // DatabaseType the type of the database interface plugin to use DatabaseType = rootKey("database.type") // DatabaseMaxChartRows the maximum rows to fetch for each histogram bucket DatabaseMaxChartRows = rootKey("database.maxChartRows") // TokensList is the root key containing a list of supported token connectors TokensList = rootKey("tokens") // DebugPort a HTTP port on which to enable the go debugger DebugPort = rootKey("debug.port") // EventTransportsDefault the default event transport for new subscriptions EventTransportsDefault = rootKey("event.transports.default") // EventTransportsEnabled which event interface plugins are enabled EventTransportsEnabled = rootKey("event.transports.enabled") // EventAggregatorFirstEvent the first event the aggregator should process, if no previous offest is stored in the DB EventAggregatorFirstEvent = rootKey("event.aggregator.firstEvent") // EventAggregatorBatchSize the maximum number of records to read from the DB before performing an aggregation run EventAggregatorBatchSize = rootKey("event.aggregator.batchSize") // EventAggregatorBatchTimeout how long to wait for new events to arrive before performing aggregation on a page of events EventAggregatorBatchTimeout = rootKey("event.aggregator.batchTimeout") // EventAggregatorOpCorrelationRetries how many times to correlate an event for an operation (such as tx submission) back to an operation. // Needed because the operation update might come back before we are finished persisting the ID of the request EventAggregatorOpCorrelationRetries = rootKey("event.aggregator.opCorrelationRetries") // EventAggregatorPollTimeout the time to wait without a notification of new events, before trying a select on the table EventAggregatorPollTimeout = rootKey("event.aggregator.pollTimeout") // EventAggregatorRewindTimeout the minimum time to wait for rewinds to accumulate before resolving them EventAggregatorRewindTimeout = rootKey("event.aggregator.rewindTimeout") // EventAggregatorRewindQueueLength the size of the queue into the rewind dispatcher EventAggregatorRewindQueueLength = rootKey("event.aggregator.rewindQueueLength") // EventAggregatorRetryFactor the backoff factor to use for retry of database operations EventAggregatorRetryFactor = rootKey("event.aggregator.retry.factor") // EventAggregatorRetryInitDelay the initial delay to use for retry of data base operations EventAggregatorRetryInitDelay = rootKey("event.aggregator.retry.initDelay") // EventAggregatorRetryMaxDelay the maximum delay to use for retry of data base operations EventAggregatorRetryMaxDelay = rootKey("event.aggregator.retry.maxDelay") // EventDispatcherPollTimeout the time to wait without a notification of new events, before trying a select on the table EventDispatcherPollTimeout = rootKey("event.dispatcher.pollTimeout") // EventDispatcherBufferLength the number of events + attachments an individual dispatcher should hold in memory ready for delivery to the subscription EventDispatcherBufferLength = rootKey("event.dispatcher.bufferLength") // EventDispatcherBatchTimeout a short time to wait for new events to arrive before re-polling for new events EventDispatcherBatchTimeout = rootKey("event.dispatcher.batchTimeout") // EventDispatcherRetryFactor the backoff factor to use for retry of database operations EventDispatcherRetryFactor = rootKey("event.dispatcher.retry.factor") // EventDispatcherRetryInitDelay he initial delay to use for retry of data base operations EventDispatcherRetryInitDelay = rootKey("event.dispatcher.retry.initDelay") // EventDispatcherRetryMaxDelay he maximum delay to use for retry of data base operations EventDispatcherRetryMaxDelay = rootKey("event.dispatcher.retry.maxDelay") // EventDBEventsBufferSize the size of the buffer of change events EventDBEventsBufferSize = rootKey("event.dbevents.bufferSize") // EventListenerTopicCacheSize cache size for blockchain listeners addresses EventListenerTopicCacheSize = rootKey("event.listenerTopic.cache.size") // EventListenerTopicCacheTTL cache time-to-live for private group addresses EventListenerTopicCacheTTL = rootKey("event.listenerTopic.cache.ttl") // GroupCacheSize cache size for private group addresses GroupCacheSize = rootKey("group.cache.size") // GroupCacheTTL cache time-to-live for private group addresses GroupCacheTTL = rootKey("group.cache.ttl") // AdminEnabled determines whether the admin interface will be enabled or not AdminEnabled = rootKey("admin.enabled") // AdminPreinit waits for at least one ConfigREcord to be posted to the server before it starts (the database must be available on startup) AdminPreinit = rootKey("admin.preinit") // IdentityType the type of the identity plugin in use IdentityType = rootKey("identity.type") // IdentityManagerCacheTTL the identity manager cache time to live IdentityManagerCacheTTL = rootKey("identity.manager.cache.ttl") // IdentityManagerCacheLimit the identity manager cache limit in count of items IdentityManagerCacheLimit = rootKey("identity.manager.cache.limit") // Lang is the language to use for translation Lang = rootKey("lang") // LogForceColor forces color to be enabled, even if we do not detect a TTY LogForceColor = rootKey("log.forceColor") // LogLevel is the logging level LogLevel = rootKey("log.level") // LogNoColor forces color to be disabled, even if we detect a TTY LogNoColor = rootKey("log.noColor") // LogTimeFormat is a string format for timestamps LogTimeFormat = rootKey("log.timeFormat") // LogUTC sets log timestamps to the UTC timezone LogUTC = rootKey("log.utc") // LogFilename sets logging to file LogFilename = rootKey("log.filename") // LogFilesize sets the size to roll logs at LogFilesize = rootKey("log.filesize") // LogMaxBackups sets the maximum number of old files to keep LogMaxBackups = rootKey("log.maxBackups") // LogMaxAge sets the maximum age at which to roll LogMaxAge = rootKey("log.maxAge") // LogCompress sets whether to compress backups LogCompress = rootKey("log.compress") // MessageCacheSize MessageCacheSize = rootKey("message.cache.size") // MessageCacheTTL MessageCacheTTL = rootKey("message.cache.ttl") // MessageWriterCount MessageWriterCount = rootKey("message.writer.count") // MessageWriterBatchTimeout MessageWriterBatchTimeout = rootKey("message.writer.batchTimeout") // MessageWriterBatchMaxInserts MessageWriterBatchMaxInserts = rootKey("message.writer.batchMaxInserts") // MetricsEnabled determines whether metrics will be instrumented and if the metrics server will be enabled or not MetricsEnabled = rootKey("metrics.enabled") // MetricsPath determines what path to serve the Prometheus metrics from MetricsPath = rootKey("metrics.path") // NamespacesDefault is the default namespace - must be in the predefines list NamespacesDefault = rootKey("namespaces.default") // NamespacesPredefined is a list of namespaces to ensure exists, without requiring a broadcast from the network NamespacesPredefined = rootKey("namespaces.predefined") // NodeName is a description for the node NodeName = rootKey("node.name") // NodeDescription is a description for the node NodeDescription = rootKey("node.description") // OpUpdateRetryInitDelay is the initial retry delay OpUpdateRetryInitDelay = rootKey("opupdate.retry.initialDelay") // OpUpdatedRetryMaxDelay is the maximum retry delay OpUpdateRetryMaxDelay = rootKey("opupdate.retry.maxDelay") // OpUpdateRetryFactor is the backoff factor to use for retries OpUpdateRetryFactor = rootKey("opupdate.retry.factor") // OpUpdateWorkerCount OpUpdateWorkerCount = rootKey("opupdate.worker.count") // OpUpdateWorkerBatchTimeout OpUpdateWorkerBatchTimeout = rootKey("opupdate.worker.batchTimeout") // OpUpdateWorkerBatchMaxInserts OpUpdateWorkerBatchMaxInserts = rootKey("opupdate.worker.batchMaxInserts") // OpUpdateWorkerQueueLength OpUpdateWorkerQueueLength = rootKey("opupdate.worker.queueLength") // OrgName is the short name o the org OrgName = rootKey("org.name") // OrgIdentityDeprecated deprecated synonym to org.key OrgIdentityDeprecated = rootKey("org.identity") // OrgKey is the signing identity allocated to the organization (can be the same as the nodes) OrgKey = rootKey("org.key") // OrgDescription is a description for the org OrgDescription = rootKey("org.description") // OrchestratorStartupAttempts is how many time to attempt to connect to core infrastructure on startup OrchestratorStartupAttempts = rootKey("orchestrator.startupAttempts") SharedStorageType = rootKey("sharedstorage.type") // PublicStorageType specifies which shared storage interface plugin to use - deprecated in favor of SharedStorageType PublicStorageType = rootKey("publicstorage.type") // SubscriptionDefaultsReadAhead default read ahead to enable for subscriptions that do not explicitly configure readahead SubscriptionDefaultsReadAhead = rootKey("subscription.defaults.batchSize") // SubscriptionMax maximum number of pre-defined subscriptions that can exist (note for high fan-out consider connecting a dedicated pub/sub broker to the dispatcher) SubscriptionMax = rootKey("subscription.max") // SubscriptionsRetryInitialDelay is the initial retry delay SubscriptionsRetryInitialDelay = rootKey("subscription.retry.initDelay") // SubscriptionsRetryMaxDelay is the initial retry delay SubscriptionsRetryMaxDelay = rootKey("subscription.retry.maxDelay") // SubscriptionsRetryFactor the backoff factor to use for retry of database operations SubscriptionsRetryFactor = rootKey("subscription.retry.factor") // TransactionCacheSize TransactionCacheSize = rootKey("transaction.cache.size") // TransactionCacheTTL TransactionCacheTTL = rootKey("transaction.cache.ttl") // AssetManagerKeyNormalization mechanism to normalize keys before using them. Valid options: "blockchain_plugin" - use blockchain plugin (default), "none" - do not attempt normalization AssetManagerKeyNormalization = rootKey("asset.manager.keyNormalization") // UIEnabled set to false to disable the UI (default is true, so UI will be enabled if ui.path is valid) UIEnabled = rootKey("ui.enabled") // UIPath the path on which to serve the UI UIPath = rootKey("ui.path") // ValidatorCacheSize ValidatorCacheSize = rootKey("validator.cache.size") // ValidatorCacheTTL ValidatorCacheTTL = rootKey("validator.cache.ttl") )
The following keys can be access from the root configuration. Plugins are responsible for defining their own keys using the Config interface
Functions ¶
func GetConfig ¶
func GetConfig() fftypes.JSONObject
func GetDuration ¶
GetDuration gets a configuration time duration with consistent semantics
func GetObjectArray ¶
func GetObjectArray(key RootKey) fftypes.JSONObjectArray
GetObjectArray gets an array of configuration maps
func GetStringSlice ¶
GetStringSlice gets a configuration string array
func MergeConfig ¶
func MergeConfig(configRecords []*fftypes.ConfigRecord) error
Types ¶
type Prefix ¶
type Prefix interface { KeySet SetDefault(key string, defValue interface{}) SubPrefix(suffix string) Prefix Array() PrefixArray Set(key string, value interface{}) Resolve(key string) string GetString(key string) string GetBool(key string) bool GetInt(key string) int GetInt64(key string) int64 GetByteSize(key string) int64 GetUint(key string) uint GetDuration(key string) time.Duration GetStringSlice(key string) []string GetObject(key string) fftypes.JSONObject GetObjectArray(key string) fftypes.JSONObjectArray Get(key string) interface{} }
Prefix represents the global configuration, at a nested point in the config hierarchy. This allows plugins to define their Note that all values are GLOBAL so this cannot be used for per-instance customization. Rather for global initialization of plugins.
func NewPluginConfig ¶
NewPluginConfig creates a new plugin configuration object, at the specified prefix
type PrefixArray ¶
PrefixArray represents an array of options at a particular layer in the config. This allows specifying the schema of keys that exist for every entry, and the defaults, as well as querying how many entries exist and generating a prefix for each entry (so that you can iterate).