clai

command module
v0.1.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Apr 28, 2024 License: MIT Imports: 9 Imported by: 0

README

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.

Documentation

The Go Gopher

There is no documentation for this package.

Directories

Path Synopsis

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL