Provided by: gnunet_0.20.0-4.1build3_amd64 bug

NAME

     gnunet.conf — GNUnet configuration file

DESCRIPTION

     A GNUnet setup typically consists of a set of service processes run by a user "gnunet" and a
     set of user-interface processes run by a standard account.  The default location for the
     configuration file for the services is ~gnunet/.config/gnunet.conf.  However, as normal
     users also may need read-access to this configuration, you might want to instead put the
     service process configuration in /etc/gnunet.conf.  gnunet-setup(1), part of gnunet-gtk, can
     be used to edit this configuration.  The parts of GNUnet that are run as a normal user may
     have config options too and they read from $HOME/.config/gnunet.conf.  The latter config
     file can skip any options for the services.

     The basic structure of the configuration file is the following.
              The file is split into sections.
              Every section begins with a token in square brakets.  The current section ends
               when a new section starts or end of file is encountered.
              A section contains a number of options of the form "OPTION=VALUE".
              Whitespace surrounding the "=" token is striped out, in other words "OPTION =
               VALUE" and "OPTION=VALUE" are treated equal.
              Empty lines and lines beginning with a "#" are treated as comments.
              Boolean values are given as "YES" and "NO".

     Almost all options are optional.  The tools resort to reasonable defaults if an option is
     not present.  Default values for all of the options can be found in the files in the
     $GNUNET_PREFIX/share/gnunet/config.d/ directory.  A typical setup will work out of the box
     with those.  See the examples section below for some common setups on top of that.

   Variable naming conventions and data types
     Boolean values for options are set via "YES" or "NO" values, without the double-quotes.

     Options which include "PATH" or "path" define a path on the file-system and can take
     additional variables in the path, such as $GNUNET_TMP.

     Section names as listed more in detail below, are small letters only enclosed by square
     brakets.

   GENERAL OPTIONS
     Many options will be common between sections.  They can be repeated under each section with
     different values.  The "[PATHS]" section is special.  Here, it is possible to specify values
     for variables like "GNUNET_HOME".  Then, in all filenames that begin with "$GNUNET_HOME" the
     "$GNUNET_HOME" will be replaced with the respective value at runtime.  The main use of this
     is to redefine "$GNUNET_HOME", which by default points to $HOME/.config/.  By setting this
     variable, you can change the location where GNUnet stores its internal data.  gnunet.conf
     accepts the variable GNUNET_TMP which we suggest to use in place of the absolute definition
     of /tmp.  So instead of /tmp/foo you would write $GNUNET_TMP/foo.  The usage of
     $GNUNET_TMP/foo, will result in $TMPDIR/gnunet/foo, or $TMP/gnunet/foo and finally, if
     TMPDIR is undefined, /tmp/gnunet/foo.  The following options are generic and shared by all
     services:

     HOSTNAME
             The hostname specifies the machine on which the service is running.  This is usually
             "localhost".

     BINARY  The filename that implements the service.  For example "gnunet-service-ats".

     IMMEDIATE_START
             Start the service always when the peer starts.  Set to YES for services that should
             always be launched, even if no other service explicitly needs them.

     START_ON_DEMAND
             Set to YES to automatically start the service when it is requested by another
             service.  YES for most GNUnet services.

     NOARMBIND
             Set to YES to never have ARM bind to the respective socket.  This option is mostly
             for debugging in situations where ARM cannot pass the pre-bound socket to the child
             due to interference from PREFIX-commands.  This option is only effective in
             combination with IMMEDIATE_START being YES.  NO by default.

     PREFIX  PREFIX the given command (with its arguments) to the actual BINARY to be executed.
             Useful to run certain services under special supervisors like strace, dtrace, or
             valgrind.  Typically used in combination with IMMEDIATE_START and NOARMBIND.  Empty
             by default.

     ACCEPT_FROM
             A semi-column separated list of IPv4 addresses that are allowed to use the service;
             usually 127.0.0.1.

     ACCEPT_FROM6
             A semi-column separated list of IPv6 addresses that are allowed to use the service;
             usually ::1.

     UNIXPATH
             Path to use for the UNIX domain socket for inter process communication with the
             service on POSIX systems.

     UNIX_MATCH_UID
             If UNIX domain sockets are used, set this to YES if only users with the same UID are
             allowed to access the service.

     UNIX_MATCH_GID
             If UNIX domain sockets are used, set this to YES if only users with the same GID are
             allowed to access the service.

     RUN_PER_USER
             End-users should never have to change the defaults GNUnet provides for this option.

             YES     Set to YES if this service should be run per-user.

             NO      Set to NO if this is a system service.
     In the following sections the absence of a default value is either expressed as "Default
     value:" followed by nothing, or the lack of this line.

   ARM
     PORT    Default value: 2087

     HOSTNAME
             Default value: localhost

     BINARY  Default value: gnunet-service-arm

     ACCEPT_FROM
             Default value: 127.0.0.1;

     ACCEPT_FROM6
             Default value: ::1;

     UNIXPATH
             Special case, uses user runtime dir even for per-system service.

             Default value: $GNUNET_USER_RUNTIME_DIR/gnunet-service-arm.sock

     UNIX_MATCH_UID
             Default value: YES

     UNIX_MATCH_GID
             Default value: YES

     GLOBAL_POSTFIX
             In the -l option, format characters from strftime(3) are allowed; In the
             GLOBAL_POSTFIX, "{}" stands for the name of the respective service.  Thus the
             following example for this option would introduce per-service logging with a new log
             file each day.  Note that only the last 3 log files are preserved.  Example:

             -l $GNUNET_CACHE_HOME/{}-%Y-%m-%d.log

             Default value:

     GLOBAL_PREFIX
             Default value:

     START_SYSTEM_SERVICES
             If set to YES, ARM will only start services that are marked as system-level services
             (and we'll expect a second ARM to be run per-user to run user-level services).  Note
             that in this case you must have manually created a different configuration file with
             the user where at least this and the START_USER_SERVICES options differ.

     START_USER_SERVICES
             If set to YES, ARM will only start services that are marked as per-user services
             (and we'll expect a system user to run ARM to provide system-level services).  Per-
             user services enable better personalization and privilege separation and in
             particular ensures that personal data is stored under $HOME, which might be
             important in a multi-user system (or if $HOME is encrypted and /var/ is not).

             Note that if you have different ARM services for SYSTEM and USER, and you are not on
             UNIX, you need to change the PORT option for the USER ARM instances to some free
             port (counting down from 2085 should provide free ports).

     RESOURCE_DIAGNOSTICS
             File where we should log per-service resource consumption on exit.

             Default value: resource.log

     USERNAME
             Name of the user that will be used to provide the service.

             Default value:

     MAXBUF  Default value:

     TIMEOUT
             Default value:

     DISABLEV6
             Default value:

     BINDTO  Default value:

     REJECT_FROM
             Default value:

     REJECT_FROM6
             Default value:

     PREFIX  Default value:

   ATS
     PORT    Default value: 2098

     HOSTNAME
             Default value: localhost

     BINARY  Default value: gnunet-service-ats

     ACCEPT_FROM
             Default value: 127.0.0.1;

     ACCEPT_FROM6
             Default value: ::1;

     UNIXPATH
             Default value: $GNUNET_RUNTIME_DIR/gnunet-service-ats.sock

     UNIX_MATCH_UID
             Default value: NO

     UNIX_MATCH_GID
             Default value: YES

     MODE    Designated assignment mode.  Possible values: PROPORTIONAL, MLP, RIL.

             Default value: proportional

     UNSPECIFIED_QUOTA_IN
             quotes in KiB or MiB per seconds.  Or use the word "unlimited".  Default value: 64
             KiB

     UNSPECIFIED_QUOTA_OUT
             quotes in KiB or MiB per seconds.  Or use the word "unlimited".  Default value: 64
             KiB

     LOOPBACK_QUOTA_IN
             quotes in KiB or MiB per seconds.  Or use the word "unlimited".  Default value:
             unlimited

     LOOPBACK_QUOTA_OUT
             quotes in KiB or MiB per seconds.  Or use the word "unlimited".  Default value:
             unlimited

     LAN_QUOTA_IN
             quotes in KiB or MiB per seconds.  Or use the word "unlimited".  Default value:
             unlimited

     LAN_QUOTA_OUT
             quotes in KiB or MiB per seconds.  Or use the word "unlimited".  Default value:
             unlimited

     WAN_QUOTA_IN
             quotes in KiB or MiB per seconds.  Or use the word "unlimited".  Default value: 64
             KiB

     WAN_QUOTA_OUT
             quotes in KiB or MiB per seconds.  Or use the word "unlimited".  Default value: 64
             KiB

     WLAN_QUOTA_IN
             quotes in KiB or MiB per seconds.  Or use the word "unlimited".  Default value: 1
             MiB

     WLAN_QUOTA_OUT
             quotes in KiB or MiB per seconds.  Or use the word "unlimited".  Default value: 1
             MiB

     BLUETOOTH_QUOTA_IN
             Default value: 128 KiB

     BLUETOOTH_QUOTA_OUT
             Default value: 128 KiB

     PROP_PROPORTIONALITY_FACTOR
             How proportional to preferences is bandwidth distribution in a network?  Default
             value: 2.00

             1.0     Fair with respect to addresses without preferences.

             > 1.0   The bigger, the more respect is paid to preferences.

     PROP_STABILITY_FACTOR
             Should we stick to existing connections are prefer to switch?  [1.0...2.0], lower
             value prefers to switch, bigger value is more tolerant.

             Default value: 1.25

     MLP_MAX_DURATION
             Maximum duration for a solution process (both LP and MILP).  Default value: 3 s

     MLP_MAX_ITERATIONS
             Maximum numbero of iterations for a solution process (only LP).  Tolerated MIP Gap
             [0.0 .. 1.0].

             Default value: 0.025

     MLP_MAX_MIP_GAP
             Tolerated LP/MIP Gap [0.0 .. 1.0].

             Default value: 0.025

     MLP_MAX_LP_MIP_GAP
             Default value: 0.025

     MLP_MAX_ITERATIONS
             Maximum number of iterations for a solution process.

             Default value: 1024

     MLP_COEFFICIENT_D
             Default value: 1.0

     MLP_COEFFICIENT_U
             Default value: 1.0

     MLP_COEFFICIENT_R
             Default value: 1.0

     MLP_MIN_BANDWIDTH
             Default value: 1024

     MLP_MIN_CONNECTIONS
             Default value: 4

     MLP_DUMP_PROBLEM_ALL
             Dump all problems to disk.

             Default value: YES

     MLP_DUMP_SOLUTION_ALL
             Dump all solution to disk.

             Default value: YES

     MLP_GLPK_VERBOSE
             Print GLPK output.

             Default value: YES

     MLP_DUMP_PROBLEM_ON_FAIL
             Dump all problems to disk.

             Default value: YES

     MLP_DUMP_SOLUTION_ON_FAIL
             Dump all solution to disk.

             Default value: YES

     RIL_STEP_TIME_MIN
             Default value: 500 ms

     RIL_STEP_TIME_MAX
             Default value: 1000 ms

     RIL_ALGORITHM
             Possible values: SARSA or Q-LEARNING.

             Default value: Q-LEARNING

     RIL_DISCOUNT_BETA
             Default value: 0.7

     RIL_GRADIENT_STEP_SIZE
             Default value: 0.3

     RIL_TRACE_DECAY
             Default value: 0.2

     RIL_EXPLORE_RATIO
             Default value: 0.1

     RIL_GLOBAL_REWARD_SHARE
             Default value: 1

   AUCTION

CADET

IMMEDIATE_START
        Default value: YES

START_ON_DEMAND
        Default value: YES
HOSTNAME
        Default value: localhost
PREFIX

ACCEPT_FROM
        Default value: 127.0.0.1;

ACCEPT_FROM6
        Default value: ::1;

UNIXPATH
        Default value: $GNUNET_RUNTIME_DIR/gnunet-service-cadet.sock

UNIX_MATCH_UID
        Default value: NO

UNIX_MATCH_GID
        Default value: YES

REFRESH_CONNECTION_TIME
        How often do we send KEEPALIVE messages on connections to keep them from timing out?

        Default value: 5 min

DROP_PERCENT
        Percentage of packets CADET is artificially dropping.  Used for testing only!

ID_ANNOUNCE_TIME
        How frequently do we usually announce our presence in the DHT?

        Default value: 1 h

CONNECT_TIMEOUT
        Default value: 30 s

DHT_REPLICATION_LEVEL
        What is the replication level we give to the DHT when announcing our existence?  Usually
        there is no need to change this.

        Default value: 3

MAX_TUNNELS
        Not implemented

        Default value: 1000

MAX_CONNECTIONS
        Not implemented, replaced by MAX_ROUTES in NEW CADET!

        Default value: 1000

MAX_ROUTES
        How many routes do we participate in at most?  Should be smaller than MAX_MSGS_QUEUE.

        Default value: 5000

MAX_MSGS_QUEUE
        Not implemented

        Default value: 10000

MAX_PEERS
        Not implemented

        Default value: 1000

RATCHET_TIME
        How often do we advance the ratchet even if there is not any traffic?

        Default value: 1 h

RATCHET_MESSAGES
        How often do we advance the ratched if there is traffic?

        Default value: 64

COMMUNICATOR-UNIX

UNIXPATH
        Default value: $GNUNET_RUNTIME_DIR/gnunet-communicator-unix.sock

CONSENSUS

START_ON_DEMAND
        Default value: YES
HOSTNAME
        Default value: localhost
ACCEPT_FROM
        Default value: 127.0.0.1;

ACCEPT_FROM6
        Default value: ::1;

UNIXPATH
        Default value: $GNUNET_RUNTIME_DIR/gnunet-service-consensus.sock

UNIX_MATCH_UID
        Default value: YES

UNIX_MATCH_GID
        Default value: YES

CORE

START_ON_DEMAND
        Default value: YES
HOSTNAME
        Default value: localhost
ACCEPT_FROM
        Default value: 127.0.0.1;

ACCEPT_FROM6
        Default value: ::1;

UNIXPATH
        Default value: $GNUNET_RUNTIME_DIR/gnunet-service-core.sock

UNIX_MATCH_UID
        Default value: NO

UNIX_MATCH_GID
        Default value: YES

DISABLE_SOCKET_FORWARDING
        Default value: NO

USERNAME

MAXBUF

TIMEOUT

DISABLEV6

BINDTO

REJECT_FROM

REJECT_FROM6

PREFIX

USE_EPHEMERAL_KEYS
        Default value: YES

        This MUST be set to YES in production, only set to NO for testing for performance
        (testbed/cluster-scale use!).

DATACACHE-POSTGRES

DATASTORE

START_ON_DEMAND
        Default value: YES

UNIXPATH
        Default value: $GNUNET_RUNTIME_DIR/gnunet-service-datastore.sock

UNIX_MATCH_UID
        Default value: NO

UNIX_MATCH_GID
        Default value: YES
HOSTNAME
        Default value: localhost
ACCEPT_FROM
        Default value: 127.0.0.1;

ACCEPT_FROM6
        Default value: ::1;
BLOOMFILTER
        Default value: $GNUNET_DATA_HOME/datastore/bloomfilter

DATABASE
        Default value: sqlite

DISABLE_SOCKET_FORWARDING
        Default value: NO

DATASTORE-SQLITE

FILENAME
        Default value: $GNUNET_DATA_HOME/datastore/sqlite.db

DATASTORE-POSTGRES

DATASTORE-MYSQL

DATABASE
        Default value: gnunet
PASSWORD

DATASTORE-HEAP

HASHMAPSIZE
        Default value: 1024

DHT

IMMEDIATE_START boolean
        Default value: YES

START_ON_DEMAND boolean
        Default value: YES

PORT integer
        Default value: 2095

HOSTNAME string
        Default value: localhost

BINARY string
        Default value: gnunet-service-dht

ACCEPT_FROM string
        Default value: 127.0.0.1;

ACCEPT_FROM6 string
        Default value: ::1;

BUCKET_SIZE integer
        Default value: 4

UNIXPATH path
        Default value: $GNUNET_RUNTIME_DIR/gnunet-service-dht.sock

UNIX_MATCH_UID boolean
        Default value: NO

UNIX_MATCH_GID boolean
        Default value: YES

DISABLE_SOCKET_FORWARDING boolean
        Default value: NO
# Should the DHT cache results that we are routing in the DATACACHE as well?  CACHE_RESULTS = YES
# Special option to disable DHT calling 'try_connect' (for testing) DISABLE_TRY_CONNECT = NO

DHTCACHE

DATABASE
        Default value: heap
DISABLE_BF_RC boolean
        Disable RC-file for Bloom filter?  (for benchmarking with limited IO availability)

        Default value: NO

      EXIT

FS

GNS

HOSTLIST

IDENTITY

NAMECACHE

NAMESTORE

NAT-AUTO

NAT

NSE

PEERINFO

PEERSTORE

PT

REGEX

RESOLVER

REST

UNIXPATH
        Default value: $GNUNET_USER_RUNTIME_DIR/gnunet-service-rest.sock
BIND_TO
        Default value: 127.0.0.1

BIND_TO6
        Default value: ::1

REST_PORT
        Default value: 7776

REST_ALLOW_HEADERS
        Default value: Authorization,Accept,Content-Type

REST_ALLOW_ORIGIN
        Default value: *

REST_ALLOW_CREDENTIALS
        Default value: true

REVOCATION

SCALARPRODUCT

SECRETSHARING

SET

STATISTICS

TEMPLATE

TESTBED-LOGGER

TESTBED

TESTING

TOPOLOGY

IMMEDIATE_START
        Default value: YES

NOARMBIND
        Default value: YES

MINIMUM-FRIENDS
        Default value: 0

FRIENDS-ONLY
        Default value: NO

TARGET-CONNECTION-COUNT
        Default value: 16

FRIENDS
        Default value: $GNUNET_CONFIG_HOME/topology/friends.txt

TRANSPORT

UTIL

VPN

START_ON_DEMAND
        Default value: YES
HOSTNAME
        Default value: localhost
ACCEPT_FROM
        Default value: 127.0.0.1;

ACCEPT_FROM6
        Default value: ::1;

UNIXPATH
        Default value: $GNUNET_RUNTIME_DIR/gnunet-service-vpn.sock

UNIX_MATCH_UID
        Default value: NO

UNIX_MATCH_GID
        Default value: YES

IPV6ADDR
        Default value: 1234::1

IPV6PREFIX
        Default value: 32

IPV4ADDR
        Default value: 10.11.10.1

IPV4MASK
        Default value: 255.255.0.0

VIRTDNS
        Default value: 10.11.10.2

VIRTDNS6
        Default value: 1234::17

ZONEMASTER

START_ON_DEMAND
        Default value: YES

IMMEDIATE_START
        Default value: YES

HOSTNAME
        Default value: localhost
UNIXPATH
        Default value: $GNUNET_USER_RUNTIME_DIR/gnunet-service-zonemaster.sock
UNIX_MATCH_UID
        Do we require users that want to access GNS to run this process (usually not a good
        idea)?

        Default value: NO

UNIX_MATCH_GID
        Do we require users that want to access GNS to be in the 'gnunet' group?

        Default value: NO

MAX_PARALLEL_BACKGROUND_QUERIES
        How many queries is GNS allowed to perform in the background at the same time?

        Default value: 1000

ZONE_PUBLISH_TIME_WINDOW
        How frequently do we try to publish our full zone?

        Default value: 4 h

USE_CACHE
        Using caching or always ask DHT?

        Default value: YES

PREFIX

ZONEMASTER-MONITOR

START_ON_DEMAND
        Default value: YES

IMMEDIATE_START
        Default value: YES

HOSTNAME
        Default value: localhost
UNIXPATH
        Default value: $GNUNET_USER_RUNTIME_DIR/gnunet-service-zonemaster-monitor.sock
UNIX_MATCH_UID
        Do we require users that want to access GNS to run this process (usually not a good
        idea)?

        Default value: NO

UNIX_MATCH_GID
        Do we require users that want to access GNS to be in the 'gnunet' group?

        Default value: NO

EXAMPLES

     This example is a simple way to get started, using a server that has a known list of peers
     to get you started.  Most users will be behind a firewall on IPv4, as such NAT is enabled.
     Please remember to change your IP address to the actual external address for your usage.
           [hostlist]
           OPTIONS = -b -e

           [nat]
           BEHIND_NAT = YES
           ENABLE_UPNP = YES
           DISABLEV6 = YES
           EXTERNAL_ADDRESS = 157.166.249.10

           [arm]
           START_SYSTEM_SERVICES = YES
           START_USER_SERVICES = NO

FILES

     ~gnunet/.config/gnunet.conf GNUnet system-user configuration file $HOME/.config/gnunet.conf
     User specific GNUnet configuration file /etc/gnunet.conf Systemwide GNUnet configuration
     file $GNUNET_PREFIX/share/gnunet/config.d/ GNUnet configuration directory with all default
     option values

SEE ALSO

     env(1), gnunet-arm(1), gnunet-setup(1), strftime(3).

     The full documentation for gnunet is maintained as a Texinfo manual.  If the info(1) and
     gnunet programs are properly installed at your site, the command

           info gnunet

     should give you access to the complete handbook,

           info gnunet-c-tutorial

     will give you access to a tutorial for developers.

     Depending on your installation, this information is also available in gnunet(7) and
     gnunet-c-tutorial(7).

BUGS

     Report bugs by using https://bugs.gnunet.org or by sending electronic mail to
     ⟨gnunet-developers@gnu.org⟩.