CLAI - AI Assistant for CLI Commands
CLAI is an AI assistant for command line commands. It is designed to help users to find commands more efficiently.
How often do you struggle to remember how to execute a specific command? Or what the right flags and arguments are?
Just write in natural language what you want to do, and CLAI will try to find the right command.
It takes into account your current shell and OS to provide the most relevant commands. However, you can also specify a different shell and OS
to target a different environment.
Examples
./clai set up a ssh tunnel to be able to connect to MySQL on my remote server
Set up an SSH tunnel to remotely connect to a MySQL server on port 3306, forwarded to localhost:3307
$ ssh -L 3307:localhost:3306 username@remote_server -N
./clai -os=Windows -shell=powershell rename all files with the extension .yml to .yaml in current directory
Rename all files with .yml extension to .yaml in the current directory.
$ Get-ChildItem *.yml | Rename-Item -NewName {$_.BaseName+'.yaml'}
OpenAI API
CLAI uses the OpenAI API to generate the commands. Per default, it uses Groq with the "llama3-70b-8192" model.
You need to provide a valid token to use the API (either per config file, see below or ENV CLAI_TOKEN).
To use OpenAI, provide an empty endpoint or use https://api.openai.com/v1 and a valid model.
You can use any OpenAI compatible API.
Config
CLAI can be configured using a YAML config file, environment variables, or command line arguments.
Values provided by config file are overwritten by environment variables and command line arguments.
The config file needs to be named .clai.yaml
and can be placed in the user's home directory or in the current working directory.
The following values can be configured:
endpoint: https://api.openai.com/v1
model: gpt-4-turbo
token: <YOUR_API_KEY>
shell: bash
os: Linux
All values can also be set using environment variables. The following environment variables are available:
CLAI_ENDPOINT
CLAI_MODEL
CLAI_TOKEN
CLAI_SHELL
CLAI_OS
At least a token is required.