Documentation ¶
Index ¶
- Constants
- func Abs(c geneos.Instance, file string) (result string)
- func AllNames(h *geneos.Host, ct *geneos.Component) (names []string)
- func AtLeastVersion(c geneos.Instance, version string) bool
- func BuildCmd(c geneos.Instance) (cmd *exec.Cmd, env []string)
- func Clean(c geneos.Instance, options ...geneos.Options) (err error)
- func ComponentFilename(c geneos.Instance, extensions ...string) string
- func ComponentFilepath(c geneos.Instance, extensions ...string) string
- func ConfigFileType() (conftype string)
- func ConfigFileTypes() []string
- func CopyInstance(ct *geneos.Component, source, destination string, move bool) (err error)
- func CreateCert(c geneos.Instance) (err error)
- func CreateCertKey(template, parent *x509.Certificate, ...) (cert *x509.Certificate, keyPEM *memguard.Enclave, err error)
- func CreateConfigFromTemplate(c geneos.Instance, path string, name string, defaultTemplate []byte) (err error)
- func DeleteSettingFromMap(c geneos.Instance, from map[string]interface{}, key string)
- func Disable(c geneos.Instance) (err error)
- func DisplayName(c geneos.Instance) string
- func Enable(c geneos.Instance) (err error)
- func Filename(c geneos.Instance, name string) (filename string)
- func Filenames(c geneos.Instance, names ...string) (filenames []string)
- func Filepath(c geneos.Instance, name string) string
- func Files(c geneos.Instance) (openfiles map[int]OpenFiles)
- func ForAll(ct *geneos.Component, hostname string, ...) (err error)
- func ForAllWithResults(ct *geneos.Component, fn func(geneos.Instance, []string) (interface{}, error), ...) (results []interface{}, err error)
- func Get(ct *geneos.Component, name string) (c geneos.Instance, err error)
- func GetAll(r *geneos.Host, ct *geneos.Component) (confs []geneos.Instance)
- func GetPID(c geneos.Instance) (pid int, err error)
- func GetPIDInfo(c geneos.Instance) (pid int, uid uint32, gid uint32, mtime time.Time, err error)
- func GetPorts(r *geneos.Host) (ports map[uint16]*geneos.Component)
- func ImportCommons(r *geneos.Host, ct *geneos.Component, common string, params []string) (filename string, err error)
- func ImportFile(h *geneos.Host, dir string, source string, options ...geneos.Options) (filename string, err error)
- func IsDisabled(c geneos.Instance) bool
- func IsProtected(c geneos.Instance) bool
- func IsRunning(c geneos.Instance) bool
- func LoadConfig(c geneos.Instance) (err error)
- func LogFile(c geneos.Instance) (logfile string)
- func Match(ct *geneos.Component, name string) (c geneos.Instance, err error)
- func MatchAll(ct *geneos.Component, name string) (c []geneos.Instance)
- func MatchKeyValue(h *geneos.Host, ct *geneos.Component, key, value string) (confs []geneos.Instance)
- func Migrate(c geneos.Instance) (err error)
- func NewPrivateKey() *memguard.Enclave
- func NextPort(r *geneos.Host, ct *geneos.Component) uint16
- func ReadCert(c geneos.Instance) (cert *x509.Certificate, err error)
- func ReadKey(c geneos.Instance) (key *memguard.Enclave, err error)
- func ReadRootCert() (cert *x509.Certificate, err error)
- func ReadSigningCert() (cert *x509.Certificate, err error)
- func RemovePaths(c geneos.Instance, paths string) (err error)
- func ReservedName(name string) (ok bool)
- func SetDefaults(c geneos.Instance, name string) (err error)
- func SetEnvs(c geneos.Instance, envs []string) (changed bool)
- func SetExtendedValues(c geneos.Instance, x ExtraConfigValues) (changed bool)
- func SetSecureArgs(c geneos.Instance) (args []string)
- func SetSlice(c geneos.Instance, items []string, setting string, key func(string) string) (changed bool)
- func SharedPath(c geneos.Instance, subs ...interface{}) string
- func Signal(c geneos.Instance, signal syscall.Signal) (err error)
- func Sockets(c geneos.Instance) (links map[int]int)
- func SplitName(in string, defaultHost *geneos.Host) (ct *geneos.Component, name string, h *geneos.Host)
- func Start(c geneos.Instance) (err error)
- func Stop(c geneos.Instance, force, kill bool) (err error)
- func TCPListenPorts(c geneos.Instance) (ports []int)
- func UnsetMap(c geneos.Instance, key string, items UnsetCmdValues) (changed bool)
- func UnsetMapHex(c geneos.Instance, key string, items UnsetCmdHexKeyed) (changed bool)
- func UnsetSlice(c geneos.Instance, key string, items []string, cmp func(string, string) bool) (changed bool)
- func UnsetValues(c geneos.Instance, x UnsetConfigValues) (changed bool, err error)
- func ValidInstanceName(name string) (ok bool)
- func Version(c geneos.Instance) (base string, version string, err error)
- func WriteCert(c geneos.Instance, cert *x509.Certificate) (err error)
- func WriteConfigValues(c geneos.Instance, values map[string]interface{}) (err error)
- func WriteKey(c geneos.Instance, key *memguard.Enclave) (err error)
- type AttributeValues
- type EnvValues
- type ExtraConfigValues
- type GatewayValues
- type IncludeValues
- type Instance
- type OpenFiles
- type TypeValues
- type UnsetCmdHexKeyed
- type UnsetCmdValues
- type UnsetConfigValues
- type VarValue
- type VarValues
Constants ¶
const AttributeValuesOptionsText = "An attribute in the format NAME=VALUE\n(Repeat as required, san only)"
const EnvValuesOptionsText = "An environment variable for instance start-up\n(Repeat as required)"
const GatewayValuesOptionstext = "A gateway connection in the format HOSTNAME:PORT\n(Repeat as required, san and floating only)"
const IncludeValuesOptionsText = "An include file in the format `PRIORITY:[PATH|URL]`\n(Repeat as required, gateway only)"
const TypeValuesOptionsText = "A type NAME\n(Repeat as required, san only)"
const VarValuesOptionsText = "A variable in the format [TYPE:]NAME=VALUE\n(Repeat as required, san only)"
Variables ¶
This section is empty.
Functions ¶
func Abs ¶
Abs returns an absolute path to file prepended with the instance working directory if file is not already an absolute path.
func AllNames ¶
Return a slice of all instance names for a given component. No checking is done to validate that the directory is a populated instance.
func AtLeastVersion ¶ added in v1.5.0
AtLeastVersion returns true if the installed version for instance c is version or greater. If the version of the instance is somehow unparseable then this returns false.
func BuildCmd ¶
BuildCmd gathers the path to the binary, arguments and any environment variables for an instance and returns an exec.Cmd, almost ready for execution. Callers will add more details such as working directories, user and group etc.
func ComponentFilename ¶
ComponentFilename() returns the filename for the component named by the instance similarly to ComponentFilepath
func ComponentFilepath ¶
ComponentFilepath() returns an absolute path to a file named for the component type of the instance with any extensions joined using ".", e.g. is c is a netprobe instance then
path := instance.ComponentFilepath(c, "xml", "orig")
will return /path/to/netprobe/netprobe.xml.orig
If no extensions are passed then the default us to add an extension of the instance.ConfigType, which defaults to "json", e.g. using the same instance as above:
path := instance.ComponentPath(c)
will return /path/to/netprobe/netprobe.json
func ConfigFileType ¶ added in v1.4.1
func ConfigFileType() (conftype string)
ConfigFileType returns the current primary configuration file extension
func ConfigFileTypes ¶ added in v1.4.1
func ConfigFileTypes() []string
ConfigFileTypes contains a list of supported configuration file extensions
func CopyInstance ¶
func CreateCert ¶
create a new certificate for an instance
this also creates a new private key
skip if certificate exists (no expiry check)
func CreateCertKey ¶
func CreateCertKey(template, parent *x509.Certificate, parentKeyPEM, existingKeyPEM *memguard.Enclave) (cert *x509.Certificate, keyPEM *memguard.Enclave, err error)
wrapper to create a new certificate given the sign cert and private key and an optional private key to (re)use for the created certificate itself. returns a certificate and private key. Keys are in PEM format so need parsing after unsealing.
func CreateConfigFromTemplate ¶
func CreateConfigFromTemplate(c geneos.Instance, path string, name string, defaultTemplate []byte) (err error)
CreateConfigFromTemplate loads templates from TYPE/templates/[tmpl]* and parse it using the instance data write it out to a single file. If tmpl is empty, load all files
func DeleteSettingFromMap ¶ added in v1.4.1
DeleteSettingFromMap removes key from the map from and if it is registered as an alias it also removes the key that alias refers to.
func Disable ¶ added in v1.5.0
Disable the instance c. Does not try to stop a running instance and returns an error if it is running.
func DisplayName ¶
DisplayName returns the type, name and non-local host as a string suitable for display.
func Filename ¶
Filename returns the basename of the file named by the configuration item given in 'name'. Returns an empty string if the configuration item doesn't exist or is not set.
func Filenames ¶
Filenames returns the basename of the files named by the configuration items given in 'names'. Returns an empty slice if the instance is not valid or empty strings for each name if the configuration item doesn't exist or is not set.
func Filepath ¶
Filepath returns the full path to the file named by the configuration item given in 'name'. If the configuration item is already an absolute path then it is returned as-is, otherwise it is joined with the home directory of the instance and returned. No indication is given if the path is a valid local one or on a remote host.
func Files ¶
Files returns a map of file descriptor (int) to file details (InstanceProcFiles) for all open, real, files for the process running as the instance. All paths that are not absolute paths are ignored. An empty map is returned if the process cannot be found.
func ForAll ¶
func ForAll(ct *geneos.Component, hostname string, fn func(geneos.Instance, []string) error, args []string, params []string) (err error)
ForAll calls the supplied function for each matching instance. It prints any returned error on STDOUT and the only error returned is os.ErrNotExist if there are no matching instances.
func ForAllWithResults ¶ added in v1.4.1
func ForAllWithResults(ct *geneos.Component, fn func(geneos.Instance, []string) (interface{}, error), args []string, params []string) (results []interface{}, err error)
ForAllWithResults calls the given function for each matching instance and gather the return values into a slice of interfaces for handling upstream. Errors are printed on STDOUT for each call and the only error returned ErrNotExist if there are no matches.
func Get ¶
Get return an instance of component ct, and loads the config. It is an error if the config cannot be loaded.
func GetPID ¶
GetPID returns the PID of the process running for the instance. If not found then an err of os.ErrProcessDone is returned.
The process is identified by checking the conventions used to start Geneos processes.
the component type must be part of the basename of the executable and the component name must be on the command line as an exact and standalone args
walk the /proc directory (local or remote) and find the matching pid. This is subject to races, but not much we can do
func GetPIDInfo ¶
func GetPorts ¶
GetPorts gets all used ports in config files on a specific remote this will not work for ports assigned in component config files, such as gateway setup or netprobe collection agent
returns a map
func ImportCommons ¶
func ImportFile ¶
func ImportFile(h *geneos.Host, dir string, source string, options ...geneos.Options) (filename string, err error)
ImportFile
func IsDisabled ¶
IsDisabled returns true if the instance c is disabled.
func IsProtected ¶
IsProtected returns true if instance c is marked protected
func LoadConfig ¶
LoadConfig will load the JSON config file if available, otherwise try to load the "legacy" .rc file
support cache?
error check core values - e.g. Name
func LogFile ¶
LogFile returns the fulle path to the log file for the instance.
XXX logdir = LogD relative to Home or absolute
func Match ¶
Match looks for exactly one matching instance across types and hosts returns Invalid Args if zero of more than 1 match
func MatchKeyValue ¶
func MatchKeyValue(h *geneos.Host, ct *geneos.Component, key, value string) (confs []geneos.Instance)
MatchKeyValue returns a slice of instances where the instance configuration key matches the value given.
func Migrate ¶
Migrate is a helper that checks if the configuration was loaded from a legacy .rc file and if it has it then saves the current configuration (it does not convert the .rc file) in a new format file and renames the .rc file to .rc.orig to allow Revert to work.
func NewPrivateKey ¶ added in v1.5.0
NewPrivateKey returns a PKCS1 encoded RSA Private Key as an enclave. It is not PEM encoded.
func NextPort ¶
given a range, find the first unused port
range is comma or two-dot separated list of single number, e.g. "7036" min-max inclusive range, e.g. "7036-8036" start- open ended range, e.g. "7041-"
some limits based on https://en.wikipedia.org/wiki/List_of_TCP_and_UDP_port_numbers
not concurrency safe at this time
func ReadCert ¶
func ReadCert(c geneos.Instance) (cert *x509.Certificate, err error)
read the instance certificate
func ReadRootCert ¶
func ReadRootCert() (cert *x509.Certificate, err error)
read the rootCA certificate from the installation directory
func ReadSigningCert ¶
func ReadSigningCert() (cert *x509.Certificate, err error)
read the signing certificate from the installation directory
func RemovePaths ¶
RemovePaths removes all files and directories in paths, each file or directory is separated by ListSeperator
func ReservedName ¶
ReservedName returns true if in name a reserved word. Reserved names are checked against all the values registered by components at start-up.
func SetDefaults ¶
SetDefaults() is a common function called by component factory functions to iterate over the component specific instance struct and set the defaults as defined in the 'defaults' struct tags.
func SetExtendedValues ¶ added in v1.5.0
func SetExtendedValues(c geneos.Instance, x ExtraConfigValues) (changed bool)
XXX abstract this for a general case
func SetSecureArgs ¶
SetSecureArgs returns a slice of arguments to enable secure connections if the correct configuration values are set. These command line options are common to all core Geneos components except the gateway, which is special-cased
func SetSlice ¶ added in v1.5.0
func SetSlice(c geneos.Instance, items []string, setting string, key func(string) string) (changed bool)
sets 'items' in the settings identified by 'key'. the key() function returns an identifier to use in merge comparisons
func SharedPath ¶ added in v1.5.0
SharedPath returns the full path a directory or file in the instances component type shared directory joined to any parts subs - the last element can be a filename. If the instance is not loaded then "." is returned for the current directory.
func Sockets ¶ added in v1.4.1
Sockets returns a map[int]int of file descriptor to socket inode for all open files for the process running as the instance. An empty map is returned if the process cannot be found.
func SplitName ¶
func SplitName(in string, defaultHost *geneos.Host) (ct *geneos.Component, name string, h *geneos.Host)
SplitName returns the parts of an instance name given an instance name in the format [TYPE:]NAME[@HOST] and a default host, return a *geneos.Component for the TYPE if given, a string for the NAME and a *geneos.Host - the latter being either from the name or the default provided
func TCPListenPorts ¶ added in v1.4.3
TCPListenPorts returns all TCP ports currently open for the process running as the instance. An empty slice is returned if the process cannot be found. The instance may be on a remote host.
func UnsetMap ¶ added in v1.5.0
func UnsetMap(c geneos.Instance, key string, items UnsetCmdValues) (changed bool)
func UnsetMapHex ¶ added in v1.5.0
func UnsetMapHex(c geneos.Instance, key string, items UnsetCmdHexKeyed) (changed bool)
func UnsetSlice ¶ added in v1.5.0
func UnsetValues ¶ added in v1.5.0
func UnsetValues(c geneos.Instance, x UnsetConfigValues) (changed bool, err error)
XXX abstract this for a general case
func ValidInstanceName ¶
ValidInstanceName returns true if name is considered a valid instance name. It is not checked against the list of reserved names.
XXX used to consume instance names until parameters are then passed down
func Version ¶
Version returns the base package name and the underlying package version for the instance c. If base is not a link, then base is also returned as the symlink. If there are more than 10 levels of symlink then return symlink set to "loop-detected" and err set to syscall.ELOOP to prevent infinite loops.
func WriteConfigValues ¶
WriteConfigValues writes the given values to the configuration file for instance c. It does not merge values with the existing configuration values.
Types ¶
type AttributeValues ¶ added in v1.5.0
type AttributeValues []string
attribute - name=value
func (*AttributeValues) Set ¶ added in v1.5.0
func (i *AttributeValues) Set(value string) error
func (*AttributeValues) String ¶ added in v1.5.0
func (i *AttributeValues) String() string
func (*AttributeValues) Type ¶ added in v1.5.0
func (i *AttributeValues) Type() string
type ExtraConfigValues ¶ added in v1.5.0
type ExtraConfigValues struct { Includes IncludeValues Gateways GatewayValues Attributes AttributeValues Envs EnvValues Variables VarValues Types TypeValues }
type GatewayValues ¶ added in v1.5.0
gateway - name:port
func (*GatewayValues) Set ¶ added in v1.5.0
func (i *GatewayValues) Set(value string) error
func (*GatewayValues) String ¶ added in v1.5.0
func (i *GatewayValues) String() string
func (*GatewayValues) Type ¶ added in v1.5.0
func (i *GatewayValues) Type() string
type IncludeValues ¶ added in v1.5.0
include file - priority:url|path
func (*IncludeValues) Set ¶ added in v1.5.0
func (i *IncludeValues) Set(value string) error
func (*IncludeValues) String ¶ added in v1.5.0
func (i *IncludeValues) String() string
func (*IncludeValues) Type ¶ added in v1.5.0
func (i *IncludeValues) Type() string
type Instance ¶
type Instance struct { geneos.Instance `json:"-"` L *sync.RWMutex `json:"-"` Conf *config.Config `json:"-"` InstanceHost *geneos.Host `json:"-"` Component *geneos.Component `json:"-"` ConfigLoaded bool `json:"-"` Env []string `json:",omitempty"` }
The Instance type is the common data shared by all instance / component types
type TypeValues ¶ added in v1.5.0
type TypeValues []string
attribute - name=value
func (*TypeValues) Set ¶ added in v1.5.0
func (i *TypeValues) Set(value string) error
func (*TypeValues) String ¶ added in v1.5.0
func (i *TypeValues) String() string
func (*TypeValues) Type ¶ added in v1.5.0
func (i *TypeValues) Type() string
type UnsetCmdHexKeyed ¶ added in v1.5.0
type UnsetCmdHexKeyed []string
func (*UnsetCmdHexKeyed) Set ¶ added in v1.5.0
func (i *UnsetCmdHexKeyed) Set(value string) error
func (*UnsetCmdHexKeyed) String ¶ added in v1.5.0
func (i *UnsetCmdHexKeyed) String() string
func (*UnsetCmdHexKeyed) Type ¶ added in v1.5.0
func (i *UnsetCmdHexKeyed) Type() string
type UnsetCmdValues ¶ added in v1.5.0
type UnsetCmdValues []string
unset Var flags take just the key, either a name or a priority for include files
func (*UnsetCmdValues) Set ¶ added in v1.5.0
func (i *UnsetCmdValues) Set(value string) error
func (*UnsetCmdValues) String ¶ added in v1.5.0
func (i *UnsetCmdValues) String() string
func (*UnsetCmdValues) Type ¶ added in v1.5.0
func (i *UnsetCmdValues) Type() string
type UnsetConfigValues ¶ added in v1.5.0
type UnsetConfigValues struct { Keys UnsetCmdValues Includes UnsetCmdValues Gateways UnsetCmdValues Attributes UnsetCmdValues Envs UnsetCmdValues Variables UnsetCmdHexKeyed Types UnsetCmdValues }