LLM-enabled companion utility for your terminal.
Project description
cli-FSD
Natural language interface for your command line.
A lightweight and portable autopilot utility for CLI tasks that takes natural language as input and uses the LLM of your choice to take the appropriate actions by generating and parsing shell scripts. Find answers to questions and let AI execute commands with your permission in Safe Mode or enable Autopilot to automate tasks or script modules and microservices on the fly.
Note: Giving LLMs shell-level access to your computer is dangerous and should only be done in sandbox or otherwise expendable environments.
I made cli-FSD for experimenting and problem solving in low stakes development environments. If you don't have access to a machine like that you can try it below:
Getting Started
Prerequisites
- Python 3.10 or later (may work with earlier versions)
- pip 24.0 or later
- An OpenAI API key or Anthropic API key or Ollama running in the same environment as cli-FSD
Installation
- Pre-requisites:
-
Upgrade pip
python3 -m pip install --upgrade pip
One line install using pip:
pip install cli-FSD
(if you are testing the package, follow steps to setup and activate a virtual environment before running pip install.).
Manual Installation
-
Clone the repo:
git clone https://github.com/WazaCraft/cli-FSD cd cli-FSD -
Set up a Python virtual environment:
python -m venv FSD -
Activate the virtual environment:
-
On Windows:
.\FSD\Scripts\activate
-
On Unix or MacOS:
source FSD/bin/activate
-
-
Install the cli-FSD Python package:
pip install .
Usage
-
To start in safe-mode in your Terminal:
@ what time is it -s
-
To run in companion mode and process a specific task using autopilot type '@' from anywhere in your terminal followed by a command:
@ what time is it
-
For additional options, you can enter
CMDmode by typingCMDat any prompt. -
To browse directories and view file contents, type
browseat the prompt and follow on-screen instructions.
Low-stakes Demos
Letting an LLM execute code on your computer is objectively dangerous. I've used cli-FSD on every computer I own but think it's important for users to understand the risk associated with this concept.
If you don't want to run it locally:
Project Progress
v2.0.9
- - Added file interaction tool that allows the agent to modify files in the active directory and all subdirectories with user permission
- - Added
fileintcommand in CMD mode for interactive file operations (list, read, write, modify, delete, search, create directories) - - Added support for Ollama (use -o to run cli-FSD using any supported local LLM model)
- - support for script custom gpt-4-turbo assistant OpenAI's Assistants API to revie v0.87
- - finish OpenAI Assistants integration (done but but needs to be made accessible in main.py)
- - integrate other LLM providers with http request APIs similar to /v1/completions (pass -c with your query to use Anthropic API's Claude 3 Opus)
- - improved error handling
v0.75
- - overhauled and refactored error resolution function to address a bug that sometimes prevented the resolution from executing
- - fixed niche text handling errors and submodule implementation for upcoming OpenAI AssistantsAPI integration v0.52
- - implement LLM error handling and resolution flows
- - refactor flags for SafeMode, Autopilot
To Do
- - refactor and expand CMD module
- for v0.8 - route requests to a custom gpt-4-turbo assistant with code interpreter access using OpenAI's Assistants API
- - build advanced menu and config options
Considering
- - passive error detection and resolution for CLI interactions
- - voice control
- - voice notation
- - automation schedules and background states
Version Management
The project uses a central version management system:
- The authoritative version is stored in
cli_FSD/version.py - To update the version, use the provided script:
python scripts/bump_version.py [major|minor|patch]
- This will automatically update the version displayed in the UI and used in setup.py
Contributing
Contributions to this project are welcome. Please fork the repository, make your changes, and submit a pull request for review.
Contributions to the main branch should aim to adhere to the project principles:
- portable (I'm avoiding unnecessary dependencies whenever possible)
- utility focused
License
This project is licensed under the GNU GPL - see the LICENSE.md file for details.
Acknowledgments
- OpenAI for providing the API used for generating chat responses.
- Flask and Flask-CORS for the web server functionality.
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 cli_fsd-2.2.0.tar.gz.
File metadata
- Download URL: cli_fsd-2.2.0.tar.gz
- Upload date:
- Size: 161.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
592f60687997d98bc110c83ad720f302b4dd10c88f5bb28b1fbcf4e75d308ad5
|
|
| MD5 |
6971c2d7bd7225761346d5690b95fc95
|
|
| BLAKE2b-256 |
076b749a8ae2fc99c739da936ab265d601e3b3e3faba7ff0ab06e9dc46f6d148
|
File details
Details for the file cli_fsd-2.2.0-py3-none-any.whl.
File metadata
- Download URL: cli_fsd-2.2.0-py3-none-any.whl
- Upload date:
- Size: 177.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f62a8663fd9d83d7c5c55f501fc85515e6bd18a29683515e8aa434de4d86cde2
|
|
| MD5 |
6ae55b7717b9509311ee47f44415aa94
|
|
| BLAKE2b-256 |
fb25c067b627500952c985f139d0798eda8510882422463928fc4ec9426d2c8c
|