Hash - Intelligent CLI system with dual-mode functionality (LLM chat and command proxy)
Project description
Hash
Your terminal, but with a brain. (Works with your current zsh, bash, fish, or PowerShell.)
Talk to your terminal in plain English. Get instant help with commands, examples, and safe execution suggestions without leaving your shell. You never have to context-switch to a browser again.
Quick Start • Why • Features • Examples • Docs
The Workflow
Stop doing this:
- Open or switch to browser
- Search "how to kill process on port 8888"
- Sift through StackOverflow answers or blog posts from 2014
- Copy-paste a command you only half-understand
- A few days later, do the same all over again
Start doing this:
$ hi kill whatever is running on port 8888
Suggested command
Description: Finds process IDs listening on port 8888 and terminates them.
Command: lsof -ti :8888 | xargs kill -9
Choose [y] execute, [n] cancel, [x] explain, [e] edit [y/n/x/e] (n): x
# Hash explains each part, then asks again before running.
Choose [y] execute, [n] cancel, [x] explain, [e] edit [y/n/x/e] (n): y
# process running on 8888 is killed
Quick Start
Installation
Install Hash CLI with uv (recommended) or pip/pipx:
uv tool install hashcli
pipx install hashcli
#or
pip install hashcli
Setup
Run the guided setup to configure your provider, choose a model, optionally store an API key or use an environment variable, enable streaming, validate the provider, and install shell integration for the # prefix in supported shells:
hi --config
Shell integration setup supports zsh, bash, fish, and PowerShell. If you run an interactive query before configuring Hash CLI and no provider API key is present in your environment, Hash CLI starts this setup flow automatically.
Start Using Hash
After shell integration, you can use #. You can always use hi or hashcli.
hi show disk usage in human readable format
# what git branches exist and which one am I on
# find all python files modified in the last week
hi explain xargs
Why Hash CLI?
⚡ Work Faster
Complex pipes, regex, and obscure flags are hard to memorize. Describe what you want—from "how to rebase my last 3 commits into one" to "find and delete all .log files larger than 50MB"—and get the exact syntax instantly. Hash CLI integrates seamlessly into your existing workflow with optional # prefix support.
♾️ Stay in the Flow
Every time you leave the terminal to Google a command, you lose focus. Hash CLI keeps your hands on the home row and your project in sight. It’s not just a tool; it’s a productivity multiplier. Ask command questions, get examples, and execute commands without leaving your terminal.
🛡️ Stay Safe
Built-in guardrails protect your system. Commands are checked against allow/deny lists, dangerous patterns are blocked automatically, and confirmation behavior can be enforced by config and query type.
- Explain: It breaks down what the command actually does.
- Review: You see the command before a single character is executed.
- Control: Choose to run it as-is, edit it for your specific needs, or cancel.
🧠 Choose Your Brain
Use OpenAI or compatible, Anthropic (Claude), or Google (Gemini) models. Switch providers and models on the fly. Your choice, your control.
🧩 Extend Infinitely
The plugin system lets you add custom slash commands in minutes. Install community plugins or write your own. Make Hash CLI work exactly how you want.
Key Capabilities:
- Natural Language Translation: From "find large files" to "undo my last git commit," it speaks your language.
- Contextual Explanations: Understand why a command works before you run it.
- Safety Interlocks: Destructive commands and how-to execution suggestions are staged for review, with config controls for stricter confirmation.
- No Tab-Hopping: Keep your hands on the home row and your focus on the code.
- Full conversation history is preserved. Reference past sessions, review what worked, and build on previous interactions.
Real-World Examples
Command Discovery
# explain tar
# what command finds files larger than 100MB
# show me examples for rsync
Hash CLI explains the command, grounds the answer with concise examples, and suggests the right invocation.
System Administration
# show me which processes are using the most memory
# clean up docker images I'm not using
# backup my Documents folder to external drive
Perfect for sysadmins who want intelligent assistance without memorizing every flag.
Development Workflow
# show last 10 commits with author names
# what command shows my current git branch
# find all python files modified in the last week
Streamline your daily development tasks with natural language.
Learning & Discovery
# how do I use awk to extract the third column
# explain grep -E
# show me examples of find with -mtime
Your terminal becomes a patient teacher, explaining concepts and showing examples.
Features
Natural Language Interface
Ask command questions and give shell-oriented instructions in plain English. Hash CLI translates your intent into precise commands and actions.
Multi-Provider AI Support
- OpenAI (including compatible OpenAI-style endpoints)
- Anthropic (Claude models)
- Google (Gemini models)
Switch models and providers instantly with CLI flags or config files.
Intelligent Tool Calling
Hash CLI can:
- Execute shell commands with timeout protection and security checks
- Explain commands and suggest safe invocations
- Ground command answers with integrated
tldrexamples when needed
Tool calls are shown transparently, and confirmation behavior follows your config and query type.
Extensible Plugin System
Create custom slash commands for your specific workflow:
# Install a plugin
hi --add-cmd plugins/model.py
# Non-interactive install
hi --add-cmd plugins/model.py --yes
# See installed plugins
hi --list-plugins
# Use it
hi /model
hi /model list
Install previews show the command name, class name, destination path, and first help line before copying. Plugins are validated in a subprocess before installation. Build plugins in minutes; check plugins/ for examples.
Smart Configuration
Hash CLI adapts to your environment:
- CLI flags (highest priority)
- Environment variables (
HASHCLI_*) - User config (
~/.hashcli/config.toml) - System config (
/etc/hashcli/config.toml) - Sensible defaults
Override anything, anytime, from anywhere.
Use command mode to inspect or edit config without opening the TOML file:
hi config get streaming
hi config set streaming true
hi config unset streaming
Conversation History
Every interaction is saved:
hi /history # List recent sessions
hi /history show 42574d4e # View session by full ID or unique prefix
hi /history search rsync # Search saved messages
hi /history clear # Clear all saved conversations
Within an interactive shell, hashcli and hi now reuse one conversation per shell session.
Use --new-session to start a fresh conversation for a single invocation.
Use --session ID_OR_PREFIX to resume a specific previous session.
If HASHCLI_SESSION_ID is set, that value is used instead of auto shell-session scoping.
Review past solutions, replay successful commands, and learn from history.
Safety & Security
Hash CLI is designed with security as a first-class feature:
Confirmation Behavior
how to ...queries force confirmation for tool calls and suggested command execution- Other action-oriented queries follow
command_confirmationfor suggested command execution andtool_confirmationfor tool calls - Suggested command confirmation offers execute, cancel, explain, and edit choices
- Tool calls and command execution are shown before they run when confirmation is required
Command Filtering
- Blocked commands list prevents dangerous operations
- Optional allowed commands whitelist for strict environments
- Shell operators can be restricted via config
Transparent Execution
- Commands and tool arguments are shown before execution when confirmation is required
- Command output is returned directly to the terminal
- No hidden background processes
Configurable Paranoia
- Configure confirmation behavior in
~/.hashcli/config.toml - Customize allow/deny lists per environment
- Set timeouts to prevent runaway processes
Advanced Configuration
Provider & Model Selection
# Use specific model
hi --model gpt-5.2 "explain quantum computing"
# Switch provider
hi --provider anthropic "debug my code"
# Show current config
hi --show-config
# Persist config changes
hi config set llm_provider anthropic
hi config set anthropic_model claude-sonnet-4-6
Quiet Mode
# Minimal output for scripting
hi --quiet "list all .py files"
Enable streaming with config or env vars, for example HASHCLI_STREAMING=true hi "write a long explanation".
Environment Variables
Environment variables map directly to top-level config keys with a HASHCLI_ prefix. API keys also support the standard provider env vars.
# Set default provider
export HASHCLI_LLM_PROVIDER=anthropic
export HASHCLI_ANTHROPIC_MODEL=claude-sonnet-4-6
# API keys
export ANTHROPIC_API_KEY=your-key-here
# or:
export HASHCLI_ANTHROPIC_API_KEY=your-key-here
# Configure behavior
export HASHCLI_COMMAND_CONFIRMATION=true
export HASHCLI_TOOL_CONFIRMATION=true
export HASHCLI_SHOW_DEBUG=true
export HASHCLI_STREAMING=true
Configuration File
Create ~/.hashcli/config.toml:
llm_provider = "anthropic"
anthropic_model = "claude-sonnet-4-6"
anthropic_api_key = "your-key-here"
streaming = true
command_confirmation = true
tool_confirmation = true
show_debug = false
blocked_commands = ["rm -rf /", "dd if=", "mkfs"]
allowed_commands = [] # empty = allow all (except blocked)
Plugin Development
Create Your Own Plugin
# my_plugin.py
from typing import List
from hashcli.command_proxy import Command
from hashcli.config import HashConfig
class MyPluginCommand(Command):
"""Custom functionality for my workflow"""
def execute(self, args: List[str], config: HashConfig) -> str:
# Your plugin logic here
return f"Plugin executed with args: {args}"
def get_help(self) -> str:
return "Usage: /my-plugin [args]\nDoes something useful."
def validate_args(self, args: List[str]) -> bool:
return True
Install & Use
# Install your plugin
hi --add-cmd my_plugin.py
# Use it immediately
hi /my-plugin arg1 arg2
# List or remove installed plugins
hi --list-plugins
hi --remove-cmd my_plugin
Plugins are stored in ~/.hashcli/plugins/ and loaded automatically on startup.
Use --yes with --add-cmd or --remove-cmd for non-interactive scripts.
CLI Reference
# Interactive mode
hi "your question here"
# Configuration
hi --config # Guided setup wizard + shell integration
hi --config-file F # Use a specific config file
hi --show-config # Display current settings
hi config get KEY # Show an effective config value
hi config set KEY VALUE
hi config unset KEY
# Plugin management
hi --add-cmd <file> # Preview, validate, and install plugin
hi --add-cmd <file> --yes
hi --list-plugins
hi --remove-cmd NAME
# Built-in commands
hi /help # Show available commands
hi /history # Manage conversation history
hi /history search QUERY
# Flags
--model MODEL # Override model
--provider PROVIDER # Override provider (openai/anthropic/google)
--new-session # Start a fresh conversation for this run
--session ID_OR_PREFIX # Resume a previous conversation
--debug, -d # Enable debug output
--quiet, -q # Minimal output
Contributing
Hash CLI is open source and welcomes contributions:
- Report bugs and request features via GitHub Issues
- Submit pull requests for bug fixes and enhancements
- Share your plugins with the community
- Improve documentation and examples
License
Hash CLI is released under the MIT License. See LICENSE file for details.
Project details
Release history Release notifications | RSS feed
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 hashcli-0.5.4.tar.gz.
File metadata
- Download URL: hashcli-0.5.4.tar.gz
- Upload date:
- Size: 105.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.3.4 CPython/3.12.13 Linux/5.15.0-164-generic
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a7f5d977fb932cf8e5b54309bb3185e6fc03d8e58b50cad8eacebbe2f7bc56d0
|
|
| MD5 |
7fd346ddc2c9c1ca6ff76d5604566f43
|
|
| BLAKE2b-256 |
ca7e86f9400410795479277d791655531eb172ebbcd5a2c96d333d212b2f1d99
|
File details
Details for the file hashcli-0.5.4-py3-none-any.whl.
File metadata
- Download URL: hashcli-0.5.4-py3-none-any.whl
- Upload date:
- Size: 99.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.3.4 CPython/3.12.13 Linux/5.15.0-164-generic
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2192721a892b4b3a197d9b69cd567badd1fd90e0a90434a1b1509cccba3b38be
|
|
| MD5 |
e13c661c93518de0d3a783431c199bb1
|
|
| BLAKE2b-256 |
17ed78246864d29d79f58e0b8a7dad707df023497a7185c6f33c3a9aa86025dc
|