aboutsummaryrefslogtreecommitdiff
path: root/doc/handbook/chapters/configuration.texi
blob: 27efc82e253d6ed3b71c43b072f6c8b8b8e0e43c (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
@node Configuration Handbook
@chapter Configuration Handbook

This chapter has yet to be fully written.  It is intended to be about in-depth
configuration of GNUnet.


@menu
* Config file format::
@end menu


@node Config file format
@section Config file format

In GNUnet realm, all components obey the same pattern to get configuration
values.  According to this pattern, once the component has been installed, the
installation deploys default values in @file{$prefix/share/gnunet/config.d/},
in @file{.conf} files.  In order to override these defaults, the user can
write a custom @file{.conf} file and either pass it to the component at
execution time, or name it @file{gnunet.conf} and place it under
@file{$HOME/.config/}.

A config file is a text file containing sections, and each section
contains its values.  The right format follows:

@example
[section1]
value1 = string
value2 = 23

[section2]
value21 = string
value22 = /path22
@end example

Throughout any configuration file, it is possible to use @code{$}-prefixed
variables, like @code{$VAR}, especially when they represent filenames in in
the filesystem.  It is also possible to provide defaults values for those
variables that are unset, by using the following syntax:

@example
$@{VAR:-default@}
@end example

@noindent
However, there are two ways a user can set @code{$}-prefixable variables:
(a) by defining them under a @code{[paths]} section

@example
[paths]
GNUNET_DEPLOYMENT_SHARED = $@{HOME@}/shared-data
..
[section-x]
path-x = $@{GNUNET_DEPLOYMENT_SHARED@}/x
@end example

@noindent
or (b) by setting them in the environment

@example
$ export VAR=/x
@end example

@noindent
The configuration loader will give precedence to variables set under
@code{[path]}, though.

The utility @samp{gnunet-config}, which gets installed along with GNUnet,
serves to get and set configuration values without directly editing the
@file{.conf} file.  The option @samp{-f} is particularly useful to resolve
filenames, when they use several levels of @code{$}-expanded variables.
See @samp{gnunet-config --help}.

Note that, in this stage of development, the file
@file{$HOME/.config/gnunet.conf} can contain sections for @strong{all} the
components.