2021-03-01 20:49:43 +01:00
package steward
import (
"flag"
"fmt"
2021-03-25 11:28:26 +01:00
"log"
2021-03-01 20:49:43 +01:00
"os"
"path/filepath"
toml "github.com/pelletier/go-toml"
)
2021-09-09 08:19:53 +02:00
// Configuration are the structure that holds all the different
// configuration options used both with flags and the config file.
// If a new field is added to this struct there should also be
// added the same field to the ConfigurationFromFile struct, and
// an if check should be added to the checkConfigValues function
// to set default values when reading from config file.
2021-03-01 20:49:43 +01:00
type Configuration struct {
2021-12-21 07:21:12 +01:00
// RingBufferSize
RingBufferSize int
2021-03-01 20:49:43 +01:00
// The configuration folder on disk
ConfigFolder string
2021-05-12 09:50:03 +02:00
// The folder where the socket file should live
SocketFolder string
2021-08-23 16:00:48 +02:00
// TCP Listener for sending messages to the system
TCPListener string
2021-09-10 05:26:16 +02:00
// HTTP Listener for sending messages to the system
HTTPListener string
2021-05-12 09:50:03 +02:00
// The folder where the database should live
DatabaseFolder string
2021-03-01 20:49:43 +01:00
// some unique string to identify this Edge unit
NodeName string
// the address of the message broker
BrokerAddress string
2021-12-17 17:28:57 +01:00
// NatsConnOptTimeout the timeout for trying the connect to nats broker
NatsConnOptTimeout int
2021-09-01 13:39:54 +02:00
// nats connect retry
NatsConnectRetryInterval int
2021-12-16 11:01:01 +01:00
// NatsReconnectJitter in milliseconds
NatsReconnectJitter int
// NatsReconnectJitterTLS in seconds
NatsReconnectJitterTLS int
2022-05-26 08:07:23 +02:00
// REQKeysRequestUpdateInterval in seconds
REQKeysRequestUpdateInterval int
// REQAclRequestUpdateInterval in seconds
REQAclRequestUpdateInterval int
2021-03-01 20:49:43 +01:00
// The number of the profiling port
ProfilingPort string
// host and port for prometheus listener, e.g. localhost:2112
PromHostAndPort string
// set to true if this is the node that should receive the error log's from other nodes
DefaultMessageTimeout int
2021-11-18 06:36:16 +01:00
// Default value for how long can a request method max be allowed to run.
DefaultMethodTimeout int
2021-03-01 20:49:43 +01:00
// default amount of retries that will be done before a message is thrown away, and out of the system
DefaultMessageRetries int
2021-03-02 13:46:02 +01:00
// Publisher data folder
SubscribersDataFolder string
2021-03-12 10:41:03 +01:00
// central node to receive messages published from nodes
2021-03-12 11:13:42 +01:00
CentralNodeName string
2021-04-19 21:06:37 +02:00
// Path to the certificate of the root CA
RootCAPath string
2021-05-14 15:23:04 +02:00
// Full path to the NKEY's seed file
NkeySeedFile string
2022-04-04 07:44:44 +02:00
// NkeyPublicKey
2022-04-04 10:29:14 +02:00
NkeyPublicKey string ` toml:"-" `
2021-08-23 12:47:33 +02:00
// The host and port to expose the data folder
ExposeDataFolder string
2021-09-07 09:43:54 +02:00
// Timeout for error messages
ErrorMessageTimeout int
// Retries for error messages.
ErrorMessageRetries int
2021-12-29 06:17:40 +01:00
// Compression
2021-12-27 11:40:29 +01:00
Compression string
2021-12-29 06:17:40 +01:00
// Serialization
Serialization string
2021-12-31 06:59:09 +01:00
// SetBlockProfileRate for block profiling
SetBlockProfileRate int
2022-01-07 07:21:21 +01:00
// EnableSocket for enabling the creation of a steward.sock file
EnableSocket bool
2022-01-07 11:17:10 +01:00
// EnableTUI will enable the Terminal User Interface
EnableTUI bool
2022-02-09 14:59:40 +01:00
// EnableSignatureCheck
EnableSignatureCheck bool
2022-05-27 06:22:51 +02:00
// EnableAclCheck
EnableAclCheck bool
2022-02-09 09:06:06 +01:00
// IsCentralAuth
IsCentralAuth bool
2022-02-18 06:24:27 +01:00
// EnableDebug will also enable printing all the messages received in the errorKernel
// to STDERR.
EnableDebug bool
2021-09-20 06:40:34 +02:00
2021-04-05 08:37:24 +02:00
// Make the current node send hello messages to central at given interval in seconds
2021-04-06 05:46:07 +02:00
StartPubREQHello int
2022-05-30 07:14:15 +02:00
// Enable the updates of public keys
EnableKeyUpdates bool
2022-05-26 08:07:23 +02:00
2022-05-30 07:14:15 +02:00
// Enable the updates of acl's
EnableAclUpdates bool
2022-05-26 08:07:23 +02:00
2021-03-24 10:14:17 +01:00
// Start the central error logger.
2022-06-03 06:02:27 +02:00
IsCentralErrorLogger bool
2021-03-25 13:39:59 +01:00
// Subscriber for hello messages
2021-09-08 18:56:23 +02:00
StartSubREQHello bool
2021-03-26 09:08:47 +01:00
// Subscriber for text logging
2021-09-08 18:56:23 +02:00
StartSubREQToFileAppend bool
2021-04-06 19:42:03 +02:00
// Subscriber for writing to file
2021-09-08 18:56:23 +02:00
StartSubREQToFile bool
2022-03-04 15:02:43 +01:00
// Subscriber for writing to file without ACK
StartSubREQToFileNACK bool
2021-11-17 13:02:48 +01:00
// Subscriber for reading files to copy
StartSubREQCopyFileFrom bool
2021-11-18 09:34:16 +01:00
// Subscriber for writing copied files to disk
StartSubREQCopyFileTo bool
2022-06-09 05:59:37 +02:00
// Subscriber for reading files to copy
StartSubREQCopySrc bool
// Subscriber for writing copied files to disk
StartSubREQCopyDst bool
2021-03-26 09:08:47 +01:00
// Subscriber for Echo Request
2021-09-08 18:56:23 +02:00
StartSubREQPing bool
2021-03-26 09:08:47 +01:00
// Subscriber for Echo Reply
2021-09-08 18:56:23 +02:00
StartSubREQPong bool
2021-03-26 09:08:47 +01:00
// Subscriber for CLICommandRequest
2021-09-08 18:56:23 +02:00
StartSubREQCliCommand bool
2021-04-13 17:22:25 +02:00
// Subscriber for REQToConsole
2021-09-08 18:56:23 +02:00
StartSubREQToConsole bool
2021-04-06 19:42:03 +02:00
// Subscriber for REQHttpGet
2021-09-08 18:56:23 +02:00
StartSubREQHttpGet bool
2022-02-11 07:27:51 +01:00
// Subscriber for REQHttpGetScheduled
StartSubREQHttpGetScheduled bool
2021-04-13 11:28:52 +02:00
// Subscriber for tailing log files
2021-09-08 18:56:23 +02:00
StartSubREQTailFile bool
2021-08-10 12:49:42 +02:00
// Subscriber for continously delivery of output from cli commands.
2021-09-17 10:17:10 +02:00
StartSubREQCliCommandCont bool
2021-11-10 11:21:38 +01:00
// Subscriber for relay messages.
StartSubREQRelay bool
2021-03-01 20:49:43 +01:00
}
2021-09-09 08:19:53 +02:00
// ConfigurationFromFile should have the same structure as
// Configuration. This structure is used when parsing the
// configuration values from file, so we are able to detect
// if a value were given or not when parsing.
type ConfigurationFromFile struct {
2022-05-26 08:07:23 +02:00
ConfigFolder * string
RingBufferSize * int
SocketFolder * string
TCPListener * string
HTTPListener * string
DatabaseFolder * string
NodeName * string
BrokerAddress * string
NatsConnOptTimeout * int
NatsConnectRetryInterval * int
NatsReconnectJitter * int
NatsReconnectJitterTLS * int
REQKeysRequestUpdateInterval * int
REQAclRequestUpdateInterval * int
ProfilingPort * string
PromHostAndPort * string
DefaultMessageTimeout * int
DefaultMessageRetries * int
DefaultMethodTimeout * int
SubscribersDataFolder * string
CentralNodeName * string
RootCAPath * string
NkeySeedFile * string
ExposeDataFolder * string
ErrorMessageTimeout * int
ErrorMessageRetries * int
Compression * string
Serialization * string
SetBlockProfileRate * int
EnableSocket * bool
EnableTUI * bool
EnableSignatureCheck * bool
2022-05-27 06:22:51 +02:00
EnableAclCheck * bool
2022-05-26 08:07:23 +02:00
IsCentralAuth * bool
EnableDebug * bool
2021-12-27 11:40:29 +01:00
2022-05-30 07:14:15 +02:00
StartPubREQHello * int
EnableKeyUpdates * bool
EnableAclUpdates * bool
2022-06-03 06:02:27 +02:00
IsCentralErrorLogger * bool
2022-05-30 07:14:15 +02:00
StartSubREQHello * bool
StartSubREQToFileAppend * bool
StartSubREQToFile * bool
StartSubREQToFileNACK * bool
StartSubREQCopyFileFrom * bool
StartSubREQCopyFileTo * bool
2022-06-09 05:59:37 +02:00
StartSubREQCopySrc * bool
StartSubREQCopyDst * bool
2022-05-30 07:14:15 +02:00
StartSubREQPing * bool
StartSubREQPong * bool
StartSubREQCliCommand * bool
StartSubREQToConsole * bool
StartSubREQHttpGet * bool
StartSubREQHttpGetScheduled * bool
StartSubREQTailFile * bool
StartSubREQCliCommandCont * bool
StartSubREQRelay * bool
2021-09-09 08:19:53 +02:00
}
// NewConfiguration will return a *Configuration.
2021-03-01 20:49:43 +01:00
func NewConfiguration ( ) * Configuration {
c := Configuration { }
return & c
}
2021-09-09 08:19:53 +02:00
// Get a Configuration struct with the default values set.
2021-03-02 06:51:08 +01:00
func newConfigurationDefaults ( ) Configuration {
c := Configuration {
2022-05-26 08:07:23 +02:00
ConfigFolder : "./etc/" ,
RingBufferSize : 1000 ,
SocketFolder : "./tmp" ,
TCPListener : "" ,
HTTPListener : "" ,
DatabaseFolder : "./var/lib" ,
NodeName : "" ,
BrokerAddress : "127.0.0.1:4222" ,
NatsConnOptTimeout : 20 ,
NatsConnectRetryInterval : 10 ,
NatsReconnectJitter : 100 ,
NatsReconnectJitterTLS : 1 ,
REQKeysRequestUpdateInterval : 60 ,
REQAclRequestUpdateInterval : 60 ,
ProfilingPort : "" ,
PromHostAndPort : "" ,
DefaultMessageTimeout : 10 ,
DefaultMessageRetries : 1 ,
DefaultMethodTimeout : 10 ,
SubscribersDataFolder : "./data" ,
CentralNodeName : "" ,
RootCAPath : "" ,
NkeySeedFile : "" ,
ExposeDataFolder : "" ,
ErrorMessageTimeout : 60 ,
ErrorMessageRetries : 10 ,
Compression : "" ,
Serialization : "" ,
SetBlockProfileRate : 0 ,
EnableSocket : true ,
EnableTUI : false ,
EnableSignatureCheck : false ,
2022-05-27 06:22:51 +02:00
EnableAclCheck : false ,
2022-05-26 08:07:23 +02:00
IsCentralAuth : false ,
EnableDebug : false ,
2021-09-07 09:43:54 +02:00
2022-05-30 07:14:15 +02:00
StartPubREQHello : 30 ,
EnableKeyUpdates : true ,
EnableAclUpdates : true ,
2022-06-03 06:02:27 +02:00
IsCentralErrorLogger : false ,
2022-05-30 07:14:15 +02:00
StartSubREQHello : true ,
StartSubREQToFileAppend : true ,
StartSubREQToFile : true ,
StartSubREQToFileNACK : true ,
StartSubREQCopyFileFrom : true ,
StartSubREQCopyFileTo : true ,
2022-06-09 05:59:37 +02:00
StartSubREQCopySrc : true ,
StartSubREQCopyDst : true ,
2022-05-30 07:14:15 +02:00
StartSubREQPing : true ,
StartSubREQPong : true ,
StartSubREQCliCommand : true ,
StartSubREQToConsole : true ,
StartSubREQHttpGet : true ,
StartSubREQHttpGetScheduled : true ,
StartSubREQTailFile : true ,
StartSubREQCliCommandCont : true ,
StartSubREQRelay : false ,
2021-03-02 06:51:08 +01:00
}
return c
}
2021-09-09 08:19:53 +02:00
// Check if all values are present in config file, and if not
// found use the default value.
func checkConfigValues ( cf ConfigurationFromFile ) Configuration {
var conf Configuration
cd := newConfigurationDefaults ( )
2021-12-21 07:21:12 +01:00
if cf . RingBufferSize == nil {
conf . RingBufferSize = cd . RingBufferSize
} else {
conf . RingBufferSize = * cf . RingBufferSize
}
2021-09-09 08:19:53 +02:00
if cf . ConfigFolder == nil {
conf . ConfigFolder = cd . ConfigFolder
} else {
conf . ConfigFolder = * cf . ConfigFolder
}
if cf . SocketFolder == nil {
conf . SocketFolder = cd . SocketFolder
} else {
conf . SocketFolder = * cf . SocketFolder
}
if cf . TCPListener == nil {
conf . TCPListener = cd . TCPListener
} else {
conf . TCPListener = * cf . TCPListener
}
2021-09-10 05:26:16 +02:00
if cf . HTTPListener == nil {
conf . HTTPListener = cd . HTTPListener
} else {
conf . HTTPListener = * cf . HTTPListener
}
2021-09-09 08:19:53 +02:00
if cf . DatabaseFolder == nil {
conf . DatabaseFolder = cd . DatabaseFolder
} else {
conf . DatabaseFolder = * cf . DatabaseFolder
}
if cf . NodeName == nil {
conf . NodeName = cd . NodeName
} else {
conf . NodeName = * cf . NodeName
}
if cf . BrokerAddress == nil {
conf . BrokerAddress = cd . BrokerAddress
} else {
conf . BrokerAddress = * cf . BrokerAddress
}
2021-12-17 17:28:57 +01:00
if cf . NatsConnOptTimeout == nil {
conf . NatsConnOptTimeout = cd . NatsConnOptTimeout
} else {
conf . NatsConnOptTimeout = * cf . NatsConnOptTimeout
}
2021-09-09 08:19:53 +02:00
if cf . NatsConnectRetryInterval == nil {
conf . NatsConnectRetryInterval = cd . NatsConnectRetryInterval
} else {
conf . NatsConnectRetryInterval = * cf . NatsConnectRetryInterval
}
2021-12-16 11:01:01 +01:00
if cf . NatsReconnectJitter == nil {
conf . NatsReconnectJitter = cd . NatsReconnectJitter
} else {
conf . NatsReconnectJitter = * cf . NatsReconnectJitter
}
if cf . NatsReconnectJitterTLS == nil {
conf . NatsReconnectJitterTLS = cd . NatsReconnectJitterTLS
} else {
conf . NatsReconnectJitterTLS = * cf . NatsReconnectJitterTLS
}
2022-05-26 08:07:23 +02:00
if cf . REQKeysRequestUpdateInterval == nil {
conf . REQKeysRequestUpdateInterval = cd . REQKeysRequestUpdateInterval
} else {
conf . REQKeysRequestUpdateInterval = * cf . REQKeysRequestUpdateInterval
}
if cf . REQAclRequestUpdateInterval == nil {
conf . REQAclRequestUpdateInterval = cd . REQAclRequestUpdateInterval
2022-04-07 09:34:06 +02:00
} else {
2022-05-26 08:07:23 +02:00
conf . REQAclRequestUpdateInterval = * cf . REQAclRequestUpdateInterval
2022-04-07 09:34:06 +02:00
}
2021-09-09 08:19:53 +02:00
if cf . ProfilingPort == nil {
conf . ProfilingPort = cd . ProfilingPort
} else {
conf . ProfilingPort = * cf . ProfilingPort
}
if cf . PromHostAndPort == nil {
conf . PromHostAndPort = cd . PromHostAndPort
} else {
conf . PromHostAndPort = * cf . PromHostAndPort
}
if cf . DefaultMessageTimeout == nil {
conf . DefaultMessageTimeout = cd . DefaultMessageTimeout
} else {
conf . DefaultMessageTimeout = * cf . DefaultMessageTimeout
}
if cf . DefaultMessageRetries == nil {
conf . DefaultMessageRetries = cd . DefaultMessageRetries
} else {
conf . DefaultMessageRetries = * cf . DefaultMessageRetries
}
2021-11-18 06:36:16 +01:00
if cf . DefaultMethodTimeout == nil {
conf . DefaultMethodTimeout = cd . DefaultMethodTimeout
} else {
conf . DefaultMethodTimeout = * cf . DefaultMethodTimeout
}
2021-09-09 08:19:53 +02:00
if cf . SubscribersDataFolder == nil {
conf . SubscribersDataFolder = cd . SubscribersDataFolder
} else {
conf . SubscribersDataFolder = * cf . SubscribersDataFolder
}
if cf . CentralNodeName == nil {
conf . CentralNodeName = cd . CentralNodeName
} else {
conf . CentralNodeName = * cf . CentralNodeName
}
if cf . RootCAPath == nil {
conf . RootCAPath = cd . RootCAPath
} else {
conf . RootCAPath = * cf . RootCAPath
}
if cf . NkeySeedFile == nil {
conf . NkeySeedFile = cd . NkeySeedFile
} else {
conf . NkeySeedFile = * cf . NkeySeedFile
}
if cf . ExposeDataFolder == nil {
conf . ExposeDataFolder = cd . ExposeDataFolder
} else {
conf . ExposeDataFolder = * cf . ExposeDataFolder
}
if cf . ErrorMessageTimeout == nil {
conf . ErrorMessageTimeout = cd . ErrorMessageTimeout
} else {
conf . ErrorMessageTimeout = * cf . ErrorMessageTimeout
}
if cf . ErrorMessageRetries == nil {
conf . ErrorMessageRetries = cd . ErrorMessageRetries
} else {
conf . ErrorMessageRetries = * cf . ErrorMessageRetries
}
2021-12-26 07:16:14 +01:00
if cf . Compression == nil {
conf . Compression = cd . Compression
} else {
conf . Compression = * cf . Compression
}
2021-12-29 06:17:40 +01:00
if cf . Serialization == nil {
conf . Serialization = cd . Serialization
} else {
conf . Serialization = * cf . Serialization
}
2021-12-31 06:59:09 +01:00
if cf . SetBlockProfileRate == nil {
conf . SetBlockProfileRate = cd . SetBlockProfileRate
} else {
conf . SetBlockProfileRate = * cf . SetBlockProfileRate
}
2022-01-07 07:21:21 +01:00
if cf . EnableSocket == nil {
conf . EnableSocket = cd . EnableSocket
} else {
conf . EnableSocket = * cf . EnableSocket
}
2022-01-07 11:17:10 +01:00
if cf . EnableTUI == nil {
conf . EnableTUI = cd . EnableTUI
} else {
conf . EnableTUI = * cf . EnableTUI
}
2022-02-09 14:59:40 +01:00
if cf . EnableSignatureCheck == nil {
conf . EnableSignatureCheck = cd . EnableSignatureCheck
2022-02-03 11:11:21 +01:00
} else {
2022-02-09 14:59:40 +01:00
conf . EnableSignatureCheck = * cf . EnableSignatureCheck
2022-02-03 11:11:21 +01:00
}
2022-05-27 06:22:51 +02:00
if cf . EnableAclCheck == nil {
conf . EnableAclCheck = cd . EnableAclCheck
} else {
conf . EnableAclCheck = * cf . EnableAclCheck
}
2022-02-09 09:06:06 +01:00
if cf . IsCentralAuth == nil {
conf . IsCentralAuth = cd . IsCentralAuth
} else {
conf . IsCentralAuth = * cf . IsCentralAuth
}
2022-02-18 06:24:27 +01:00
if cf . EnableDebug == nil {
conf . EnableDebug = cd . EnableDebug
} else {
conf . EnableDebug = * cf . EnableDebug
}
2022-01-07 11:17:10 +01:00
// --- Start pub/sub
2021-12-26 07:16:14 +01:00
2021-09-09 08:19:53 +02:00
if cf . StartPubREQHello == nil {
conf . StartPubREQHello = cd . StartPubREQHello
} else {
conf . StartPubREQHello = * cf . StartPubREQHello
}
2022-05-30 07:14:15 +02:00
if cf . EnableKeyUpdates == nil {
conf . EnableKeyUpdates = cd . EnableKeyUpdates
2022-04-07 09:34:06 +02:00
} else {
2022-05-30 07:14:15 +02:00
conf . EnableKeyUpdates = * cf . EnableKeyUpdates
2022-04-07 09:34:06 +02:00
}
2022-05-26 08:07:23 +02:00
2022-05-30 07:14:15 +02:00
if cf . EnableAclUpdates == nil {
conf . EnableAclUpdates = cd . EnableAclUpdates
2022-05-26 08:07:23 +02:00
} else {
2022-05-30 07:14:15 +02:00
conf . EnableAclUpdates = * cf . EnableAclUpdates
2022-05-26 08:07:23 +02:00
}
2022-06-03 06:02:27 +02:00
if cf . IsCentralErrorLogger == nil {
conf . IsCentralErrorLogger = cd . IsCentralErrorLogger
2021-09-09 08:19:53 +02:00
} else {
2022-06-03 06:02:27 +02:00
conf . IsCentralErrorLogger = * cf . IsCentralErrorLogger
2021-09-09 08:19:53 +02:00
}
if cf . StartSubREQHello == nil {
conf . StartSubREQHello = cd . StartSubREQHello
} else {
conf . StartSubREQHello = * cf . StartSubREQHello
}
if cf . StartSubREQToFileAppend == nil {
conf . StartSubREQToFileAppend = cd . StartSubREQToFileAppend
} else {
conf . StartSubREQToFileAppend = * cf . StartSubREQToFileAppend
}
if cf . StartSubREQToFile == nil {
conf . StartSubREQToFile = cd . StartSubREQToFile
} else {
conf . StartSubREQToFile = * cf . StartSubREQToFile
}
2022-03-04 15:02:43 +01:00
if cf . StartSubREQToFileNACK == nil {
conf . StartSubREQToFileNACK = cd . StartSubREQToFileNACK
} else {
conf . StartSubREQToFileNACK = * cf . StartSubREQToFileNACK
}
2021-11-17 13:02:48 +01:00
if cf . StartSubREQCopyFileFrom == nil {
conf . StartSubREQCopyFileFrom = cd . StartSubREQCopyFileFrom
} else {
conf . StartSubREQCopyFileFrom = * cf . StartSubREQCopyFileFrom
}
2021-11-18 09:34:16 +01:00
if cf . StartSubREQCopyFileTo == nil {
conf . StartSubREQCopyFileTo = cd . StartSubREQCopyFileTo
} else {
conf . StartSubREQCopyFileTo = * cf . StartSubREQCopyFileTo
}
2022-06-09 05:59:37 +02:00
if cf . StartSubREQCopySrc == nil {
conf . StartSubREQCopySrc = cd . StartSubREQCopySrc
} else {
conf . StartSubREQCopySrc = * cf . StartSubREQCopySrc
}
if cf . StartSubREQCopyDst == nil {
conf . StartSubREQCopyDst = cd . StartSubREQCopyDst
} else {
conf . StartSubREQCopyDst = * cf . StartSubREQCopyDst
}
2021-09-09 08:19:53 +02:00
if cf . StartSubREQPing == nil {
conf . StartSubREQPing = cd . StartSubREQPing
} else {
conf . StartSubREQPing = * cf . StartSubREQPing
}
if cf . StartSubREQPong == nil {
conf . StartSubREQPong = cd . StartSubREQPong
} else {
conf . StartSubREQPong = * cf . StartSubREQPong
}
if cf . StartSubREQCliCommand == nil {
conf . StartSubREQCliCommand = cd . StartSubREQCliCommand
} else {
conf . StartSubREQCliCommand = * cf . StartSubREQCliCommand
}
if cf . StartSubREQToConsole == nil {
conf . StartSubREQToConsole = cd . StartSubREQToConsole
} else {
conf . StartSubREQToConsole = * cf . StartSubREQToConsole
}
if cf . StartSubREQHttpGet == nil {
conf . StartSubREQHttpGet = cd . StartSubREQHttpGet
} else {
conf . StartSubREQHttpGet = * cf . StartSubREQHttpGet
}
2022-02-11 07:27:51 +01:00
if cf . StartSubREQHttpGetScheduled == nil {
conf . StartSubREQHttpGetScheduled = cd . StartSubREQHttpGetScheduled
} else {
conf . StartSubREQHttpGetScheduled = * cf . StartSubREQHttpGetScheduled
}
2021-09-09 08:19:53 +02:00
if cf . StartSubREQTailFile == nil {
conf . StartSubREQTailFile = cd . StartSubREQTailFile
} else {
conf . StartSubREQTailFile = * cf . StartSubREQTailFile
}
2021-09-17 10:17:10 +02:00
if cf . StartSubREQCliCommandCont == nil {
conf . StartSubREQCliCommandCont = cd . StartSubREQCliCommandCont
2021-09-09 08:19:53 +02:00
} else {
2021-09-17 10:17:10 +02:00
conf . StartSubREQCliCommandCont = * cf . StartSubREQCliCommandCont
2021-09-09 08:19:53 +02:00
}
2021-11-10 11:21:38 +01:00
if cf . StartSubREQRelay == nil {
conf . StartSubREQRelay = cd . StartSubREQRelay
} else {
conf . StartSubREQRelay = * cf . StartSubREQRelay
}
2021-09-09 08:19:53 +02:00
return conf
}
2021-04-06 11:02:58 +02:00
// CheckFlags will parse all flags
2021-03-24 10:14:17 +01:00
func ( c * Configuration ) CheckFlags ( ) error {
2021-03-02 06:51:08 +01:00
// Create an empty default config
var fc Configuration
2021-08-23 11:45:31 +02:00
// Set default configfolder if no env was provided.
2021-08-27 10:49:06 +02:00
configFolder := os . Getenv ( "CONFIG_FOLDER" )
2021-08-23 11:45:31 +02:00
2021-08-27 12:19:35 +02:00
if configFolder == "" {
configFolder = "./etc/"
}
2021-08-23 11:45:31 +02:00
// Read file config. Set system default if it can't find config file.
2021-05-28 14:48:53 +02:00
fc , err := c . ReadConfigFile ( configFolder )
2021-03-25 11:28:26 +01:00
if err != nil {
log . Printf ( "%v\n" , err )
fc = newConfigurationDefaults ( )
}
2021-08-27 10:49:06 +02:00
if configFolder == "" {
fc . ConfigFolder = "./etc/"
} else {
fc . ConfigFolder = configFolder
}
2021-03-25 11:28:26 +01:00
* c = fc
2021-03-01 20:49:43 +01:00
2021-08-23 11:45:31 +02:00
//flag.StringVar(&c.ConfigFolder, "configFolder", fc.ConfigFolder, "Defaults to ./usr/local/steward/etc/. *NB* This flag is not used, if your config file are located somwhere else than default set the location in an env variable named CONFIGFOLDER")
2021-12-21 07:21:12 +01:00
flag . IntVar ( & c . RingBufferSize , "ringBufferSize" , fc . RingBufferSize , "size of the ringbuffer" )
2021-05-12 09:50:03 +02:00
flag . StringVar ( & c . SocketFolder , "socketFolder" , fc . SocketFolder , "folder who contains the socket file. Defaults to ./tmp/. If other folder is used this flag must be specified at startup." )
2021-08-23 16:00:48 +02:00
flag . StringVar ( & c . TCPListener , "tcpListener" , fc . TCPListener , "start up a TCP listener in addition to the Unix Socket, to give messages to the system. e.g. localhost:8888. No value means not to start the listener, which is default. NB: You probably don't want to start this on any other interface than localhost" )
2021-09-10 05:26:16 +02:00
flag . StringVar ( & c . HTTPListener , "httpListener" , fc . HTTPListener , "start up a HTTP listener in addition to the Unix Socket, to give messages to the system. e.g. localhost:8888. No value means not to start the listener, which is default. NB: You probably don't want to start this on any other interface than localhost" )
2021-05-12 09:50:03 +02:00
flag . StringVar ( & c . DatabaseFolder , "databaseFolder" , fc . DatabaseFolder , "folder who contains the database file. Defaults to ./var/lib/. If other folder is used this flag must be specified at startup." )
2021-03-24 10:14:17 +01:00
flag . StringVar ( & c . NodeName , "nodeName" , fc . NodeName , "some unique string to identify this Edge unit" )
2021-03-01 20:49:43 +01:00
flag . StringVar ( & c . BrokerAddress , "brokerAddress" , fc . BrokerAddress , "the address of the message broker" )
2021-12-28 12:05:09 +01:00
flag . IntVar ( & c . NatsConnOptTimeout , "natsConnOptTimeout" , fc . NatsConnOptTimeout , "default nats client conn timeout in seconds" )
2021-09-01 13:39:54 +02:00
flag . IntVar ( & c . NatsConnectRetryInterval , "natsConnectRetryInterval" , fc . NatsConnectRetryInterval , "default nats retry connect interval in seconds." )
2021-12-16 11:01:01 +01:00
flag . IntVar ( & c . NatsReconnectJitter , "natsReconnectJitter" , fc . NatsReconnectJitter , "default nats ReconnectJitter interval in milliseconds." )
flag . IntVar ( & c . NatsReconnectJitterTLS , "natsReconnectJitterTLS" , fc . NatsReconnectJitterTLS , "default nats ReconnectJitterTLS interval in seconds." )
2022-05-26 08:07:23 +02:00
flag . IntVar ( & c . REQKeysRequestUpdateInterval , "REQKeysRequestUpdateInterval" , fc . REQKeysRequestUpdateInterval , "default interval in seconds for asking the central for public keys" )
flag . IntVar ( & c . REQAclRequestUpdateInterval , "REQAclRequestUpdateInterval" , fc . REQAclRequestUpdateInterval , "default interval in seconds for asking the central for acl updates" )
2021-03-01 20:49:43 +01:00
flag . StringVar ( & c . ProfilingPort , "profilingPort" , fc . ProfilingPort , "The number of the profiling port" )
flag . StringVar ( & c . PromHostAndPort , "promHostAndPort" , fc . PromHostAndPort , "host and port for prometheus listener, e.g. localhost:2112" )
flag . IntVar ( & c . DefaultMessageTimeout , "defaultMessageTimeout" , fc . DefaultMessageTimeout , "default message timeout in seconds. This can be overridden on the message level" )
flag . IntVar ( & c . DefaultMessageRetries , "defaultMessageRetries" , fc . DefaultMessageRetries , "default amount of retries that will be done before a message is thrown away, and out of the system" )
2021-11-18 06:36:16 +01:00
flag . IntVar ( & c . DefaultMethodTimeout , "defaultMethodTimeout" , fc . DefaultMethodTimeout , "default amount of seconds a request method max will be allowed to run" )
2021-03-02 13:46:02 +01:00
flag . StringVar ( & c . SubscribersDataFolder , "subscribersDataFolder" , fc . SubscribersDataFolder , "The data folder where subscribers are allowed to write their data if needed" )
2021-03-12 11:13:42 +01:00
flag . StringVar ( & c . CentralNodeName , "centralNodeName" , fc . CentralNodeName , "The name of the central node to receive messages published by this node" )
2021-04-19 21:06:37 +02:00
flag . StringVar ( & c . RootCAPath , "rootCAPath" , fc . RootCAPath , "If TLS, enter the path for where to find the root CA certificate" )
2021-05-14 15:23:04 +02:00
flag . StringVar ( & c . NkeySeedFile , "nkeySeedFile" , fc . NkeySeedFile , "The full path of the nkeys seed file" )
2021-08-23 12:47:33 +02:00
flag . StringVar ( & c . ExposeDataFolder , "exposeDataFolder" , fc . ExposeDataFolder , "If set the data folder will be exposed on the given host:port. Default value is not exposed at all" )
2021-09-07 09:43:54 +02:00
flag . IntVar ( & c . ErrorMessageTimeout , "errorMessageTimeout" , fc . ErrorMessageTimeout , "The number of seconds to wait for an error message to time out" )
flag . IntVar ( & c . ErrorMessageRetries , "errorMessageRetries" , fc . ErrorMessageRetries , "The number of if times to retry an error message before we drop it" )
2022-01-03 12:30:28 +01:00
flag . StringVar ( & c . Compression , "compression" , fc . Compression , "compression method to use. defaults to no compression, z = zstd, g = gzip. Undefined value will default to no compression" )
2021-12-29 06:17:40 +01:00
flag . StringVar ( & c . Serialization , "serialization" , fc . Serialization , "Serialization method to use. defaults to gob, other values are = cbor. Undefined value will default to gob" )
2021-12-31 06:59:09 +01:00
flag . IntVar ( & c . SetBlockProfileRate , "setBlockProfileRate" , fc . SetBlockProfileRate , "Enable block profiling by setting the value to f.ex. 1. 0 = disabled" )
2022-02-09 14:59:40 +01:00
flag . BoolVar ( & c . EnableSocket , "enableSocket" , fc . EnableSocket , "true/false, for enabling the creation of a steward.sock file" )
2022-01-07 11:17:10 +01:00
flag . BoolVar ( & c . EnableTUI , "enableTUI" , fc . EnableTUI , "true/false for enabling the Terminal User Interface" )
2022-02-09 14:59:40 +01:00
flag . BoolVar ( & c . EnableSignatureCheck , "enableSignatureCheck" , fc . EnableSignatureCheck , "true/false *TESTING* enable signature checking." )
2022-05-27 06:22:51 +02:00
flag . BoolVar ( & c . EnableAclCheck , "enableAclCheck" , fc . EnableAclCheck , "true/false *TESTING* enable Acl checking." )
2022-02-09 14:59:40 +01:00
flag . BoolVar ( & c . IsCentralAuth , "isCentralAuth" , fc . IsCentralAuth , "true/false, *TESTING* is this the central auth server" )
2022-02-18 06:24:27 +01:00
flag . BoolVar ( & c . EnableDebug , "enableDebug" , fc . EnableDebug , "true/false, will enable debug logging so all messages sent to the errorKernel will also be printed to STDERR" )
2021-03-02 13:46:02 +01:00
2022-05-26 08:07:23 +02:00
// Start of Request publishers/subscribers
2021-04-06 05:46:07 +02:00
flag . IntVar ( & c . StartPubREQHello , "startPubREQHello" , fc . StartPubREQHello , "Make the current node send hello messages to central at given interval in seconds" )
2021-03-25 13:39:59 +01:00
2022-05-30 07:14:15 +02:00
flag . BoolVar ( & c . EnableKeyUpdates , "EnableKeyUpdates" , fc . EnableKeyUpdates , "true/false" )
2022-05-26 08:07:23 +02:00
2022-05-30 07:14:15 +02:00
flag . BoolVar ( & c . EnableAclUpdates , "EnableAclUpdates" , fc . EnableAclUpdates , "true/false" )
2022-05-26 08:07:23 +02:00
2022-06-03 06:02:27 +02:00
flag . BoolVar ( & c . IsCentralErrorLogger , "isCentralErrorLogger" , fc . IsCentralErrorLogger , "true/false" )
2021-09-08 18:56:23 +02:00
flag . BoolVar ( & c . StartSubREQHello , "startSubREQHello" , fc . StartSubREQHello , "true/false" )
flag . BoolVar ( & c . StartSubREQToFileAppend , "startSubREQToFileAppend" , fc . StartSubREQToFileAppend , "true/false" )
flag . BoolVar ( & c . StartSubREQToFile , "startSubREQToFile" , fc . StartSubREQToFile , "true/false" )
2022-03-04 15:02:43 +01:00
flag . BoolVar ( & c . StartSubREQToFileNACK , "startSubREQToFileNACK" , fc . StartSubREQToFileNACK , "true/false" )
2021-11-17 13:02:48 +01:00
flag . BoolVar ( & c . StartSubREQCopyFileFrom , "startSubREQCopyFileFrom" , fc . StartSubREQCopyFileFrom , "true/false" )
2021-11-18 09:34:16 +01:00
flag . BoolVar ( & c . StartSubREQCopyFileTo , "startSubREQCopyFileTo" , fc . StartSubREQCopyFileTo , "true/false" )
2022-06-09 05:59:37 +02:00
flag . BoolVar ( & c . StartSubREQCopySrc , "startSubREQCopySrc" , fc . StartSubREQCopySrc , "true/false" )
flag . BoolVar ( & c . StartSubREQCopyDst , "startSubREQCopyDst" , fc . StartSubREQCopyDst , "true/false" )
2021-09-08 18:56:23 +02:00
flag . BoolVar ( & c . StartSubREQPing , "startSubREQPing" , fc . StartSubREQPing , "true/false" )
flag . BoolVar ( & c . StartSubREQPong , "startSubREQPong" , fc . StartSubREQPong , "true/false" )
flag . BoolVar ( & c . StartSubREQCliCommand , "startSubREQCliCommand" , fc . StartSubREQCliCommand , "true/false" )
flag . BoolVar ( & c . StartSubREQToConsole , "startSubREQToConsole" , fc . StartSubREQToConsole , "true/false" )
flag . BoolVar ( & c . StartSubREQHttpGet , "startSubREQHttpGet" , fc . StartSubREQHttpGet , "true/false" )
2022-02-11 07:27:51 +01:00
flag . BoolVar ( & c . StartSubREQHttpGetScheduled , "startSubREQHttpGetScheduled" , fc . StartSubREQHttpGetScheduled , "true/false" )
2021-09-08 18:56:23 +02:00
flag . BoolVar ( & c . StartSubREQTailFile , "startSubREQTailFile" , fc . StartSubREQTailFile , "true/false" )
2021-09-17 10:17:10 +02:00
flag . BoolVar ( & c . StartSubREQCliCommandCont , "startSubREQCliCommandCont" , fc . StartSubREQCliCommandCont , "true/false" )
2021-11-10 11:21:38 +01:00
flag . BoolVar ( & c . StartSubREQRelay , "startSubREQRelay" , fc . StartSubREQRelay , "true/false" )
2021-03-24 10:14:17 +01:00
2022-02-10 06:19:13 +01:00
purgeBufferDB := flag . Bool ( "purgeBufferDB" , false , "true/false, purge the incoming buffer db and all it's state" )
2021-03-01 20:49:43 +01:00
flag . Parse ( )
2021-03-24 10:14:17 +01:00
// Check that mandatory flag values have been set.
switch {
case c . NodeName == "" :
return fmt . Errorf ( "error: the nodeName config option or flag cannot be empty, check -help" )
case c . CentralNodeName == "" :
return fmt . Errorf ( "error: the centralNodeName config option or flag cannot be empty, check -help" )
2021-03-01 20:49:43 +01:00
}
2021-03-24 10:14:17 +01:00
2021-03-25 11:28:26 +01:00
if err := c . WriteConfigFile ( ) ; err != nil {
log . Printf ( "error: checkFlags: failed writing config file: %v\n" , err )
os . Exit ( 1 )
}
2021-03-24 10:14:17 +01:00
2022-02-10 06:19:13 +01:00
if * purgeBufferDB {
fp := filepath . Join ( c . DatabaseFolder , "incomingBuffer.db" )
err := os . Remove ( fp )
if err != nil {
log . Printf ( "error: failed to purge buffer state database: %v\n" , err )
}
}
2021-03-24 10:14:17 +01:00
return nil
2021-03-01 20:49:43 +01:00
}
2021-03-24 07:05:41 +01:00
// Reads the current config file from disk.
2021-05-28 14:48:53 +02:00
func ( c * Configuration ) ReadConfigFile ( configFolder string ) ( Configuration , error ) {
2021-09-09 08:19:53 +02:00
fPath := filepath . Join ( configFolder , "config.toml" )
2021-03-01 20:49:43 +01:00
2021-09-09 08:19:53 +02:00
if _ , err := os . Stat ( fPath ) ; os . IsNotExist ( err ) {
return Configuration { } , fmt . Errorf ( "error: no config file found %v: %v" , fPath , err )
2021-03-01 20:49:43 +01:00
}
2021-09-09 08:19:53 +02:00
f , err := os . OpenFile ( fPath , os . O_RDONLY , 0600 )
2021-03-01 20:49:43 +01:00
if err != nil {
2021-03-02 13:46:02 +01:00
return Configuration { } , fmt . Errorf ( "error: ReadConfigFile: failed to open file: %v" , err )
2021-03-01 20:49:43 +01:00
}
defer f . Close ( )
2021-09-09 08:19:53 +02:00
var cFile ConfigurationFromFile
2021-03-01 20:49:43 +01:00
dec := toml . NewDecoder ( f )
2021-09-09 08:19:53 +02:00
err = dec . Decode ( & cFile )
2021-03-01 20:49:43 +01:00
if err != nil {
2021-09-09 08:19:53 +02:00
log . Printf ( "error: decoding config.toml file. The program will automatically try to correct the problem, and use sane default where it kind find a value to use, but beware of this error in case the program start to behave in not expected ways: path=%v: err=%v" , fPath , err )
2021-03-01 20:49:43 +01:00
}
2021-09-09 08:19:53 +02:00
// Check that all values read are ok.
conf := checkConfigValues ( cFile )
2021-03-01 20:49:43 +01:00
return conf , nil
}
2021-03-02 06:51:08 +01:00
// WriteConfigFile will write the current config to file. If the file or the
// directory for the config file does not exist it will be created.
2021-03-01 20:49:43 +01:00
func ( c * Configuration ) WriteConfigFile ( ) error {
if _ , err := os . Stat ( c . ConfigFolder ) ; os . IsNotExist ( err ) {
2021-05-12 09:50:03 +02:00
err := os . MkdirAll ( c . ConfigFolder , 0700 )
2021-03-01 20:49:43 +01:00
if err != nil {
2021-05-20 12:27:25 +02:00
return fmt . Errorf ( "error: failed to create config directory %v: %v" , c . ConfigFolder , err )
2021-03-01 20:49:43 +01:00
}
}
fp := filepath . Join ( c . ConfigFolder , "config.toml" )
f , err := os . OpenFile ( fp , os . O_RDWR | os . O_CREATE | os . O_TRUNC , 0600 )
if err != nil {
2021-03-02 13:46:02 +01:00
return fmt . Errorf ( "error: WriteConfigFile: failed to open file: %v" , err )
2021-03-01 20:49:43 +01:00
}
defer f . Close ( )
enc := toml . NewEncoder ( f )
enc . Encode ( c )
return nil
}