Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/bjarneo/tai

tAI is an AI terminal assistant CLI that helps you with Linux and macOS commands.
https://github.com/bjarneo/tai

ai ask assistant chatgpt cli gpt-4o gpt4o helper terminal

Last synced: about 17 hours ago
JSON representation

tAI is an AI terminal assistant CLI that helps you with Linux and macOS commands.

Awesome Lists containing this project

README

        

tAI, a terminal AI assistant


tAI is a CLI that helps you with Linux and macOS terminal commands. Just ask it a question, and it will use AI to suggest a command and explain what it does. If you like the suggestion, the script can automatically run the command for you in your terminal.


![Demo](example.png)

## BREAKING

Changing the name from `lfg` to `tai`. The package name is changed from `lfg-llama` to `terminal-ai-assistant`.

## Why & What?

- Github Copilot CLI syntax feels clunky to me
- Faster than using Gemini, ChatGPT or similar in a browser
- Simpler to find answers without checking man pages
- NEW: Switching to the free GPT-4o model
- NEW: Now you can run commands right from this command-line interface
- NEW: New package name `terminal-ai-assistant`

However, never trust the output entirely.

## Installation

```bash
# install pipx
brew install pipx

# add pipx binaries to path
pipx ensurepath

# restart your terminal
# install TAI
pipx install terminal-ai-assistant
```

## Usage

This executable is using OpenAI, that means you need and [API token](https://platform.openai.com/api-keys).

[GPT-4o](https://platform.openai.com/docs/models/gpt-4o) is free to use.

Add the token to your .bashrc/.zshrc and reload your terminal.

```
export OPENAI_API_KEY={replace_me}
```

You can use either of these commands

```bash
$ tai
```

Now you can use the executable

```bash
$ tai kill port 3000

fuser -k 3000/tcp

Explanation:
The `fuser` command identifies processes using files or sockets. The `-k` option is used to kill th
ose processes. Here, `3000/tcp` specifies the TCP port number 3000. This command effectively kills
any process currently using port 3000.

> Execute the command? (N/y):
```

Change the LLM

```bash
$ tai get pods from all namespaces

kubectl get pods --all-namespaces

Explanation:
The `kubectl get pods --all-namespaces` command lists all the pods across all namespaces in a Kuber
netes cluster. The `--all-namespaces` flag is used to fetch the pods from every namespace instead of the default namespace.

> Execute the command? (N/y):
```

### Development

```bash
pip install --user pipenv
pipenv --python 3.11
pipenv install

pipenv run tai kill port 3000
```

### TODO

- Fix the setup and pyproject file, including github workflow for releasing the package