.. _swh-fuse-config:
Configuration
=============
The configuration for the Software Heritage Filesystem resides in the
``swh > fuse`` section of the shared `YAML `_ configuration
file used by all Software Heritage tools, located by default at
``~/.config/swh/global.yml``.
The configuration file location is subject to the `XDG Base Directory
`_ specification as
well as explicitly overridden on the :ref:`command line ` via the
``-C/--config-file`` flag.
You can choose how ``swh-fuse`` will fetch content from the archive.
The simplest (and default) way is to query the SWH public API.
This method can be configured with the following block:
- ``web-api``:
- ``url``: archive API URL
- ``auth-token``: (optional) authentication token used with the API URL
You can use a :ref:`compressed graph ` close to your server, via its gRPC API,
to traverse the folder hierarchy much faster.
This can be configured with the following block:
- ``graph``:
- ``grpc-url``: URL to the graph's :ref:`gRPC server `.
``swh-fuse`` will also search for the following options:
- ``cache``:
- ``metadata``: where to store the metadata cache, must have either a
``in-memory`` boolean entry set to true or a ``path`` string entry (with the
corresponding disk path).
- ``blob``: where to store the blob cache, same entries as the ``metadata``
cache.
- ``direntry``: how much memory should be used by the direntry cache,
specified using a ``maxram`` entry (either as a percentage of available RAM,
or with disk storage unit suffixes: ``B``, ``KB``, ``MB``, ``GB``).
- ``json-indent``: number of spaces used to print JSON metadata files (setting
it to ``null`` disables indentation).
If no configuration is given, default values are:
- ``cache``: all cache files are stored in ``$XDG_CACHE_HOME/swh/fuse/`` (or
``~/.cache/swh/fuse`` if ``XDG_CACHE_HOME`` is not set). The direntry cache
will use at most 10% of available RAM.
- ``web-api``: URL is :swh_web:`api/1/`, with no authentication token
- ``json-indent``: 2 spaces.
Examples
--------
Here is a full ``~/.config/swh/global.yml`` equivalent to the default configuration:
.. code:: yaml
swh:
fuse:
cache:
metadata:
path: "/path/to/cache/blob.sqlite"
blob:
path: "/path/to/cache/blob.sqlite"
direntry:
maxram: 10%
web-api:
url: "https://archive.softwareheritage.org/api/1/"
json-indent: 2
This example uses a local compressed graph, an in-memory cache for metadata,
and authenticates against the SWH public API to benefit from higher rate limits:
.. code:: yaml
swh:
fuse:
cache:
metadata:
in-memory: true
blob:
path: "/path/to/cache/blob.sqlite"
graph:
grpc-url: localhost:50091
web-api:
url: "https://archive.softwareheritage.org/api/1/"
auth-token: eyJhbGciOiJIUzI1NiIsInR5cCIgOiAiSldUIiwia2lkIiA6ICJhMTMxYTQ1My1hM2IyLTQwMTUtO...
Logging
-------
The default logging level is set to ``INFO`` and can be configured through the
:ref:`shared command line interface ` via the ``-l/--log-level``
flag.
.. code:: bash
$ swh --log-level swh.fuse:DEBUG fs mount swhfs/