Skip to main content

Simple LightRAG API client

Project description

🚀 lightrag-api

Simple LightRAG API client for Python.

This library provides both synchronous and asynchronous clients for interacting with the LightRAG API, enabling document management, RAG queries, knowledge graph operations, and more.

📦 Installation

Install from source using uv or pip:

# Using uv
uv add lightrag-api

# Using pip
pip install lightrag-api

Requirements:

  • 🐍 Python >= 3.10
  • 📡 httpx >= 0.28.1
  • ✅ pydantic >= 2.12.5

⚡ Quick Start

Synchronous Client

from lightrag.api import SyncLightRagClient

# Initialize client with API key
client = SyncLightRagClient(
    base_url="https://your-lightrag-server.com",
    api_key="your-api-key"
)

# Execute a query
response = client.query("What is machine learning?")
print(response.response)

# Don't forget to close the client
client.close()

Asynchronous Client

from lightrag.api import AsyncLightRagClient

async def main():
    # Initialize client with OAuth token
    client = AsyncLightRagClient(
        base_url="https://your-lightrag-server.com",
        oauth_token="your-oauth-token"
    )
    
    try:
        # Execute a query
        response = await client.query("What is machine learning?")
        print(response.response)
    finally:
        await client.close()

# Run the async function
import asyncio
asyncio.run(main())

✨ Features

  • 📄 Document Management: Upload documents, insert text, delete documents, and manage document pipelines
  • 🔍 RAG Queries: Execute queries with multiple modes (local, global, hybrid, naive, mix, bypass), streaming support, and conversation history
  • 🕸️ Knowledge Graph Operations: Create, update, merge, and delete entities and relations
  • ⚙️ Pipeline Management: Monitor and control document processing pipelines
  • 🔄 Dual Client Support: Both synchronous (SyncLightRagClient) and asynchronous (AsyncLightRagClient) clients
  • 🛡️ Type Safety: Full Pydantic model support for request/response validation

💡 Usage Examples

🔧 Initialize Client

from lightrag.api import SyncLightRagClient, AsyncLightRagClient

# Sync client with API key
sync_client = SyncLightRagClient(
    base_url="https://api.example.com",
    api_key="your-api-key"
)

# Async client with OAuth token
async_client = AsyncLightRagClient(
    base_url="https://api.example.com",
    oauth_token="your-oauth-token"
)

❓ Simple Query

# Synchronous query
response = sync_client.query(
    query="Explain quantum computing",
    mode="mix",
    include_references=True
)
print(response.response)
print(response.references)

# Asynchronous query
response = await async_client.query(
    query="Explain quantum computing",
    mode="mix",
    include_references=True
)

📤 Upload Document

# Upload a file
response = sync_client.upload_document("path/to/document.pdf")
print(f"Document ID: {response.doc_id}")

# Or upload from bytes
with open("document.pdf", "rb") as f:
    response = sync_client.upload_document(f.read())

📝 Insert Text

# Insert single text
response = sync_client.insert_text(
    text="Your document content here...",
    file_source="manual_input.txt"
)

# Insert multiple texts
response = sync_client.insert_texts(
    texts=["Text 1", "Text 2", "Text 3"],
    file_sources=["doc1.txt", "doc2.txt", "doc3.txt"]
)

📚 API Overview

📄 Document Management

  • upload_document(file) - Upload a document file
  • insert_text(text, file_source) - Insert text into the system
  • insert_texts(texts, file_sources) - Insert multiple texts
  • get_documents() - Get statuses of all documents
  • get_documents_paginated(page, page_size) - Get paginated document list
  • delete_document(doc_ids, delete_file, delete_llm_cache) - Delete documents by ID
  • clear_documents() - Clear all documents
  • get_pipeline_status() - Get document processing pipeline status
  • cancel_pipeline() - Cancel current processing pipeline
  • reprocess_failed() - Reprocess failed documents
  • get_status_counts() - Get document status counts
  • get_track_status(track_id) - Track document processing status
  • scan_documents() - Scan for new documents

🔍 Query Methods

  • query(query, mode, include_references, ...) - Execute RAG query
  • query_stream(query, mode, ...) - Execute streaming RAG query
  • query_data(query, mode, ...) - Execute query and return structured data

🕸️ Knowledge Graph Operations

  • create_entity(name, description, labels) - Create a new entity
  • update_entity(name, description, labels) - Update an existing entity
  • delete_entity(entity_name) - Delete an entity
  • merge_entities(source_name, target_name) - Merge two entities
  • create_relation(source, target, relation, description) - Create a relation
  • update_relation(source, target, relation, description) - Update a relation
  • delete_relation(source, target, relation) - Delete a relation
  • get_knowledge_graph(limit) - Get knowledge graph data
  • get_graph_labels() - Get all graph labels
  • get_popular_labels(limit) - Get popular labels
  • search_labels(q, limit) - Search labels
  • check_entity_exists(name) - Check if entity exists

🛠️ Utility Methods

  • clear_cache() - Clear LLM response cache
  • get_version() - Get API version
  • get_tags() - Get available tags
  • get_running_models() - Get running models
  • get_health() - Check API health status
  • get_auth_status() - Get authentication status
  • login(username, password) - Login and get token
  • generate(**kwargs) - Generate text
  • chat(**kwargs) - Chat with the API

For detailed method signatures and parameters, refer to the source code documentation in src/lightrag/api/_sync_client.py and src/lightrag/api/_async_client.py.

🔐 Authentication

The client supports two authentication methods:

🔑 API Key Authentication

client = SyncLightRagClient(
    base_url="https://api.example.com",
    api_key="your-api-key"
)

The API key is sent in the X-API-Key header.

🎫 OAuth Token Authentication

client = SyncLightRagClient(
    base_url="https://api.example.com",
    oauth_token="your-oauth-token"
)

The OAuth token is sent in the Authorization: Bearer header.

Note: ⚠️ If both are provided, OAuth token takes priority.

⚠️ Error Handling

The library provides two exception types:

  • LightRagError - Base exception for all LightRAG API errors
  • LightRagHttpError - Exception for HTTP-related errors
from lightrag.api import SyncLightRagClient, LightRagError, LightRagHttpError

client = SyncLightRagClient(base_url="https://api.example.com", api_key="key")

try:
    response = client.query("test query")
except LightRagHttpError as e:
    print(f"HTTP error occurred: {e}")
except LightRagError as e:
    print(f"LightRAG error occurred: {e}")

🔗 Links

❓ FAQ

Why do you write code manually? There is an openapi-python-client generator.

openapi-python-client generates slop client code.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

lightrag_api-0.1.0.tar.gz (16.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

lightrag_api-0.1.0-py3-none-any.whl (16.3 kB view details)

Uploaded Python 3

File details

Details for the file lightrag_api-0.1.0.tar.gz.

File metadata

  • Download URL: lightrag_api-0.1.0.tar.gz
  • Upload date:
  • Size: 16.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.17 {"installer":{"name":"uv","version":"0.9.17","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for lightrag_api-0.1.0.tar.gz
Algorithm Hash digest
SHA256 546214413ee4a1e6e1411440bca2430b737dfd4fb98ccc97b82286b9f391a94e
MD5 de2e16c0b1835e82888a255c1dbaa015
BLAKE2b-256 95480cd17ac869bbd67ea78644c879c63f6136504e0b1efd07c6a6d572ab51fe

See more details on using hashes here.

File details

Details for the file lightrag_api-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: lightrag_api-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 16.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.17 {"installer":{"name":"uv","version":"0.9.17","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for lightrag_api-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 695d0860446c581e318d870e3a23a2b6de181bcb8c4928dae4fda8d750cc3bea
MD5 3ff26b54282da62ee593f240096bee5e
BLAKE2b-256 4c1310604fe39e8dd89370c0287ee38008ee8da7aad7f552559d8079b8123b40

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page