Skip to content

Latest commit

 

History

History
157 lines (102 loc) · 5.82 KB

README.md

File metadata and controls

157 lines (102 loc) · 5.82 KB

Bash AI

Bash AI (bai) is an advanced Bash shell script functioning as an AI-powered terminal assistant, inspired by Your AI.
Leveraging the newest OpenAI's capabilities, it allows you to ask questions and perform terminal-based tasks using natural language. It provides answers and command suggestions based on your input and allows you to execute or edit the suggested commands if desired.

Bash AI is not only powerful out of the box, but also expandable!
With its plugin architecture, you can easily add your own tools, thereby empowering Bash AI to accomplish even more, and extending its functionality beyond its original capabilities.

Features

Bash AI offers the following features:

  • 100% Shell Script
    No need to install anything. Just run it!

  • Plugins!
    Extend Bash AI's functionality by adding plugins known as "tools".

  • Natural Language Interface
    Communicate with the terminal using everyday language.

  • Question Answering
    Get answers to all your terminal questions by ending your request with a question mark.

  • Command Suggestions
    Receive intelligent command suggestions based on your input.

  • Command Information
    Get detailed information about the suggested commands.

  • Distribution Awareness
    Get answers and commands that are compatible with, and related to, your specific Linux distribution.

  • Command Execution
    Choose to execute the suggested commands directly from Bash AI.

  • Command Editing
    Edit the suggested commands before execution.

  • Error Examination
    Examine the error messages generated by the suggested commands and attempt to fix them.

  • Persistent Memory
    Remembers your previous requests and uses them to improve future suggestions.

  • Directory Awareness
    Automatically detects and uses the current directory when executing commands.

  • Locale Awareness
    Automatically detects your system's locale and uses it to provide localized responses.

  • Vim Awareness
    Automatically detects if you are using Vim and provides Vim-specific suggestions.

Setup

  1. To setup Bash AI quickly, you can run the following command:
curl -sS https://raw.githubusercontent.com/hezkore/bash-ai/main/install.sh | bash

Warning

Never run unknown scripts without reviewing them for safety. Read the install script here.

  1. Run bai to start Bash AI.
Manual Setup
  1. Clone or download the repository:

    git clone https://github.com/hezkore/bash-ai.git
  2. Make the script executable:

    chmod +x bai.sh
  3. Execute Bash AI:

    ./bai.sh
  • (Optional) For convenience, you can create a shortcut to the bai.sh script. There are two ways to do this:

    • Create a symbolic link in /usr/local/bin. This will allow you to run the script from anywhere, without having to type the full path. Replace path/to/bai.sh with the actual path to the bai.sh script:

       ln -s path/to/bai.sh /usr/local/bin/bai
    • Alternatively, you can create an alias for the bai.sh script in your .bashrc file. This will also allow you to execute the script using the bai command, reducing the need for typing the full path to the script each time. Replace path/to/bai.sh with the actual path to the bai.sh script:

       alias bai='path/to/bai.sh'
      

Configuration

On the first run, a configuration file named bai.cfg will be created in your ~/.config directory.

Important

Always remove bai.cfg before updating Bash AI to avoid compatibility issues.

You must provide a OpenAI API key in the key= field of this file. The OpenAI API key can be obtained from your OpenAI account.

Caution

Keeping the key in a plain text file is dangerous, and it is your responsibility to keep it secure.

You can also change the GPT model, temperature and many other things in this file.

Usage

Bash AI operates in two modes: Interactive Mode and Command Mode.

To enter Interactive Mode, you simply run bai without any request. This allows you to continuously interact with Bash AI without needing to re-run the command.

In Command Mode, you run bai followed by your request, like so: bai your request here

Example usage:

bai create a new directory with a name of your choice, then create a text file inside it

You can also ask questions by ending your request with a question mark:

bai what is the current time?

Plugins and tools

Plugins are OpenAI tools that expand Bash AI's functionality, but they are not included in the default Bash AI setup.
All tools should be placed in your ~/.bai_tools directory.
You can see which tools are currently installed by running bai, and Bash AI will list them for you.

Tools are nothing more than a shell script with a init and execute function.
You can find examples and available tools in the tools folder.
Feel free to move them to your ~/.bai_tools directory to enable them!

Known Issues

  • In Command Mode, avoid using single quotes in your requests.
    For instance, the command bai what's the current time? will not work. However, both bai "what's the current time?" and bai what is the current time? will execute successfully.
    Please note that this issue is specific to the terminal, and does not occur in Interactive Mode.

Prerequisites