Document voice transcription hardening and storage behavior
This commit is contained in:
@@ -0,0 +1,89 @@
|
||||
# Voice Transcription Debug Runbook
|
||||
|
||||
This runbook covers Telegram voice-message troubleshooting for `audio.transcribe`.
|
||||
|
||||
## Fast Checks
|
||||
|
||||
1. Confirm tool is enabled in config:
|
||||
|
||||
```yaml
|
||||
audio:
|
||||
enabled: true
|
||||
provider:
|
||||
endpoint: http://localhost:18801/v1/audio/transcriptions
|
||||
```
|
||||
|
||||
2. Confirm recent tool events:
|
||||
|
||||
```bash
|
||||
tail -n 400 ~/.local/share/flynn/audit.log | jq -c 'select(.event_type=="tool.start" or .event_type=="tool.success" or .event_type=="tool.error" or .event_type=="tool.args_rewritten")'
|
||||
```
|
||||
|
||||
3. If needed, confirm local endpoint behavior directly:
|
||||
|
||||
```bash
|
||||
curl -sS -i -X POST http://localhost:18801/v1/audio/transcriptions \
|
||||
-F file=@/tmp/sample.ogg \
|
||||
-F model=whisper-1 \
|
||||
-F response_format=json
|
||||
```
|
||||
|
||||
## Interpreting Common Errors
|
||||
|
||||
- `Either data or url must be provided`
|
||||
- Model/tool call had empty args and no hydrated attachment data.
|
||||
|
||||
- `Only http/https URLs are allowed, got file:`
|
||||
- Model emitted `file://...` URL; Flynn should rewrite from latest session audio.
|
||||
|
||||
- `Transcription endpoint error: FFmpeg conversion failed.`
|
||||
- Endpoint could not decode payload as audio. Often caused by model-provided fake or mismatched `data`/`mime_type`.
|
||||
|
||||
- `[No speech detected]`
|
||||
- Request succeeded and endpoint returned empty transcript text.
|
||||
|
||||
## Rewrite Metric
|
||||
|
||||
Flynn emits `tool.args_rewritten` whenever it replaces model-provided `audio.transcribe` args with trusted session audio bytes.
|
||||
|
||||
Fields:
|
||||
|
||||
- `source`: `latest_turn`, `persisted`, or `history`
|
||||
- `reason`: `latest_audio_preferred`, `voice_turn_fallback`, `invalid_model_args`, `missing_model_args`
|
||||
- `original_*` and `final_mime_type` for quick diagnosis
|
||||
|
||||
Example:
|
||||
|
||||
```json
|
||||
{
|
||||
"event_type": "tool.args_rewritten",
|
||||
"event": {
|
||||
"tool_name": "audio.transcribe",
|
||||
"source": "persisted",
|
||||
"reason": "voice_turn_fallback",
|
||||
"original_mime_type": "audio/ogg",
|
||||
"final_mime_type": "audio/ogg"
|
||||
}
|
||||
}
|
||||
```
|
||||
|
||||
## Where Audio Is Stored Locally
|
||||
|
||||
Audio bytes are not written as standalone files by default. They are persisted in SQLite:
|
||||
|
||||
- DB path: `~/.local/share/flynn/sessions.db`
|
||||
- Table: `session_config`
|
||||
- Key: `lastAudioAttachment`
|
||||
- Value: JSON with `data` (base64) or `url`, plus `mimeType`
|
||||
|
||||
Inspect current value:
|
||||
|
||||
```bash
|
||||
sqlite3 ~/.local/share/flynn/sessions.db \
|
||||
"SELECT session_id,key,length(value) FROM session_config WHERE key='lastAudioAttachment';"
|
||||
```
|
||||
|
||||
## Data Lifecycle
|
||||
|
||||
- `session.clear()` (e.g. `/reset`) removes messages, tool executions, and session config for that session.
|
||||
- Session TTL pruning removes stale sessions and associated config from SQLite.
|
||||
Reference in New Issue
Block a user