Elektra
0.8.24
|
kdb import <destination> [<format>]
Where destination
is the destination where the user wants the keys to be imported into. format
is the format of the keys that are imported.
If the format
argument is not passed, then the default format will be used as determined by the value of the sw/kdb/current/format
key. By default, that key is set to the storage
format. The format
attribute relies on Elektra’s plugin system to properly import the configuration. The user can view all plugins available for use by running the kdb-list(1) command. To learn about any plugin, the user can simply use the kdb-info(1) command.
This command allows a user to import an existing configuration into the key database. The configuration that the user wants to import is read from stdin
. The user should specify the format that the current configuration or keys are in, otherwise the default format will be used. The default format is storage
but can be changed by editing the value of the /sw/elektra/kdb/#0/current/format
key. The storage
plugin can be configured at compile-time or changed by the link libelektra-storage.so
.
Conflicts can occur when importing a configuration to a part of the database where keys already exist. Conflicts when importing can be resolved using a strategy with the -s
argument.
Specific to kdb import
the following strategy exists:
validate
: apply metadata as received from base, and then cut+append all keys as imported. If the appended keys do not have a namespace, the namespace given by -N
is added.The other strategies are implemented by the merge framework and are documented in elektra-merge-strategy(7).
-H
, --help
: Show the man page.-V
, --version
: Print version info.-p
, --profile <profile>
: Use a different kdb profile.-C
, --color <when>
: Print never/auto(default)/always colored output.-s
, --strategy <name>
: Specify which strategy should be used to resolve conflicts.-v
, --verbose
: Explain what is happening.-c
, --plugins-config
: Add a configuration to the format plugin.-N
, --namespace <namespace>
: Specify the namespace to use when writing cascading keys (validate
strategy only). See below in KDB./sw/elektra/kdb/#0/current/verbose
: Same as -v
: Explain what is happening (output merged keys)./sw/elektra/kdb/#0/current/format
Change default format (if none is given at commandline) and built-in default is not your preferred format./sw/elektra/kdb/#0/current/namespace
: Specifies which default namespace should be used when setting a cascading name. By default the namespace is user, except kdb
is used as root, then system
is the default (validate
strategy only).To import a configuration stored in the XML format in a file called example.xml
below user/keyset
:
kdb import user/keyset xmltool < example.xml
To import a configuration stored in the ini
format in a file called example.ini
below user/keyset
replacing any previous keys stored there:
cat example.ini | kdb import -s cut user/keyset ini
To import a configuration stored in the ini
format in a file called example.ini
below user/keyset
keeping any previous keys stored there that aren't present in the newly imported configuration:
cat example.ini | kdb import -s import user/keyset ini
To restore a backup (stored as sw.ecf
) of a user's configuration below system/sw
:
cat sw.ecf | kdb import system/sw