Elektra
0.8.16
|
This tutorial assumes that you know what namespaces are. We will only be talking about cascading lookup here.
In Elektra, the default order of namespaces is as follows:
.git
or .htaccess
)Looking at this order, we can see that if a configuration option isn't specified by the user (then it would be in the user
namespace), it will be loaded from the system
namespace. In this case, the option in the system
namespace will be used if the key hasn't been defined by the user.
``` $ sudo kdb set system/sw/tutorial/cascading/#0/current/test "hello world" create a new key system/sw/tutorial/cascading/#0/current/test with string hello world
$ kdb get /sw/tutorial/cascading/#0/current/test hello world
$ kdb set user/sw/tutorial/cascading/#0/current/test "hello universe" Create a new key user/sw/tutorial/cascading/#0/current/test with string hello universe
$ kdb get /sw/tutorial/cascading/#0/current/test hello universe ```
Furthermore, in the order dir
is even higher than user
, which means that configuration in the current folder can overwrite user configuration.
.configuration
in your current directory:
``` test = hello dir ```
Then run:
``` $ sudo kdb mount /.configuration dir/sw/tutorial/cascading/#0/current ini $ kdb get /sw/tutorial/cascading/#0/current/test hello dir ```
Cascading triggers actions when, for example, the key isn't found. This concept is used for our previous example of using system
configuration when the user
configuration is not defined. When a key starts with /
, cascading lookup will automatically be performed. e.g. using /test
instead of system/test
will do a cascading lookup.
The spec
namespace is special as it can completely change how the cascading lookup works.
For example, in the meta data of the respective spec
-keys, override links can be specified to use other keys in favor of the key itself. This way, even config from current folders (dir
) can be overwritten.
In the cascading lookup, meta data of spec
-keys comes in as follows:
override/#
keys will be considerednamespaces/#
keys are consideredfallback/#
keys will be considereddefault
value will be returnedNote: override/#
means an array of override
keys, the array can be filled by setting #
followed by the position, e.g. #0
, #1
, etc
As you can see, override links are considered before everything else, which makes them really powerful.
To create an override link, first you need to create a key to link the override to:
``` $ sudo kdb set system/overrides/test "hello override" Create a new key system/overrides/test with string hello override ```
Override links can be defined by adding them to the override/#
array:
``` $ sudo kdb setmeta spec/sw/tutorial/cascading/#0/current/test override/#0 /overrides/test $ kdb get /sw/tutorial/cascading/#0/current/test hello system override ```
Furthermore, you can specify a custom order for the namespaces, set fallback keys and more. For more information, read the `elektra-spec` help page.
Override links can also be used to define default values. It's similar to defining default values via the system
namespace, but uses overrides, which means it will be preferred over the configuration in the current folder (dir
).
This means that user defaults overwrite values specified in the .configuration
file we created and mounted earlier in this tutorial.
First you need to create the system default value to link the override to if the user hasn't defined it:
``` $ sudo kdb set system/overrides/test "hello default" Create a new key system/overrides/test with string hello default ```
Then we can create the link:
``` $ sudo kdb setmeta spec/sw/tutorial/cascading/#0/current/test override/#0 /overrides/test $ kdb get /sw/tutorial/cascading/#0/current/test hello default ```
Now the user overrides the system default:
``` $ kdb set /overrides/test "hello user" Using name user/overrides/test Create a new key user/overrides/test with string hello user $ kdb get /sw/tutorial/cascading/#0/current/test hello user ```