Configuration reference
Ragna uses TOML as language for its configuration file. The
ragna
CLI defaults to ragna.toml
in the current working directory. This behavior can
be overritten in two ways:
- The
RAGNA_CONFIG
environment variable. - The
-c
/--config
option of theragna
CLI subcommands.
The CLI option takes precedence over the environment variable.
There are two main ways to generate a configuration file:
- Running
ragna init
in a terminal starts an interactive wizard that guides you through the generation. The example configuration below is the result of choosing the first option the wizard offers you. -
The configuration can also be created programmatically from Python. The example configuration below is the result of the following snippet.
from ragna.deploy import Config config = Config() config.to_file("ragna.toml")
Example
local_root = "/home/docs/.cache/ragna"
auth = "ragna.deploy.NoAuth"
key_value_store = "ragna.deploy.InMemoryKeyValueStore"
document = "ragna.core.LocalDocument"
source_storages = [
"ragna.source_storages.RagnaDemoSourceStorage",
]
assistants = [
"ragna.assistants.RagnaDemoAssistant",
]
hostname = "127.0.0.1"
port = 31476
root_path = ""
origins = [
"http://127.0.0.1:31476",
]
session_lifetime = 86400
database_url = "sqlite:////home/docs/.cache/ragna/ragna.db"
Referencing Python objects
Some configuration options reference Python objects, e.g.
document = ragna.core.LocalDocument
. Internally, this is roughly treated as
from ragna.core import LocalDocument
.
You can inject your own objects here and do not need to rely on the defaults by Ragna. To do so, make sure that the module the object is defined in is on Python's search path. There are multiple ways to achieve this, e.g.:
- Install your module as part of a package in your current environment.
- Set the
PYTHONPATH
environment variable to include the directory your module is located in.
Environment variables
All configuration options can be set or overridden by environment variables by using the
RAGNA_
prefix. For example, document = ragna.core.LocalDocument
in the configuration
file is equivalent to setting RAGNA_DOCUMENT=ragna.core.LocalDocument
.
For configuration options in subsections, the subsection name needs to be appended to
the prefix, e.g. RAGNA_API_
. The value needs to be in JSON format. For example
[api]
origins = [
"http://localhost:31477",
]
is equivalent to RAGNA_API_ORIGINS='["http://localhost:31477"]'
.
Configuration options
local_root
Local root directory Ragna uses for storing files. See ragna.local_root.
auth
ragna.deploy.Auth class to use for authenticating users.
key_value_store
ragna.deploy.KeyValueStore class to use for temporary storage.
document
ragna.core.Document class to use to upload and read documents.
source_storages
ragna.core.SourceStorages to be available for the user to use.
assistants
ragna.core.Assistants to be available for the user to use.
hostname
Hostname the REST API will be bound to.
port
Port the REST API will be bound to.
root_path
A path prefix handled by a proxy that is not seen by the REST API, but is seen by external clients.
origins
CORS origins that are allowed to connect to the REST API.
session_lifetime
Number of seconds of inactivity after a user has to login again.
database_url
URL of a SQL database that will be used to store the Ragna state. See SQLAlchemy documentation on how to format the URL.