Metadata-Version: 2.4
Name: spondex
Version: 0.1.0
Summary: CLI daemon for syncing music libraries between Yandex Music and Spotify
Project-URL: Homepage, https://github.com/alesha-pro/spondex
Project-URL: Repository, https://github.com/alesha-pro/spondex
Author: alesha-pro
License-Expression: MIT
License-File: LICENSE
Classifier: Development Status :: 4 - Beta
Classifier: Environment :: Console
Classifier: Operating System :: POSIX
Classifier: Programming Language :: Python :: 3.12
Classifier: Topic :: Multimedia :: Sound/Audio
Requires-Python: >=3.12
Requires-Dist: aiosqlite>=0.19
Requires-Dist: fastapi>=0.110
Requires-Dist: httpx>=0.27
Requires-Dist: pydantic>=2.0
Requires-Dist: rich>=13.0
Requires-Dist: spotipy>=2.25.2
Requires-Dist: structlog>=23.0
Requires-Dist: typer>=0.9
Requires-Dist: uvicorn[standard]>=0.27
Requires-Dist: yandex-music>=2.2.0
Provides-Extra: dev
Requires-Dist: mypy>=1.8; extra == 'dev'
Requires-Dist: pytest-asyncio>=0.23; extra == 'dev'
Requires-Dist: pytest-cov>=4.0; extra == 'dev'
Requires-Dist: pytest>=8.0; extra == 'dev'
Requires-Dist: ruff>=0.3; extra == 'dev'
Description-Content-Type: text/markdown

# Spondex

CLI-демон для синхронизации музыкальных библиотек между **Spotify** и **Яндекс Музыкой**.

Spondex работает в фоне как демон и периодически синхронизирует любимые треки между платформами. Новые лайки с любой стороны автоматически переносятся на другую с учётом нечёткого сопоставления, транслитерации и проверки длительности.

## Установка

```bash
# Клонировать и установить через uv
git clone <repo-url> && cd spondex
uv sync
```

## Предварительная настройка

Перед первым запуском `spondex start` понадобятся учётные данные обоих сервисов. Мастер настройки запросит их интерактивно; ниже — как их получить заранее.

### Токен Яндекс Музыки

OAuth-токен можно получить через браузер (DevTools) или по инструкции:

- [Получение токена Yandex Music](https://yandex-music.readthedocs.io/en/main/token.html)

Полученный токен нужно будет ввести в wizard или позже задать командой:

```bash
spondex config set yandex.token <ваш_токен>
```

### Настройка приложения Spotify

1. Откройте [Spotify Developer Dashboard](https://developer.spotify.com/dashboard/).
2. Создайте новое приложение (Create app).
3. В настройках приложения скопируйте **Client ID** и **Client Secret**.
4. В разделе **Redirect URIs** добавьте URI для OAuth:
   - `http://127.0.0.1:8888/callback`
5. Сохраните изменения.

При первом запуске wizard настройки запросит Client ID и Client Secret, откроет браузер для авторизации в Spotify и сохранит `refresh_token` в `~/.spondex/config.toml`.

При необходимости задать данные вручную:

```bash
spondex config set spotify.client_id <client_id>
spondex config set spotify.client_secret <client_secret>
spondex config set spotify.redirect_uri "http://127.0.0.1:8888/callback"
# refresh_token выдаётся после авторизации через браузер (wizard это делает автоматически)
```

## Быстрый старт

```bash
# Первый запуск — запускает wizard настройки
spondex start

# Проверить статус
spondex status

# Запустить синхронизацию сразу
spondex sync --now

# Смотреть логи
spondex logs -f

# Открыть веб-дашборд
spondex dashboard

# Остановить демон
spondex stop
```

## Команды

| Команда                              | Описание                                              |
| ------------------------------------ | ----------------------------------------------------- |
| `spondex start`                      | Запустить демон (при первом запуске — мастер настройки) |
| `spondex stop`                       | Остановить демон корректно                            |
| `spondex restart`                    | Остановить и снова запустить                          |
| `spondex status`                     | Состояние, аптайм, планировщик, счётчики треков        |
| `spondex sync [--mode full]`         | Запустить цикл синхронизации                          |
| `spondex logs [-n 50] [-f]`         | Вывод логов демона                                    |
| `spondex logs --sync`                | JSON-лог синхронизации                                |
| `spondex dashboard`                  | Открыть веб-дашборд в браузере                        |
| `spondex config show`                | Текущая конфигурация (секреты скрыты)                 |
| `spondex config set <key> <val>`     | Задать значение (напр. `sync.mode full`)              |
| `spondex db status`                  | Статистика БД и данные последней синхронизации         |

Подробная документация по CLI со всеми опциями и примерами: [docs/CLI.md](docs/CLI.md).

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

Конфигурация хранится в `~/.spondex/config.toml` и создаётся мастером настройки при первом запуске `spondex start`.

```bash
# Просмотр
spondex config show

# Изменение
spondex config set sync.interval_minutes 15
spondex config set sync.mode full
spondex config set spotify.refresh_token <token>
spondex config set yandex.token <token>
```

### Секции

- **daemon** — `dashboard_port`, `log_level`
- **sync** — `interval_minutes`, `mode` (full/incremental), `propagate_deletions`
- **spotify** — `client_id`, `client_secret`, `redirect_uri`, `refresh_token`
- **yandex** — `token`

## Архитектура

```
CLI (typer)
  │
  │  httpx (UDS)
  ▼
FastAPI RPC Server ──► DaemonState
  │  ~/.spondex/daemon.sock       │
  │                               ├── SyncEngine
  │                               ├── SyncScheduler
  │                               └── Database (SQLite)
  │
Dashboard Server (Starlette + React SPA)
  │  http://127.0.0.1:9847
```

**CLI** — тонкий клиент, отправляющий JSON-команды через Unix domain socket.

**Daemon** — даемонизация через double-fork с PID-файлом, обработкой сигналов и структурированным логированием (structlog → RotatingFileHandler).

**RPC Server** — FastAPI на UDS. Все команды идут через `POST /rpc` с телом `{"cmd": "...", "params": {}}`.

**Sync Engine** — двунаправленная синхронизация с трёхуровневым нечётким сопоставлением (нормализация, транслитерация, fuzzy с проверкой длительности). Режимы full и incremental.

**Dashboard** — React SPA на Starlette с обновлениями по WebSocket в реальном времени, графиками и управлением треками.

## Разработка

```bash
# Установить dev-зависимости
uv sync --extra dev

# Запустить тесты
uv run pytest tests/ -v

# Тесты с покрытием
uv run pytest tests/ --cov=spondex --cov-report=term-missing

# Линтинг
uv run ruff check src/ tests/

# Форматирование
uv run ruff format src/ tests/

# Проверка типов
uv run mypy src/
```

## Безопасность

- Файл конфигурации (`~/.spondex/config.toml`) создаётся с правами `chmod 600`
- Выводится предупреждение, если права на конфиг слишком открытые
- Демон выставляет `umask(0o077)` — все runtime-файлы (сокет, логи) доступны только владельцу
- API-токены хранятся как `SecretStr` и не попадают в логи и вывод CLI
