Documentation ¶
Overview ¶
Package config provides types and functions to collect, validate and apply user-provided settings.
Index ¶
- Constants
- func Branding(msg string) func() string
- func Version() string
- type Config
- func (c Config) DBName() string
- func (c Config) DBServerEncryptMode() string
- func (c Config) DBServerHost() string
- func (c Config) DBServerInstance() string
- func (c Config) DBServerPassword() string
- func (c Config) DBServerPort() int
- func (c Config) DBServerTrustCert() bool
- func (c Config) DBServerUsername() string
- func (c Config) Description() string
- func (c Config) EmailAgeThresholds() EmailAgeThresholds
- func (c Config) EmailCountThresholds() EmailCountThresholds
- func (c Config) EmitBranding() bool
- func (c Config) IgnoreMissingEmails() bool
- func (c Config) LogLevel() string
- func (c Config) String() string
- func (c Config) Version() string
- type DBServer
- type Database
- type EmailAgeThresholds
- type EmailCountThresholds
- type Filters
- type Logging
- type TableEMailCopies
- type Thresholds
Constants ¶
const ( EncryptModeDisable string = "disable" EncryptModeTrue string = "true" EncryptModeFalse string = "false" )
These values directly map to the `encrypt` parameter settings used by the database driver. https://github.com/denisenkom/go-mssqldb#common-parameters
const ( MSSQLInstanceNameMaxChars int = 16 MSSQLUsernameMaxChars int = 128 MSSQLPasswordMaxChars int = 128 MSSQLDatabaseNameMaxChars int = 123 )
https://docs.microsoft.com/en-us/previous-versions/sql/sql-server-2008-r2/ms143531(v=sql.105) https://docs.microsoft.com/en-us/sql/relational-databases/system-stored-procedures/sp-server-info-transact-sql https://docs.microsoft.com/en-us/sql/t-sql/statements/create-database-transact-sql https://docs.microsoft.com/en-us/sql/t-sql/statements/create-user-transact-sql
const ( TCPReservedPort int = 0 TCPSystemPortStart int = 1 TCPSystemPortEnd int = 1023 TCPUserPortStart int = 1024 TCPUserPortEnd int = 49151 TCPDynamicPrivatePortStart int = 49152 TCPDynamicPrivatePortEnd int = 65535 )
TCP port ranges http://www.iana.org/assignments/port-numbers Port numbers are assigned in various ways, based on three ranges: System Ports (0-1023), User Ports (1024-49151), and the Dynamic and/or Private Ports (49152-65535)
const ( // ILLiadDatabase is the default database name for ILLiad software. ILLiadDatabase string = "ILLData" // ILLiadDatabaseEMailTable is the name of the database table which holds // metadata for email notifications. ILLiadDatabaseEMailTable string = "EMailCopies" )
const ( QueryILLiadEMailCancelledCount string = "SELECT COUNT(*) As [CancelledEmails] FROM [ILLData].[dbo].[EMailCopies] WHERE [Status] = 'Cancelled';" QueryILLiadEMailNULLCount string = "SELECT COUNT(*) As [NULLEmails] FROM [ILLData].[dbo].[EMailCopies] WHERE [Status] IS NULL;" QueryILLiadEMailSentCount string = "SELECT COUNT(*) As [SentEmails] FROM [ILLData].[dbo].[EMailCopies] WHERE [Status] = 'Sent';" QueryILLiadEMailPendingCount string = "SELECT COUNT(*) As [PendingEmails] FROM [ILLData].[dbo].[EMailCopies] WHERE [Status] = 'Pending';" QueryILLiadEMailStatusSummary string = "SELECT [Status], COUNT(*) AS [Count] FROM [ILLData].[dbo].[EMailCopies] GROUP BY [Status];" QueryILLiadEMailCancelledEmailValues string = "SELECT [TransactionNumber], [EMailDate], [Status], [Note] FROM [ILLData].[dbo].[EMailCopies] WHERE [Status] = 'Cancelled';" QueryILLiadEMailPendingEmailValues string = "SELECT [TransactionNumber], [EMailDate], [Status], [Note] FROM [ILLData].[dbo].[EMailCopies] WHERE [Status] = 'Pending';" )
Queries used to interact with the ILLiad database that this plugin is responsible for checking.
const ( // LogLevelDisabled maps to zerolog.Disabled logging level LogLevelDisabled string = "disabled" // LogLevelPanic maps to zerolog.PanicLevel logging level LogLevelPanic string = "panic" // LogLevelFatal maps to zerolog.FatalLevel logging level LogLevelFatal string = "fatal" // LogLevelError maps to zerolog.ErrorLevel logging level LogLevelError string = "error" // LogLevelWarn maps to zerolog.WarnLevel logging level LogLevelWarn string = "warn" // LogLevelInfo maps to zerolog.InfoLevel logging level LogLevelInfo string = "info" // LogLevelDebug maps to zerolog.DebugLevel logging level LogLevelDebug string = "debug" // LogLevelTrace maps to zerolog.TraceLevel logging level LogLevelTrace string = "trace" )
Variables ¶
This section is empty.
Functions ¶
Types ¶
type Config ¶
type Config struct { Logging DBServer Database Thresholds Filters // Log is an embedded zerolog Logger initialized via config.New(). Log zerolog.Logger `arg:"-"` // contains filtered or unexported fields }
Config is a unified set of configuration values for this application. This struct is configured via command-line flags or (maybe in the future) TOML configuration file provided by the user. Values held by this object are intended to be retrieved via "getter" methods.
func New ¶
New is a factory function that produces a new Config object based on user provided flag and where applicable, default values.
func (Config) DBName ¶
DBName returns the user-provided database name or the default value if not provided.
func (Config) DBServerEncryptMode ¶
DBServerEncryptMode returns the user-provided encrypt mode or the default value if not provided.
func (Config) DBServerHost ¶
DBServerHost returns the user-provided database server host or the default value if not provided.
func (Config) DBServerInstance ¶
DBServerInstance returns the user-provided database server instance or the default value if not provided.
func (Config) DBServerPassword ¶
DBServerPassword returns the user-provided database server password or the default value if not provided.
func (Config) DBServerPort ¶
DBServerPort returns the user-provided database server port or the default value if not provided.
func (Config) DBServerTrustCert ¶
DBServerTrustCert returns the user-provided choice of whether the database server certificate is trusted as-is or if validation is enforced, or the default value if not provided.
func (Config) DBServerUsername ¶
DBServerUsername returns the user-provided database server username or the default value if not provided.
func (Config) Description ¶
Description emits branding information whenever the user specifies the `-h` flag. The application uses this as a header prior to displaying available CLI flag options.
func (Config) EmailAgeThresholds ¶
func (c Config) EmailAgeThresholds() EmailAgeThresholds
EmailAgeThresholds returns the user-provided WARNING and CRITICAL threshold values for the age of email notifications in a pending state, or the default threshold values if not provided.
func (Config) EmailCountThresholds ¶
func (c Config) EmailCountThresholds() EmailCountThresholds
EmailCountThresholds returns the user-provided WARNING and CRITICAL threshold values for the number of email notifications in a pending state, or the default threshold values if not provided.
func (Config) EmitBranding ¶
EmitBranding returns the user-provided choice of whether branded output is emitted with check results or the default value if not provided.
func (Config) IgnoreMissingEmails ¶
IgnoreMissingEmails returns the user-provided choice of whether missing email notification entries in the database should be treated as an OK state or the default value if not provided.
func (Config) LogLevel ¶
LogLevel returns the user-provided logging level or the default value if not provided.
type DBServer ¶
type DBServer struct { Host *string `` /* 256-byte string literal not displayed */ Port *int `` /* 152-byte string literal not displayed */ Instance *string `arg:"--instance,env:CHECK_ILLIAD_DBSERVER_INSTANCE" help:"The database server instance name. This may be blank."` Username *string `` /* 203-byte string literal not displayed */ Password *string `` /* 213-byte string literal not displayed */ EncryptMode *string `` /* 197-byte string literal not displayed */ TrustCert *bool `` /* 203-byte string literal not displayed */ }
DBServer is the user-specified settings for creating a database server connection.
type Database ¶
type Database struct {
Name *string `` /* 144-byte string literal not displayed */
}
Database is the user-specified settings for the database used by the ILLiad software.
type EmailAgeThresholds ¶
type EmailAgeThresholds struct { Critical time.Duration `arg:"-"` Warning time.Duration `arg:"-"` Set bool `arg:"-"` }
EmailAgeThresholds represents the user-specified email notification age thresholds.
type EmailCountThresholds ¶
type EmailCountThresholds struct { Critical int `arg:"-"` Warning int `arg:"-"` Set bool `arg:"-"` }
EmailCountThresholds represents the user-specified email notification count thresholds.
type Filters ¶
type Filters struct {
IgnoreMissingEmails *bool `` /* 283-byte string literal not displayed */
}
Filters represents options which lets the sysadmin filter in/out specific values or scenarios.
type Logging ¶
type Logging struct { Level *string `` /* 156-byte string literal not displayed */ EmitBranding *bool `` /* 342-byte string literal not displayed */ }
Logging represents options specific to how this application handles logging.
type TableEMailCopies ¶
type TableEMailCopies struct { TransactionNumber int `arg:"-"` EMailDate time.Time `arg:"-"` Status sql.NullString `arg:"-"` Note sql.NullString `arg:"-"` }
TableEMailCopies reflects fields from the `EMailCopies` table from the `ILLData` database.
type Thresholds ¶
type Thresholds struct { CountWarning *int `` /* 176-byte string literal not displayed */ CountCritical *int `` /* 179-byte string literal not displayed */ AgeWarning *int `` /* 203-byte string literal not displayed */ AgeCritical *int `` /* 206-byte string literal not displayed */ }
Thresholds represents the values which determine WARNING and CRITICAL thresholds.