Skip to main content

Python SDK for Railtown AI Railengine - Retrieval

Project description

Railengine Retrieval SDK

Python SDK for retrieving and searching data from Railtown AI Railengine - handles embeddings, storage documents, and indexed content.

Overview

The rail-engine package provides a Pythonic interface for retrieving and searching data from Railengine. It supports async/await patterns, client-side filtering, explicit storage list paging via StorageListPage, and Pydantic model deserialization.

Installation

uv pip install rail-engine

Quick Start

import asyncio
from railtown.engine import Railengine

async def main():
    # Initialize client (reads from ENGINE_PAT and ENGINE_ID env vars)
    async with Railengine() as client:
        page = await client.list_storage_documents(
            page_number=1,
            page_size=25,
        )
        print(f"total_count={page.total_count} total_pages={page.total_pages}")
        for doc in page.items:
            print(doc)

asyncio.run(main())

Configuration

Environment Variables

  • ENGINE_PAT (required) - Personal Access Token
  • ENGINE_ID (required) - Engine ID (can also be passed to constructor)
  • RAILTOWN_API_URL (optional) - Base API URL (defaults to https://cndr.railtown.ai/api)

Constructor Parameters

  • pat (optional) - PAT token (if not provided, reads from ENGINE_PAT env)
  • engine_id (optional) - Engine ID (if not provided, reads from ENGINE_ID env, required if not in env)
  • api_url (optional) - Base API URL (if not provided, reads from RAILTOWN_API_URL env or defaults to production)
  • model (optional) - Pydantic model type for deserializing retrieved data

Features

  • Multiple retrieval methods:
    • search_vector_store() - Semantic search in vector stores
    • get_storage_document_by_event_id() - Get document by EventId
    • get_storage_document_by_customer_key() - Same paging as list_storage_documents (page_number, page_size) but scoped to a CustomerKey; returns StorageListPage with items, total_pages, and total_count
    • query_storage_by_jsonpath() - Query using JSONPath
    • list_storage_documents() - Use page_number and page_size to paginate; returns StorageListPage with items, total_pages, and total_count
    • search_index() - Index search (default raw=True: each hit is the API dict; use raw=False to parse each hit's body with model or the client default); returns IndexingSearchResult with items and optional total_count
    • delete_event() - Delete an event from storage, embeddings, and indexing (raises on API errors)
  • Client-side filtering on storage reads - Optional filter_fn on storage/list/query helpers (not on search_vector_store; filter vector hits in your loop)
  • Storage list pagination - One HTTP GET per page; use page_number / page_size on the request and total_pages / total_count on StorageListPage when looping
  • Model deserialization - Optional Pydantic model support with per-call override
  • Graceful error handling - Read/search helpers often return None or empty iterables instead of raising
  • Async/await support - Built for modern async Python applications

Error Handling

The SDK provides custom exception classes:

  • RailtownError - Base exception
  • RailtownBadRequestError - 400 Bad Request
  • RailtownUnauthorizedError - 401 Unauthorized
  • RailtownNotFoundError - 404 Not Found
  • RailtownConflictError - 409 Conflict
  • RailtownServerError - 5xx Server errors

Read/search helpers return None or empty iterables on many errors (graceful degradation). delete_event() raises Railtown* exceptions on HTTP/API failures.

Requirements

  • uv
  • Python 3.10+
  • httpx >= 0.24.0
  • pydantic >= 1.10.0

Related package

For ingesting data into Railengine, install and use rail-engine-ingest.

License

MIT

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

rail_engine-0.2.1.tar.gz (19.2 kB view details)

Uploaded Source

Built Distribution

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

rail_engine-0.2.1-py3-none-any.whl (21.6 kB view details)

Uploaded Python 3

File details

Details for the file rail_engine-0.2.1.tar.gz.

File metadata

  • Download URL: rail_engine-0.2.1.tar.gz
  • Upload date:
  • Size: 19.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.22

File hashes

Hashes for rail_engine-0.2.1.tar.gz
Algorithm Hash digest
SHA256 b901dcf0b89247d190b2ef789dc3aaa4ee2c91f9bd7e288411e82dce26eff644
MD5 307bd4f50b2a0946626d790c29d11c96
BLAKE2b-256 959f562473fd3c63c41d7dc8a044d02c8a2b3ccbc3feb4a5106a077838330778

See more details on using hashes here.

File details

Details for the file rail_engine-0.2.1-py3-none-any.whl.

File metadata

File hashes

Hashes for rail_engine-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 bc7bf3eb708fe0a983b515f1d93d2c660a9cd1a08b4a84fe1789994bc2cff47b
MD5 4d90612b53c0675bdf30512f8bb32084
BLAKE2b-256 4cfbd8a701ee6657f7bb44c621a1791d656247e5e9ef622acee4b8b38a0d543a

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