Skip to main content

SDK for generating rich multimedia content for verse-based texts

Project description

Sanatan SDK - Python SDK for Spiritual Verse Collections

Complete toolkit for generating rich multimedia content for spiritual text collections (Hanuman Chalisa, Sundar Kaand, etc.)

Features

  • 🔄 Complete Workflow: Fetch text, generate media, and update embeddings - all in one command
  • 📖 Text Sources: Read from local YAML files or fetch from authoritative online sources
  • 🎨 AI Images: Generate themed images with DALL-E 3
  • 🎵 Audio Pronunciation: Full and slow-speed audio with ElevenLabs
  • 🔍 Semantic Search: Vector embeddings for intelligent verse discovery
  • 📚 Multi-Collection: Organized support for multiple verse collections
  • 🎨 Theme System: Customizable visual styles (modern, traditional, kids-friendly, etc.)

Quick Start

# Install
pip install sanatan-sdk

# Set up API keys (in your project directory)
cp .env.example .env
# Edit .env and add your API keys

# List available collections
verse-generate --list-collections

# Complete workflow (default) - fetch text, generate media, update embeddings
verse-generate --collection hanuman-chalisa --verse 15

# Skip text fetching (when verse text already exists)
verse-generate --collection sundar-kaand --verse 5 --no-fetch-text

# Or generate specific components only
verse-generate --collection sundar-kaand --verse 3 --image
verse-generate --collection sankat-mochan-hanumanashtak --verse 5 --audio

By default, the complete workflow includes:

  • 🔍 Fetch traditional Devanagari text (from local YAML files or web sources)
  • 🎨 DALL-E 3 generated image (saved to images/{collection}/{theme}/)
  • 🎵 Full-speed pronunciation (saved to audio/{collection}/{verse}_full.mp3)
  • 🎵 Slow-speed pronunciation (saved to audio/{collection}/{verse}_slow.mp3)
  • 🔗 Update vector embeddings for semantic search

Text Sources (checked in order):

  1. Local YAML file: data/verses/{collection}.yaml (recommended)
  2. Web scraping from authoritative sources (fallback)

Opt-out flags (to skip specific steps):

  • --no-fetch-text - Skip fetching text (use when verse text already exists)
  • --no-update-embeddings - Skip updating embeddings

Installation

pip install sanatan-sdk

Commands

Configuration

Copy the example environment file and add your API keys:

cp .env.example .env
# Edit .env and add your API keys

See the Usage Guide for detailed information on project structure, workflows, batch processing, and cost optimization.

Documentation

Example Project

Hanuman GPT - Multi-collection project with Hanuman Chalisa, Sundar Kaand, and Sankat Mochan Hanumanashtak

Requirements

  • Python 3.8+
  • OpenAI API key (for text/images/embeddings)
  • ElevenLabs API key (for audio)

License

MIT License - See LICENSE file for details

Support

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

sanatan_sdk-0.7.1.tar.gz (38.4 kB view details)

Uploaded Source

Built Distribution

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

sanatan_sdk-0.7.1-py3-none-any.whl (50.1 kB view details)

Uploaded Python 3

File details

Details for the file sanatan_sdk-0.7.1.tar.gz.

File metadata

  • Download URL: sanatan_sdk-0.7.1.tar.gz
  • Upload date:
  • Size: 38.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.5

File hashes

Hashes for sanatan_sdk-0.7.1.tar.gz
Algorithm Hash digest
SHA256 42fe5a2cb8959ef45991404484dea89a385b2043eeb088aad3953989314ef9b0
MD5 a749e4a226fe003c2ce944b4fbb258ae
BLAKE2b-256 6f9feeeda2ec7a64ab6d06e8789f6c13b54f2e0d21ad70d21f418323297fe99a

See more details on using hashes here.

File details

Details for the file sanatan_sdk-0.7.1-py3-none-any.whl.

File metadata

  • Download URL: sanatan_sdk-0.7.1-py3-none-any.whl
  • Upload date:
  • Size: 50.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.5

File hashes

Hashes for sanatan_sdk-0.7.1-py3-none-any.whl
Algorithm Hash digest
SHA256 f1014a1cc2cf24c6f2a0f60297bfafde3d4439478a8487dc305fd09e1b976ded
MD5 4a62ff9b7639fd993b5eeec8dfa99401
BLAKE2b-256 f1c15b8872bf99f3a70e9e34e0e83c7fa4d5e184b29ff1c0de3d493782549b61

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