# Конфигурация

Autin использует два файла конфигурации. Они хранятся в `~/.config/atuin/`. Данные
хранятся в `~/.local/share/atuin` (если не определено другое в XDG\_\*).

Путь до катклога конфигурации может быть изменён установкой
параметра `ATUIN_CONFIG_DIR`. Например

```
export ATUIN_CONFIG_DIR = /home/ellie/.atuin
```

## Пользовательская конфигурация

```
~/.config/atuin/config.toml
```

Этот файл используется когда клиент работает на локальной машине (не сервере).

See [config.toml](../../atuin-client/config.toml) for an example

### `dialect`

Этот параметр контролирует как [stats](stats.md) команда обрабатывает данные.
Может принимать одно из двух допустимых значений:

```
dialect = "uk"
```

или

```
dialect = "us"
```

По умолчанию - "us".

### `auto_sync`

Синхронизироваться ли автоматически если выполнен вход. По умолчанию - да (true)
```
auto_sync = true/false
```

### `sync_address`

Адрес сервера для синхронизации. По умолчанию `https://api.atuin.sh`.

```
sync_address = "https://api.atuin.sh"
```

### `sync_frequency`

Как часто клиент синхронизируется с сервером. Может быть указано в
понятном для человека формате. Например, `10s`, `20m`, `1h`, и т.д.
По умолчанию `1h`

Если стоит значение 0, Autin будет синхронизироваться после каждой выполненной команды.
Помните, что сервера могут иметь ограничение на количество отправленных запросов.

```
sync_frequency = "1h"
```

### `db_path`

Путь до базы данных SQlite. По умолчанию это
`~/.local/share/atuin/history.db`.

```
db_path = "~/.history.db"
```

### `key_path`

Путь до ключа шифрования Autin. По умолчанию,
`~/.local/share/atuin/key`.

```
key = "~/.atuin-key"
```

### `session_path`

Путь до серверного файла сессии Autin. По умолчанию,
`~/.local/share/atuin/session`. На самом деле это просто API токен.

```
key = "~/.atuin-session"
```

### `search_mode`

Определяет, какой режим поиска будет использоваться. Autin поддерживает "prefix",
текст целиком (fulltext) и неточный ("fuzzy") поиск. Режим "prefix" производит
поиск по "запрос\*", "fulltext" по "\*запрос\*", и "fuzzy" использует
[вот такой](#fuzzy-search-syntax) синтаксис.

По умолчанию стоит значение "fuzzy"

### `filter_mode`

Фильтр, по-умолчанию использующийся для поиска

| Столбец 1        | Столбец 2	                                               |
|------------------|----------------------------------------------------------|
| global (default) | Искать историю команд со всех хостов, сессий и каталогов |
| host             | Искать историю команд с этого хоста                      |
| session          | Искать историю команд этой сессии                        |
| directory        | Искать историю команд, выполненных в текущей папке       |

Режимы поиска могут быть изменены через ctrl-r


```
search_mode = "fulltext"
```

#### fuzzy search syntax

Режим поиска "fuzzy" основан на
[fzf search syntax](https://github.com/junegunn/fzf#search-syntax).

| Токен     | Тип совпадений             | Описание                            |
|-----------|----------------------------|-------------------------------------|
| `sbtrkt`  | fuzzy-match                | Всё, что совпадает с `sbtrkt`       |
| `'wild`   | exact-match (В кавычках)   | Всё, что включает в себя `wild`     |
| `^music`  | prefix-exact-match         | Всё, что начинается с `music`       |
| `.mp3$`   | suffix-exact-match         | Всё, что заканчивается на `.mp3`    |
| `!fire`   | inverse-exact-match        | Всё, что не включает в себя `fire`  |
| `!^music` | inverse-prefix-exact-match | Всё, что не начинается с `music`    |
| `!.mp3$`  | inverse-suffix-exact-match | Всё, что не заканчивается на `.mp3` |

Знак вертикальной черты означает логическое ИЛИ. Например, запрос ниже вернет
всё, что начинается с `core` и заканчивается либо на `go`, либо на `rb`, либо на `py`.

```
^core go$ | rb$ | py$
```

## Серверная конфигурация

`// TODO`