Quick Start
Billix-Agent lets you query your database using natural language or voice input, extract structured data from invoices using AI, and interact with everything via secure, production-grade REST APIs.
This guide walks you through:
- Authenticating 
- Connecting your database 
- Making your first query (text or voice) 
- Uploading and extracting invoice data 
⚡ Quick Start
1. 🆕 Get API Access
To start using Billix-Agent:
- Register via - POST /sign-up
- Sign in via - POST /sign-into receive your JWT token
- Use the token for all secured requests: 
Authorization: Bearer <your_token>2. 🛢️ Link Your Database
Billix-Agent supports external PostgreSQL databases. Provide the connection string in your API call.
Example:
"db_url": "postgresql://username:password@host:5432/database_name"3. 💬 Make Your First Text Query
Endpoint: POST /chat
Use natural language to generate and run SQL queries.
Request:
POST /chat
Authorization: Bearer <your_token>
Content-Type: application/json{
  "db_url": "postgresql://user:pass@host:5432/sales_db",
  "prompt": "Show me the top 5 selling products this year"
}Response:
{
  "sql_query": "SELECT name, SUM(quantity)...",
  "result": [...],
  "refined_answer": "The top 5 products are..."
}4. 🎙️ Make Your First Voice Query
Endpoint: POST /audio-chat
Upload a voice file (WAV/MP3) or send plain text for processing.
Request (form-data):
audio
file
optional
Voice input (WAV/MP3)
text
string
optional
Plain text alternative
Response:
{
  "audio_content": "<base64_audio>",
  "transcription": "Top 5 selling products..."
}5. 📄 AI Invoice Data Extraction
Billix-Agent also lets you upload invoices and get structured data extracted using AI.
A. 🧾 Upload PDF or Image
Endpoint: POST /extract/pdf-image-text
Uploads your invoice and extracts plain text from the file.
B. 📊 Extract Structured Invoice Data
Endpoint: POST /extract/invoice
Send raw text and receive structured JSON output.
Request:
{
  "text": "Invoice No: 2024-0021, Date: March 5, 2024, Total: $1,240.50..."
}Response:
{
  "vendor": "Acme Corp",
  "invoice_number": "2024-0021",
  "date": "2024-03-05",
  "total_amount": 1240.50
}🧠 Concepts & Architecture
🔍 Natural Language to SQL
When you send a prompt like “Show revenue this quarter,” Billix-Agent:
- Parses your database schema 
- Converts your prompt into SQL 
- Executes it on your provided DB 
- Refines the result into human-readable text 
Powered by Google Gemini for natural language understanding.
🛠 Tool-Based Querying (Templates)
Billix-Agent uses parameterized SQL templates called tools.
Example:
{
  "sql_template": "SELECT * FROM orders WHERE date >= '{start}' AND date <= '{end}'"
}The system automatically fills parameters like {start} and {end} based on your prompt.
🎙️ Voice Interface (via ElevenLabs)
- STT (speech-to-text): Converts voice into a prompt 
- TTS (text-to-speech): Converts response into audio 
Voice flow:
- You upload an audio file to - /audio-chat
- It's transcribed and processed like text 
- You receive both a text and audio response 
Last updated