mirror of
https://github.com/Direct-Dev-Ru/go-lcg.git
synced 2025-11-15 17:20:00 +00:00
180 lines
6.0 KiB
Markdown
180 lines
6.0 KiB
Markdown
# Linux Command GPT (lcg)
|
||
|
||
This repo is forked from <https://github.com/asrul10/linux-command-gpt.git>
|
||
|
||
Generate Linux commands from natural language. Supports Ollama and Proxy backends, system prompts, different explanation levels (v/vv/vvv), and JSON history.
|
||
|
||
## Installation
|
||
|
||
Build from source:
|
||
|
||
```bash
|
||
git clone --depth 1 https://github.com/Direct-Dev-Ru/linux-command-gpt.git ~/.linux-command-gpt
|
||
cd ~/.linux-command-gpt
|
||
go build -o lcg
|
||
|
||
# Add to your PATH
|
||
ln -s ~/.linux-command-gpt/lcg ~/.local/bin
|
||
```
|
||
|
||
## Quick start
|
||
|
||
```bash
|
||
lcg "I want to extract linux-command-gpt.tar.gz file"
|
||
```
|
||
|
||
After generation you will see a CAPS warning that the answer is from AI and must be verified, the command, and the action menu:
|
||
|
||
```text
|
||
ACTIONS: (c)opy, (s)ave, (r)egenerate, (e)xecute, (v|vv|vvv)explain, (n)othing
|
||
```
|
||
|
||
Explanations:
|
||
|
||
- `v` — short; `vv` — medium; `vvv` — detailed with alternatives.
|
||
|
||
Clipboard support requires `xclip` or `xsel`.
|
||
|
||
## What's new in 2.0.14
|
||
|
||
- Authentication: JWT-based authentication with HTTP-only cookies
|
||
- CSRF protection: Full CSRF protection with tokens and middleware
|
||
- Security: Enhanced security with token validation and sessions
|
||
- Kubernetes deployment: Full set of manifests for Kubernetes deployment with Traefik
|
||
- Reverse Proxy: Support for working behind reverse proxy with cookie configuration
|
||
- Web interface: Improved web interface with modern design
|
||
- Monitoring: Prometheus metrics and ServiceMonitor
|
||
- Scaling: HPA for automatic scaling
|
||
- Testing: CSRF protection testing tools
|
||
|
||
## Environment
|
||
|
||
- `LCG_PROVIDER` (default `ollama`) — provider type: `ollama` or `proxy`
|
||
- `LCG_HOST` (default `http://192.168.87.108:11434/`) — base API URL
|
||
- `LCG_MODEL` (default `hf.co/yandex/YandexGPT-5-Lite-8B-instruct-GGUF:Q4_K_M`)
|
||
- `LCG_PROMPT` — default system prompt content
|
||
- `LCG_PROXY_URL` (default `/api/v1/protected/sberchat/chat`) — proxy chat endpoint
|
||
- `LCG_COMPLETIONS_PATH` (default `api/chat`) — Ollama chat endpoint (relative)
|
||
- `LCG_TIMEOUT` (default `300`) — request timeout in seconds
|
||
- `LCG_RESULT_FOLDER` (default `~/.config/lcg/gpt_results`) — folder for saved results
|
||
- `LCG_RESULT_HISTORY` (default `$(LCG_RESULT_FOLDER)/lcg_history.json`) — JSON history path
|
||
- `LCG_PROMPT_FOLDER` (default `~/.config/lcg/gpt_sys_prompts`) — folder for system prompts
|
||
- `LCG_PROMPT_ID` (default `1`) — default system prompt ID
|
||
- `LCG_BROWSER_PATH` — custom browser executable path for `--browser` flag
|
||
- `LCG_JWT_TOKEN` — JWT token for proxy provider
|
||
- `LCG_NO_HISTORY` — if `1`/`true`, disables history writes for the process
|
||
- `LCG_ALLOW_EXECUTION` — if `1`/`true`, enables command execution via `(e)` action menu
|
||
- `LCG_SERVER_PORT` (default `8080`), `LCG_SERVER_HOST` (default `localhost`) — HTTP server settings
|
||
|
||
## Flags
|
||
|
||
- `--file, -f` read part of prompt from file
|
||
- `--sys, -s` system prompt content or ID
|
||
- `--prompt-id, --pid` choose built-in prompt (1–5)
|
||
- `--timeout, -t` request timeout (sec)
|
||
- `--no-history, --nh` disable writing/updating JSON history for this run
|
||
- `--debug, -d` show debug information (request parameters and prompts)
|
||
- `--version, -v` print version; `--help, -h` help
|
||
|
||
## Commands
|
||
|
||
- `models`, `health`, `config`
|
||
- `prompts list|add|delete`
|
||
- `test-prompt <prompt-id> <command>`
|
||
- `update-jwt`, `delete-jwt` (proxy)
|
||
- `update-key`, `delete-key` (not needed for ollama/proxy)
|
||
- `history list` — list history from JSON
|
||
- `history view <index>` — view by index
|
||
- `history delete <index>` — delete by index (re-numbering)
|
||
- `serve` — start HTTP server to browse saved results (`--port`, `--host`, `--browser`)
|
||
- `/run` — web interface for executing requests
|
||
- `/execute` — API endpoint for programmatic access via curl
|
||
|
||
## Saving results
|
||
|
||
Files are saved to `LCG_RESULT_FOLDER` (default `~/.config/lcg/gpt_results`).
|
||
|
||
- Command result: `gpt_request_<MODEL>_YYYY-MM-DD_HH-MM-SS.md`
|
||
- `# <title>` — H1 with original request (trimmed to 120 chars: first 116 + `...`)
|
||
- `## Prompt`
|
||
- `## Response`
|
||
|
||
- Detailed explanation: `gpt_explanation_<MODEL>_YYYY-MM-DD_HH-MM-SS.md`
|
||
- `# <title>`
|
||
- `## Prompt`
|
||
- `## Command`
|
||
- `## Explanation and Alternatives (model: <MODEL>)`
|
||
|
||
## History
|
||
|
||
- Stored as JSON array in `LCG_RESULT_HISTORY`.
|
||
- On new request, if the same command exists, you will be prompted to view or overwrite.
|
||
- Showing from history does not call the API; the standard action menu is shown.
|
||
|
||
## Browser Integration
|
||
|
||
The `serve` command supports automatic browser opening:
|
||
|
||
```bash
|
||
# Start server and open browser automatically
|
||
lcg serve --browser
|
||
|
||
# Use custom browser
|
||
export LCG_BROWSER_PATH="/usr/bin/firefox"
|
||
lcg serve --browser
|
||
|
||
# Start on custom host/port with browser
|
||
lcg serve --host 0.0.0.0 --port 9000 --browser
|
||
```
|
||
|
||
Supported browsers (in priority order):
|
||
|
||
- Yandex Browser (`yandex-browser`, `yandex-browser-stable`)
|
||
- Mozilla Firefox (`firefox`, `firefox-esr`)
|
||
- Google Chrome (`google-chrome`, `google-chrome-stable`)
|
||
- Chromium (`chromium`, `chromium-browser`)
|
||
|
||
## API Access
|
||
|
||
The `serve` command provides both a web interface and REST API:
|
||
|
||
**Web Interface:**
|
||
|
||
- Browse results at `http://localhost:8080/` (or `http://localhost:8080<BASE_PATH>/` if `LCG_BASE_URL` set)
|
||
- Execute requests at `.../run`
|
||
- Manage prompts at `.../prompts`
|
||
- View history at `.../history`
|
||
|
||
Notes:
|
||
- Base path: set `LCG_BASE_URL` (e.g. `/lcg`) to prefix all routes and API.
|
||
- Custom 404: unknown paths under base path render a modern 404 page.
|
||
- Debug: enable via flag `--debug` or env `LCG_DEBUG=1|true`.
|
||
|
||
**REST API:**
|
||
|
||
```bash
|
||
# Start server
|
||
lcg serve
|
||
|
||
# Make API request
|
||
curl -X POST http://localhost:8080/execute \
|
||
-H "Content-Type: application/json" \
|
||
-d '{"prompt": "create directory test", "verbose": "vv"}'
|
||
```
|
||
|
||
**Response:**
|
||
|
||
```json
|
||
{
|
||
"success": true,
|
||
"command": "mkdir test",
|
||
"explanation": "The mkdir command creates a new directory...",
|
||
"model": "hf.co/yandex/YandexGPT-5-Lite-8B-instruct-GGUF:Q4_K_M",
|
||
"elapsed": 1.23
|
||
}
|
||
```
|
||
|
||
For complete API documentation, see `API_GUIDE.md`.
|
||
|
||
For full guide in Russian, see `USAGE_GUIDE.md`.
|