PrivacyForms AI - LLM integration module
Project description
PrivacyForms AI
A Python CLI tool for interacting with Large Language Models (LLMs) via Simon Willison's llm library. Supports multiple providers including OpenAI, Anthropic, Moonshot, and Ollama.
Features
- 🔧 Simple CLI - Easy-to-use command-line interface with colored output
- 💬 Interactive Chat - Multi-turn conversations with context/memory
- 🚀 Multiple Providers - Works with OpenAI, Anthropic, Moonshot, Ollama, and more
- 🧪 Well Tested - Comprehensive test coverage
- ⚡ Fast - Built with modern Python tooling
- 🔍 Observable - Optional verbose logging (
-v/-vv) to inspect prompt payloads
Installation
Using uv (recommended)
# Clone the repository
git clone https://github.com/zopyx/privacyforms.ai.git
cd privacyforms.ai
# Install with uv
uv sync
# Or install in development mode
uv sync --all-extras --dev
Using pip
pip install privacyforms-ai
Configuration
Set your API keys as environment variables:
# OpenAI
export OPENAI_API_KEY="your-key"
# Anthropic
export ANTHROPIC_API_KEY="your-key"
# Moonshot
export MOONSHOT_API_KEY="your-key"
For Ollama, make sure the Ollama server is running locally.
Usage
Global Options
# Show version
privacyforms-ai --version
# Show help
privacyforms-ai --help
# Enable verbose output (shows prompt logs on stderr)
privacyforms-ai -v models
# Enable debug output
privacyforms-ai -vv prompt gpt-4o-mini "Hello!"
List Available Models
privacyforms-ai models
# JSON output
privacyforms-ai models --json-output
Send a Single Prompt
# Basic prompt
privacyforms-ai prompt gpt-4o-mini "What is the capital of France?"
# With system prompt
privacyforms-ai prompt gpt-4o-mini "Explain recursion" --system "You are a computer science tutor"
Interactive Chat
Start an interactive chat session with conversation history:
# Basic chat
privacyforms-ai chat moonshot/kimi-k2.5
# With system prompt
privacyforms-ai chat gpt-4o-mini -s "You are a helpful coding assistant"
Chat Commands:
/quit,/exit,/q- End the chat session/clear- Clear conversation history/model- Show current model
Example session:
Starting chat with model: moonshot/kimi-k2.5
Type /quit, /exit, or /q to end the session. Type /clear to reset history.
--------------------------------------------------
You: Hello!
AI: Hello! How can I help you today?
You: What can you do?
AI: I can help with a variety of tasks including...
You: /quit
Goodbye!
Development
Setup
# Clone and setup
git clone https://github.com/zopyx/privacyforms.ai.git
cd privacyforms.ai
uv sync --all-extras --dev
source .venv/bin/activate
Running Tests
# Run all tests
make test
# With coverage
make test-cov
# Verbose output
uv run pytest -v
Code Quality
# Format code
make format
# Check formatting
make format-check
# Lint
make lint
# Auto-fix linting issues
make fix
# Type check
make type-check
# Run the full local gate
make check
Build Package
# Build release artifacts into dist/
make dist
Upload Package
# Upload to PyPI using twine and your ~/.pypirc or TWINE_* credentials
make upload
# Upload to another configured repository, e.g. TestPyPI
make upload TWINE_REPOSITORY=testpypi
Create a Release
# 1. Update the version in pyproject.toml, src/privacyforms_ai/_version.py, README, and tests
# 2. Refresh the lockfile if needed
uv sync --all-extras --dev
# 3. Verify and build
make check
make dist
# 4. Upload
make upload
# 5. Commit and tag
git add pyproject.toml src/privacyforms_ai/_version.py src/privacyforms_ai/__init__.py tests/ uv.lock CHANGELOG.md .gitattributes LICENSE
git commit -m "Release X.Y.Z"
git tag vX.Y.Z
git push origin HEAD
git push origin vX.Y.Z
API Design
See API_DESIGN.md for the REST API and WebSocket design specification for multi-chat server functionality.
Project Structure
privacyforms.ai/
├── src/privacyforms_ai/
│ ├── __init__.py
│ ├── _version.py # Package version
│ ├── ai.py # AI class for LLM interactions
│ └── cli.py # Click CLI commands
├── tests/
│ ├── conftest.py # Pytest fixtures
│ ├── test_ai.py # AI class tests
│ └── test_cli.py # CLI tests
├── pyproject.toml # Project configuration
├── uv.lock # Locked dependencies
├── CHANGELOG.md # Release notes
├── LICENSE # MIT license
├── .gitattributes # Line-ending configuration
└── README.md
CI/CD
GitHub Actions workflow runs on:
- Python 3.12, 3.13, 3.14, 3.14t (free-threaded)
- Ubuntu Linux
Jobs:
- test - Run pytest with coverage
- lint - ruff (formatting, linting) and ty (type checking)
- build - Build package artifacts and validate with twine
License
MIT License - see LICENSE file for details.
Contributing
Contributions are welcome! Please:
- Fork the repository
- Create a feature branch
- Make your changes with tests
- Ensure all checks pass (
make check) - Submit a pull request
Acknowledgments
- Built on top of Simon Willison's llm library
- Uses Astral's uv for fast Python package management
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file privacyforms_ai-0.1.4.tar.gz.
File metadata
- Download URL: privacyforms_ai-0.1.4.tar.gz
- Upload date:
- Size: 13.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a7e898d1e7c4f4cdf367bda86d9d922e594b915226c54a0807afec1a99049e01
|
|
| MD5 |
06e1b353c658556c4c506059123317a5
|
|
| BLAKE2b-256 |
e6efea50450dec0f604f3e280cced0dfca7bc47b68514349c1435fc59e20cd39
|
File details
Details for the file privacyforms_ai-0.1.4-py3-none-any.whl.
File metadata
- Download URL: privacyforms_ai-0.1.4-py3-none-any.whl
- Upload date:
- Size: 10.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4f33a12f8aaa001f1efd1ff4d018651b07ecabfdfb0ed8db6f132f6ae075c0ff
|
|
| MD5 |
5c95e325b260fc979654ab64fecb6faa
|
|
| BLAKE2b-256 |
e0bf25189696b7b5f8e1557d4890b01855dfe2953621f549685fc7bc615263cf
|