Commit Graph

83 Commits

Author SHA1 Message Date
e5d6925911 Remove shell restart note from README 2026-05-31 12:36:02 +00:00
f1deb7c162 Ignore local Antigravity config 2026-05-31 12:33:33 +00:00
c888056a7a Fix: correct cleanup logic that accidentally deleted new ai-gpt and ai-kimi scripts 2026-05-31 19:22:08 +07:00
c6a1a788d4 Docs: rewrite README.md to be simple and concise 2026-05-31 19:15:26 +07:00
f38915eab2 Refactor: rename setup script to ai-setup.sh and update all references 2026-05-31 19:09:50 +07:00
9d7d51aac1 Refactor: rename alias scripts to use ai-* prefix and add ai-claude proxy 2026-05-31 19:06:50 +07:00
6aac2cb083 test: add isolated install verification scripts
- Dockerfile.test: Ubuntu 24.04 container for clean-room setup testing
- test_isolated.sh: mock-based test verifying auto-install URLs are called
2026-05-31 18:50:30 +07:00
52072a5e4c docs: update README for native CLI launchers
- claude_gpt: native OpenAI Codex with auto-install
- claude_kimi: native Kimi K2.6 with auto-install
2026-05-31 18:50:06 +07:00
47e0f5e58d refactor: migrate claude_gpt and claude_kimi to native CLIs with auto-install
claude_gpt:
- Replace proxy orchestration with direct codex binary launch
- Auto-install via curl -fsSL https://chatgpt.com/codex/install.sh | sh

claude_kimi:
- Remove openai-anthropic-proxy.py (~450 lines)
- Replace Artemox API key flow with native kimi CLI
- Auto-install via curl -fsSL https://code.kimi.com/kimi-code/install.sh | bash

tests/test_fixes.sh:
- Remove obsolete proxy-specific tests (trap, readiness loops, etc.)
- Add tests for auto-install URLs and absence of proxy logic
2026-05-31 18:49:38 +07:00
1e15e4b6e8 refactor(claude_gpt): switch to native OpenAI Codex CLI
Replace claude-code-proxy + effort-proxy + claude wrapper with direct
codex binary invocation. claude_gpt now behaves like a simple launcher:
- Looks for codex in ~/.npm-global/bin or PATH
- Falls back with helpful install hint if missing
- Removes all proxy orchestration, auth polling, and Anthropic env vars
2026-05-31 18:12:42 +07:00
0c6508f239 refactor(claude_kimi): restore key prompt + proxy launch for Artemox API
claude_kimi now behaves like claude_deepseek:
- Prompts for Artemox API key if missing
- Validates key via _claude_test_openai_api
- Saves key to ~/.config/claude-launcher/kimi_key
- Starts claude-openai-anthropic-proxy.py locally
- Launches claude through the proxy with Anthropic env vars
2026-05-31 18:00:41 +07:00
42546b4dc1 feat: migrate Kimi from Moonshot to Artemox OpenAI API
- Add claude-openai-anthropic-proxy.py (Anthropic ↔ OpenAI translator)
- Rewrite claude_kimi to use native kimi CLI instead of Claude wrapper
- Add OpenAI-compatible API test helpers (_claude_test_openai_api, _handle_openai_api_response)
- Replace 127.0.0.1 with localhost for broader compatibility
- Add test for query-string handling in Kimi proxy
- Update README to reflect Artemox API usage
2026-05-31 17:55:57 +07:00
a1bf8023a9 fix: исправить падение claude_gpt (effort-proxy, гонка старта, xhigh→high)
Три корневые причины и исправления:

1. effort-proxy: однопоточный HTTPServer заменён на ThreadingMixIn,
   включён маппинг xhigh→high (claude-code-proxy больше не принимает xhigh),
   добавлено логирование ошибок в /tmp/claude-gpt-effort-proxy.log

2. Стартовая логика claude_gpt: убрано гоночное условие (pkill прокси
   при отсутствии effort-proxy), effort-proxy всегда перезапускается,
   curl -s вместо curl -sf для healthcheck'а

3. localhost заменён на 127.0.0.1 во всех URL для консистентности

Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
2026-05-31 15:55:38 +07:00
3647eba494 fix: fallback на raw body при пустом _emsg в проверке RESOURCE_EXHAUSTED
Если python3 недоступен или JSON не парсится, _emsg пустой.
Теперь grep проверяет сырое тело ответа как запасной вариант.

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-05-31 15:12:15 +07:00
65c15b97bc fix: сохранять новый ключ даже при исчерпании квоты (ret=429)
При вводе нового ключа ret=429 теперь обрабатывается так же, как для
сохранённого ключа: ключ сохраняется, затем предлагается продолжить всё равно.

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-05-31 15:12:01 +07:00
20bbae0657 feat: добавить обработку HTTP 400 в _handle_api_response
Thinking-модели (DeepSeek, Kimi) возвращают 400 на max_tokens=1 при проверке ключа.
Новый case обрабатывает это: RESOURCE_EXHAUSTED → return 429, иначе → OK.

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-05-31 15:11:30 +07:00
b3bff78977 fix: исправить заголовок авторизации для DeepSeek и Kimi
Anthropic SDK отправляет ключ в заголовке x-api-key, а не Authorization: Bearer.
Проверочные запросы теперь используют тот же заголовок, что и реальные вызовы.

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-05-31 15:11:15 +07:00
7cd7feb3f0 docs: обновить правила для агентов в AGENTS.md
Правило 1 упрощено — убрана явная оговорка про git add.
Добавлено правило 3: изменения должны быть видны через plain git diff.
Добавлено правило 4: отвечать на русском языке.

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-05-31 15:10:02 +07:00
2c20d4384f chore: add CLAUDE.md symlink pointing to AGENTS.md 2026-05-31 13:35:43 +07:00
c1bee1406e feat: make gemini 3.1 pro the default model for claude_gemini 2026-05-31 13:29:47 +07:00
78556245ef fix: effort-proxy mapping max→xhigh for GPT, add EFFORT_MAPPING.md
- Fix effort-proxy direction: GPT-5.5 natively supports xhigh but not max,
  so map max→xhigh (was incorrectly xhigh→max)
- Add EFFORT_MAPPING.md with full mapping table for all providers:
  Anthropic, GPT-5.5, DeepSeek V4, Kimi K2.6, Gemini 3.x
- Update proxy docstring and comments
2026-05-31 13:09:41 +07:00
a5f5c08e01 Rename CLAUDE.md -> AGENTS.md (universal agent instructions) 2026-05-31 12:59:35 +07:00
61c21fe296 Refactor architecture to use standalone scripts in ~/.local/bin/ instead of ~/.bashrc 2026-05-31 12:55:54 +07:00
4f25596867 Remove redundant claude_anthropic wrapper 2026-05-31 12:36:16 +07:00
46b7cfa798 Fix proxy handling and improve error reporting
- Add wrapper proxy for fixing effort level in claude-code-proxy
- Improve proxy cleanup trap to include wrapper
- Add credential backup and restore for ChatGPT to prevent Anthropic keys deletion on /logout
- Enhance error messages for 400 and other HTTP errors in ChatGPT and Gemini handlers
2026-05-31 12:29:51 +07:00
15c4727fb7 Исправить двойной логин Anthropic: убрать claude auth login, запускать claude напрямую
В Claude Code v2.x команда "claude auth login" запускает полный интерактивный TUI
(включая "Welcome to Claude Code" и "Select login method"), а затем функция дополнительно
вызывала claude "$@" — вторая сессия. Пользователь проходил выбор типа аккаунта дважды.

Исправление: ветка [L] теперь запускает claude "$@" напрямую с нужными моделями
и сразу делает return "$?", не допуская повторного вызова claude снизу функции.
Claude сам обрабатывает весь auth flow (браузер → OAuth → выбор аккаунта) за одно
взаимодействие.

Добавлен тест test_fix8_no_double_login (3 проверки), итого 24/24.

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-05-31 01:10:23 +07:00
048f6b1770 Исправить 7 багов после code review: экспорт ключа, утечка прокси, re-валидация
- Fix 1: export ANTHROPIC_API_KEY при ручном вводе ключа в claude_anthropic ([K]-ветка);
  без export subprocess claude не видел ключ и падал с ошибкой авторизации
- Fix 2: trap RETURN в claude_gpt убивает прокси при любом ранем return 1,
  устраняя утечку фоновых процессов
- Fix 3: sleep 1 заменён на poll-цикл (10 попыток, curl exit 7 = connection refused);
  connection refused теперь не маскируется под «нет сети»
- Fix 4: после codex auth login в claude_gpt добавлена повторная проверка _claude_test_api;
  прежде claude запускался без подтверждения успешности reauth
- Fix 5: аналогичная re-валидация в claude_gemini после браузерной авторизации
  (ветки 401/403 и 429)
- Fix 6: prompt [c/Q] → [C/q] в 429-обработчике claude_anthropic — заглавная буква
  соответствует умолчанию (стандарт файла: CAPITAL = default)
- Fix 7: trap 'rm -rf "$TMP"' EXIT — одинарные кавычки + кавычки вокруг $TMP,
  предотвращают word-split при путях с пробелами

Добавлены тесты: tests/test_fixes.sh (21 тест, все проходят)

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-05-31 00:53:53 +07:00
68c731b72e Добавить правило полной актуализации данных .bashrc при запуске сетап-скрипта
Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
2026-05-30 23:43:03 +07:00
8bb81398af Добавить поддержку Kimi K2.6 (Moonshot AI) и улучшить проверку API ключей
- Новая функция claude_kimi: Anthropic-совместимый API Moonshot AI
- Улучшена проверка ключей DeepSeek и Kimi: реальный вызов API
  с 1 токеном вместо GET /v1/models (бесплатный endpoint не ловил
  заблокированные аккаунты)
- Проверка различает: 200 (OK), 429 (заблокирован/нет средств),
  401/403 (невалидный ключ), сетевые ошибки
- При блокировке (429) выводится сообщение об ошибке и ссылка
  на пополнение баланса, ключ не сохраняется
- Обновлён README.md

Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
2026-05-30 23:38:43 +07:00
de5e94922b Обновить модели DeepSeek, добавить CLAUDE.md и тесты сигналов
- claude_setup.sh: обновлён эндпоинт DeepSeek API (/v1/models вместо /anthropic/v1/models),
  исправлена аутентификация (Authorization: Bearer вместо x-api-key),
  обновлены модели (deepseek-v4-pro, deepseek-v4-flash),
  убрано предложение сделать ,
  добавлен авто-перезапуск shell после выполнения скрипта
- CLAUDE.md: правила для агентов (запрет самостоятельных коммитов)
- test_interactive.py: тест обработки SIGINT в интерактивном bash (PTY)
- test_sigint.sh: тест сигналов для фоновых процессов

Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
2026-05-30 23:02:37 +07:00
9778b820c7 Update default Gemini models in setup script to fix invalid argument error 2026-05-30 22:02:38 +07:00
6f2c1b0b97 Add script and documentation 2026-05-30 21:47:06 +07:00
a27eb5d0f7 Initial commit 2026-05-30 21:46:39 +07:00