Skip to main content

Parlor - a private parlor for AI conversation

Project description

PyPI Version Python 3.10+ Coverage License

Parlor Logo

Parlor

The secure digital speakeasy for AI conversation.

Self-hosted ChatGPT-style web UI and agentic CLI that connects to any OpenAI-compatible API.
Install with pip. Run locally. Own your data.

DocumentationQuick StartFeaturesSecurity

Parlor - Midnight Theme


Why Parlor?

Step inside. Parlor connects to any OpenAI-compatible endpoint --- your company's internal API, OpenAI, Azure, Ollama, LM Studio, or anything else that speaks the OpenAI protocol. Built to OWASP ASVS L1 standards because your conversations deserve real security, not security theater.

One command. No cloud. No telemetry. No compromise.


Quick Start

pip install parlor
parlor init         # Interactive setup wizard

Or create ~/.parlor/config.yaml manually:

ai:
  base_url: "https://your-ai-endpoint/v1"
  api_key: "your-api-key"
  model: "gpt-4"
parlor --test       # Verify connection
parlor              # Web UI at http://127.0.0.1:8080
parlor chat         # Terminal CLI
parlor --version    # Show version

Features

Web UI

Full-featured ChatGPT-style interface with conversations, projects, folders, tags, file attachments, MCP tool integration, prompt queuing, command palette, and four built-in themes.

Midnight Theme Dawn Theme

CLI Chat

An agentic terminal REPL with built-in tools (read/write/edit files, bash, glob, grep), MCP integration, skills system, and Rich markdown rendering. Type while the AI works --- messages queue automatically.

parlor chat                          # Interactive REPL
parlor chat "explain main.py"        # One-shot mode
parlor chat -c                       # Continue last conversation
parlor chat --model gpt-4o "hello"   # Override model

Shared Core

Both interfaces share the same agent loop, storage layer, and SQLite database. Conversations created in the CLI show up in the web UI, and vice versa.


Security

Layer Implementation
Auth Session tokens, HttpOnly cookies, HMAC-SHA256
CSRF Per-session double-submit tokens
Headers CSP, X-Frame-Options, HSTS, Referrer-Policy
Database Parameterized queries, column allowlists, path validation
Input DOMPurify, UUID validation, filename sanitization
Rate Limiting 120 req/min per IP
CLI Safety Destructive command confirmation, path blocking
MCP Safety SSRF protection, shell metacharacter rejection

Full details in SECURITY.md.


Documentation

For complete documentation including configuration, CLI commands, API reference, themes, MCP setup, skills, and development guides, visit parlor.readthedocs.io.


Development

git clone https://github.com/troylar/parlor.git
cd parlor
pip install -e ".[dev]"
pytest tests/ -v
Backend Python 3.10+, FastAPI, Uvicorn
Frontend Vanilla JS, marked.js, highlight.js, KaTeX
CLI Rich, prompt-toolkit, tiktoken
Database SQLite with FTS5, WAL journaling
AI OpenAI Python SDK (async streaming)
MCP Model Context Protocol SDK (stdio + SSE)

MIT License
Built for people who care about their conversations.
parlor.readthedocs.io

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

parlor-0.15.0.tar.gz (703.1 kB view details)

Uploaded Source

Built Distribution

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

parlor-0.15.0-py3-none-any.whl (746.0 kB view details)

Uploaded Python 3

File details

Details for the file parlor-0.15.0.tar.gz.

File metadata

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

File hashes

Hashes for parlor-0.15.0.tar.gz
Algorithm Hash digest
SHA256 bfdee232838b797edf39bebbc71297a8005e2ee6fbcca4ce0e6171f268faa3c1
MD5 34de9569a99a9d199089b8b98194d759
BLAKE2b-256 f4073b5c7f21c78596d70d214b8ffa39dc78cf42508d57d2d5f87717c9c1c1b3

See more details on using hashes here.

File details

Details for the file parlor-0.15.0-py3-none-any.whl.

File metadata

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

File hashes

Hashes for parlor-0.15.0-py3-none-any.whl
Algorithm Hash digest
SHA256 ae142806d0348ca9c503e5550e4708db0cbd9c711ec63450c03e6c93a4d76f67
MD5 d42b47d46ee5907aaffb7c0f97a43e8e
BLAKE2b-256 1dfc80ae2fa7f55881e0d6bb30cf7b3862875bcb39de0189442bc250d52a2b84

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