Skip to main content

An open-source offensive-security AI agent that lives in your terminal.

Project description

riftor

An open-source offensive-security AI agent that lives in your terminal. Find the rift. Open it. Cross through.

riftor is a Python TUI pentest assistant: a full-screen Textual interface backed by litellm, organised around the RIFT methodology — Recon → Intrusion → Foothold → Takeover.

It's cloud-first (Anthropic, OpenAI, OpenRouter, …) for the strongest agent behaviour, with local Ollama supported as an option.

Status: early (Phase 4a). Working agent: streaming chat, tool use with permission prompts + audit log, scope enforcement, RIFT stage tracking, a per-engagement findings store, and reports (markdown + HTML with CVSS). See todo.md for the roadmap.

Install

pip install riftor          # or: uv tool install riftor / pipx install riftor

Requires Python 3.11+ and a model — set one of ANTHROPIC_API_KEY, OPENAI_API_KEY, OPENROUTER_API_KEY (or run a local Ollama server).

export ANTHROPIC_API_KEY=sk-ant-...   # or OPENAI_API_KEY, etc.
riftor                                 # launch the TUI
riftor --config                        # show the config file path
riftor --version

On first launch riftor writes a config file and picks a default model from your environment keys (cloud-first); if no key is set but an Ollama server is running, it falls back to that.

From source

git clone https://github.com/Estudely/riftor && cd riftor
uv sync && uv run riftor

Configure

~/.config/riftor/config.toml:

[riftor]
model = "anthropic/claude-sonnet-4-6"  # any litellm model id
# api_key = "sk-..."                   # prefer the provider's env var
temperature = 0.3
max_tokens = 2048
theme = "rift"
lore = true

# Local option (Ollama):
# model = "ollama_chat/llama3.1"
# api_base = "http://localhost:11434"

Workflow

1. Set scope        /scope add 10.0.0.0/24 example.com
2. Task the agent   "enumerate the web host and look for low-hanging fruit"
                    → it runs recon tools via bash (you approve), records
                      services/findings, and advances the R·I·F·T stage
3. Review           /findings
4. Report           /report            → .riftor/reports/report-*.md and .html

Out-of-scope targets are blocked (with an explicit per-call override). State lives in .riftor/ per working directory; sessions auto-save and resume.

Commands

Command Action
/help show commands
/clear clear the conversation (Ctrl+L)
/model [name] show or switch the model
/stage [R|I|F|T] show or set the RIFT stage
/scope [add|out|rm <t>|clear|on|off] manage in/out-of-scope targets
/findings list recorded findings
/report [md|html|both] write a pentest report to .riftor/reports/
/sessions · /resume <id> · /new manage saved sessions
/tools list available tools
/lore toggle the rift persona
/exit quit (Ctrl+C)

Esc cancels a running response. Dangerous tools (bash/write/edit) prompt for approval; every tool call is written to an audit log.

Use responsibly

riftor is for authorized security testing only. You are responsible for having explicit, written permission for any system you assess.

License

GPL-3.0.

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

riftor-0.0.2.tar.gz (50.5 kB view details)

Uploaded Source

Built Distribution

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

riftor-0.0.2-py3-none-any.whl (52.9 kB view details)

Uploaded Python 3

File details

Details for the file riftor-0.0.2.tar.gz.

File metadata

  • Download URL: riftor-0.0.2.tar.gz
  • Upload date:
  • Size: 50.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for riftor-0.0.2.tar.gz
Algorithm Hash digest
SHA256 6034e1a3655bb4bc81e835287e9865686aa984736127d614bc33a38b4cbeeafb
MD5 a8e14d17db564dfcda3fa31cf3409901
BLAKE2b-256 2dcd7c9dff096a3c6ed8c65f085952daedd5d86bd77630a71ae48944a7ed40fa

See more details on using hashes here.

Provenance

The following attestation bundles were made for riftor-0.0.2.tar.gz:

Publisher: release.yml on Estudely/riftor

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file riftor-0.0.2-py3-none-any.whl.

File metadata

  • Download URL: riftor-0.0.2-py3-none-any.whl
  • Upload date:
  • Size: 52.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for riftor-0.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 3480df2210a55e062eaf2f9ef379f56f5c2e96ca4b575bcd6ff69cd673e1e63b
MD5 def1f202c3bba2d61f414bb39f5e46ba
BLAKE2b-256 1e1530af4d646145983c7baf55c69b31621c31c7260d9019a71cc279512ea639

See more details on using hashes here.

Provenance

The following attestation bundles were made for riftor-0.0.2-py3-none-any.whl:

Publisher: release.yml on Estudely/riftor

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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