Hiveconf¶
Overview¶
Hiveconf is the name of the configuration system used in ThinLinc. It is however not a ThinLinc-specific configuration system, but instead a generic configuration framework for storing key/value pairs in a human-readable way, although still in a format that’s easy to read and modify from a computer program.
Hiveconf stores data using a “backend”, meaning configuration data can
be stored in different ways. The default backend which is also used in
ThinLinc is using a text file format similar to Windows
.INI
-files, or the format used in smb.conf
from Samba.
In ThinLinc, Hiveconf can only guarantee that files with encoding UTF-8 are correctly read. The Hiveconf-files of ThinLinc ships in UTF-8, but the encoding of the files could change if the files are opened or manually modified on a non UTF-8 system.
In this section, we will describe Hiveconf from a general point of view and also describe ThinLinc-specific details.
Basic syntax¶
Basically, a Hiveconf file consists of key/value pairs with an equal
sign (=
) between them, as in the following example:
vsm_server_port = 9000
vnc_port_base = 5900
The values after the equal sign can be of the following types:
String
Boolean
Integer
Float
Binary data as hexadecimal ASCII
Data can also be lists of the above types, these lists are space-separated.
Tree structure¶
Parameters in Hiveconf all reside in folders. Folders are just like a directory or folder in a normal file system. By adding folder directives to Hiveconf files, the parameters will be split up in a tree structure, meaning each parameter will be addressed using a path. This way, two folders can have two parameters with the same name without collision.
The benefits of this is that a software suite (for instance ThinLinc)
can have one common configuration namespace, without having to name all
configuration parameters uniquely, since every component in the suite
can have its own namespace. In ThinLinc, the VSM server has its
parameters in the /vsmserver
folder, the VSM agent has its
parameters in the /vsmagent
folder and so on.
Looking from a system global point of view, every software package has its own folder, meaning all configuration parameters of the system can be accessed using a common tool.
Folders are put into the configuration files by adding a path inside square brackets to the file as in the following example:
#
# Hiveconf configuration file - VSM server
#
[/vsmserver]
unbind_ports_at_login=true
# Administrators email
admin_email = root@localhost
In this example, both parameters (unbind_ports_at_login
and
admin_email
) reside in the /vsmserver
folder. This means that
they should be addressed as /vsmserver/unbind_ports_at_login
,
/vsmserver/admin_email
respectively if used from inside a program
using the Hivetool libraries. This is of course not that important from
the system administrator’s point of view, but it’s important to
understand the principle.
Mounting datasources¶
One Hiveconf file can use another Hiveconf file by mounting the other file using a mount command as in the following example:
%mount HA.hconf
The mount should be compared to a mount on a Linux. That is, the mount adds the tree structure of the file mounted at exactly the place in the current tree structure where the mount command was found.
Mounts can also use wildcards, as in the following example:
%mount conf.d/*.hconf
The above is exactly what you’ll find if you look into the file
/opt/thinlinc/etc/thinlinc.hconf
. Hiveconf will mount all files
in /opt/thinlinc/etc/conf.d
and add them to the current folder.
This is a very convenient way to add all configuration files for a
specific software suite to the Hiveconf namespace.
Host-wide configuration¶
As we hinted in Tree structure, Hiveconf lays the foundation for a host-wide configuration system where all applications on a host can be configured using a single system with a common API. This can be accomplished because each application will get its own subfolder in the host-wide configuration folder, so that two applications’ parameters won’t collide even if they have the same name. Using the mount command, every application can have its own configuration file, while still exporting its parameters to the host-wide folder system.
There is a host-wide Hiveconf “root”, implemented by the file
/etc/root.hconf
. This file mounts all files in
/etc/hiveconf.d/
where an application can drop its own Hiveconf
file at install-time, just like it can drop a file in for example
/etc/logrotate.d
or /etc/profile.d
.
Hiveconf tools¶
In addition to the system libraries used by applications to read and write configuration parameters that reside in Hiveconf files, there is a command line utility named hivetool for inspecting and setting parameters from the command line. This can be very convenient, for example when scripting setup scripts that need to set some parameter.
hivetool without parameters will do nothing. To see all parameters on the system, run:
$ hivetool -Ra /
This instructs hivetool to print all parameters, beginning
from the root (/
) and recursing downwards. With a standard Hiveconf
installation this will list Samba and KDE configuration parameters. If
ThinLinc is installed, it will list ThinLinc parameters as well.
To print a specific parameter, run hivetool with the name of the parameter as parameter. For example:
$ hivetool /thinlinc/vsmserver/admin_email
root@localhost
Setting a parameter is equally easy. To set the admin_email
parameter above, execute the following:
$ hivetool /thinlinc/vsmserver/admin_email=johndoe@example.com
Hiveconf and ThinLinc¶
ThinLinc uses Hiveconf as its primary configuration system on the server-side. In this section, we will describe the convenience utility shipped with ThinLinc. For descriptions of the folders and parameters used by ThinLinc, please refer to Server configuration
The ThinLinc configuration tool¶
In order to access the ThinLinc part of the Hiveconf configuration
namespace without having to address it using the host-wide path (i.e. to
avoid having to add /thinlinc/
to all parameters, a tool named
tl-config is shipped with ThinLinc).
tl-config takes the same parameters as hivetool and works the same way. Refer to Hiveconf tools for information about hivetool. Try for example:
$ tl-config -Ra /
This command will print all ThinLinc-related parameters.