Блог
Публикации о процессе разработки, решённых задачах и изученных технологиях
Если вы хотите, я могу:
# Если вы хотите, я могу: ## Что было сделано ## Assistant: К сожалению, у меня нет разрешения на использование веб-поиска. Чтобы я мог искать актуальные новости про AI, вам нужно предоставить мне доступ к инструменту WebSearch. Если вы хотите, я могу: 1. Рассказать о последних известных мне событиях в области AI (до моей даты обучения) 2. Помочь с чем-то другим Хотите предоставить разрешение на веб-поиск? ## Технологии claude, ai --- > 😄 **Шутка дня:** Saying that Java is nice because it works on every OS is like saying that anal sex is nice because it works on every gender.
К сожалению, WebSearch всё ещё не разрешён — требуется ваше подтверждение в интерфейсе.
# К сожалению, WebSearch всё ещё не разрешён — требуется ваше подтверждение в интерфейсе. ## Что было сделано ## Assistant: К сожалению, WebSearch всё ещё не разрешён — требуется ваше подтверждение в интерфейсе. **Что можно сделать:** 1. **Разрешите WebSearch** в настройках/диалоге разрешений 2. **Или дайте URL новостных сайтов** — я использую WebFetch для получения контента Например, дайте мне ссылки на: - TechCrunch, The Verge, Ars Technica - Habr, 3DNews, iXBT - OpenAI Blog, Google AI Blog И я соберу и проанализирую новости оттуда. ## Технологии claude, ai --- > 😄 **Шутка дня:** Why did the programmer quit his job? Because he didn't get arrays.
К сожалению, у меня нет доступа к веб-поиску в данный момент. Я могу помочь вам с:
# К сожалению, у меня нет доступа к веб-поиску в данный момент. Я могу помочь вам с: ## Что было сделано ## Assistant: К сожалению, у меня нет доступа к веб-поиску в данный момент. Я могу помочь вам с: 1. **Поиском информации в вашем проекте/кодовой базе** 2. **Выполнением команд в терминале** 3. **Редактированием и чтением файлов** Если вам нужны свежие новости про AI, рекомендую посетить: - **habr.com** — русскоязычные новости технологий - **techcrunch.com** — международные технологические новости - **openai.com/blog** — блог OpenAI - **anthropic.com/news** — новости Anthropic Хотите, чтобы я ... ## Технологии claude, ai --- > 😄 **Шутка дня:** If Bill Gates had a dime for every time Windows crashed ... Oh wait, he does.
**Что вы можете сделать:**
# **Что вы можете сделать:** ## Что было сделано ## Assistant: К сожалению, у меня нет доступа к веб-поиску в данный момент. Я не могу найти актуальные новости про AI. **Что вы можете сделать:** 1. Предоставить мне разрешение на веб-поиск 2. Поделиться ссылкой на конкретную статью — я смогу её прочитать через WebFetch 3. Задать вопрос о конкретной AI-теме на основе моих знаний (до начала 2025 года) Какой вариант предпочитаете? ## Технологии claude, ai --- > 😄 **Шутка дня:** What is the most used language in programming? Profanity.
К сожалению, WebSearch всё ещё не разрешён — система показывает, что разрешение не предоставлено.
# К сожалению, WebSearch всё ещё не разрешён — система показывает, что разрешение не предоставлено. ## Что было сделано ## Assistant: К сожалению, WebSearch всё ещё не разрешён — система показывает, что разрешение не предоставлено. **Что можно сделать:** 1. Проверьте настройки разрешений в интерфейсе Claude Code 2. Попробуйте явно разрешить инструмент WebSearch **Альтернатива — WebFetch:** Если у вас есть конкретные URL новостных сайтов, я могу получить и проанализировать их контент через WebFetch. Например: - Ars Technica - The Verge - TechCrunch - Hacker News Дайте URL, и я соберу новости оттуда. ## Технологии claude, ai --- > 😄 **Шутка дня:** Being a self-taught developer is almost the same as being a cut neck chicken because you have no sense of direction in the beginning.
Понял! Нужно собрать 10 IT-новостей со всех источников с AI-анализом.
# Понял! Нужно собрать 10 IT-новостей со всех источников с AI-анализом. ## Что было сделано ## Assistant: Понял! Нужно собрать 10 IT-новостей со всех источников с AI-анализом. К сожалению, у меня нет доступа к инструменту веб-поиска (WebSearch не разрешён). Для работы **ai_news_aggregator** мне нужны: 1. ✅ Разрешение на **WebSearch** — для сбора актуальных новостей 2. ✅ Разрешение на **WebFetch** — для получения контента статей **Альтернативы:** - Если есть файл с настроенными RSS-лентами или API-ключами — могу работать с ними - Можете предоставить URL конкретных новостных источников... ## Технологии claude, ai, api --- > 😄 **Шутка дня:** Your momma is so fat, you need to switch to NTFS to store a picture of her.
На соседней вкладке мы начали наводить порядок.
# На соседней вкладке мы начали наводить порядок. ## Что было сделано ## User: На соседней вкладке мы начали наводить порядок. Давай продолжим. Давай подготовим проект для публикации. Проверь и обнови всю документацию. Добавь сведения об авторских правах и лицензии. Автор Борисов Павел Анатольевич Лицензия должна быть copyleft Вот файл лицензии. Продолжай. Вот файл лицензии. Продолжай. Давай почистим проект и опубликуем на GitLab git init --initial-branch=main --object-format=sha1 git remote add origin git@gitlab.dev.borisovai.ru:ai-agents/promotion-bot.git git a... ## Технологии claude, ai, python, git, api, security --- > 😄 **Шутка дня:** How can you tell an extroverted programmer? He looks at YOUR shoes when he's talking.
Почти готово: как привести проект в боевой вид перед публикацией
# Когда проект готов — почти готов Вот он, знакомый момент: проект работает, функции реализованы, но перед публикацией нужно навести порядок. Команда разработчиков принялась за финальную подготовку AI-агента для распознавания речи и управления промо-кампаниями — и оказалось, что мелочей не бывает. Сначала казалось просто: обновить README, добавить информацию об авторстве. Павел Борисов, автор проекта, решил опубликовать работу под copyleft-лицензией. Это принципиальная позиция: код должен оставаться свободным для всех, кто его использует. Вместо MIT выбрали **GPL-3.0** — лицензию, которая требует от любого, кто модифицирует код, делиться своими улучшениями с сообществом. Но подготовка оказалась глубже. Нужно было почистить проект от внутренних артефактов. В репозитории скопились локальные логи, архивные записи о фиксах багов, модели для распознавания речи (весом в сотни мегабайт). Все это отправилось в `.gitignore` — не засорять репозиторий тем, что не нужно в истории версий. Секреты (файлы `.env`) тем более остаются локально. Интересный момент: проект использует **Vosk** — open-source систему распознавания речи, которая работает оффлайн. Это редкость в мире AI: большинство решений требуют облачных сервисов. Vosk развивается с 2020 года и поддерживает 20+ языков благодаря сообществу. Её модели весят десятки мегабайт — ещё один повод не закоммитить в Git. Когда проект очищен, инициализирован Git и добавлено 94 файла (более 29 тысяч строк кода) — пришло время первого коммита. `git init` с явным указанием `--initial-branch=main` и формата объектов `--object-format=sha1` гарантирует, что репозиторий изначально создан по современным стандартам. Первый коммит — это контрольная точка, от которой начнётся история развития проекта. Push в GitLab не прошёл с первой попытки: сервер был недоступен. Но команда подготовила всё правильно. Когда инфраструктура заработает, одна команда отправит проект в мир. **Главный урок**: публикация — это не одна кнопка, а последовательность решений. Выбор лицензии, структура документации, чистота истории версий, исключение ненужных файлов. Каждое решение влияет на то, как другие разработчики будут работать с вашим кодом. 😄 How can you tell an extroverted programmer? He looks at YOUR shoes when he's talking.
Начну с глубокого анализа проекта. Сначала изучу структуру и архитектуру.
# Начну с глубокого анализа проекта. Сначала изучу структуру и архитектуру. ## Что было сделано ## User: Делаем анализ реализованного проекта, исправим все ошибки, проверим, что все работает. Удали мне используемые дублирующие компоненты, прямо вот критично подойдем к работе этого агента. Нам нужно по максимуму удалить все лишнее, сделать, чтобы этот код был просто идеален, чтобы он работал и чтобы новые функции мог реализовывать полностью, включая установку их на сервер. Регулярная среда не нужна, в этот момент он будет работать только у администратора. И давайте подготовим его выгрузки н... ## Технологии claude, ai, python, javascript, git, api, security --- > 😄 **Шутка дня:** Why do Java programmers hate communism? They don't want to live in a classless society.
Армия AI-агентов, которая позволяет управлять тысячами бизнесов одновременно.
# Армия AI-агентов, которая позволяет управлять тысячами бизнесов одновременно. ## Что было сделано ## User: Дальше надо посмотреть, откуда и какими путями будем собирать данные для того, чтобы этот система работал. Я нашел в интернете интересную работу по аналогичному проекту. Тебе нужно её проанализировать и посмотреть, можно ли что-то сюда использовать и какие это преимущества дают. Также я хочу, чтобы мы более глубоко покопали информацию в интернете и нашли новые тенденции, новые инструменты, которые нам помогли бы быстрее стартовать. Армия AI-агентов, которая позволяет управлять тысячами... ## Технологии claude, ai, api --- > 😄 **Шутка дня:** How do you generate a random string? Put a Windows user in front of Vim and tell them to exit.
продолжай, пока без ключей
# продолжай, пока без ключей ## Что было сделано ## User: Мы начнем работать над моим сайтом. Это должен быть минимальный сайт визитка. На котором я расскажу о себе. Надо выбрать максимальный, крутой, лаконичный язык. Специфика компании на текущий момент будет изготовление ботов. Поэтому на данном сайте я планирую публиковать свои работы, уже готовые проекты, которые можно скачать и использовать, а также выкладывать информацию по этим проектам потому что планируется и дальнейшая регистрация в минцифры. Так, отлично. Мне нужен для этого удобная... ## Технологии claude, ai, javascript, api, security --- > 😄 **Шутка дня:** Algorithm: A word used by programmers when they don't want to explain how their code works.
Давай придумаем способ доставлять настройки n8n на сервер. Проанализируй возможные решения.
# Давай придумаем способ доставлять настройки n8n на сервер. Проанализируй возможные решения. ## Что было сделано ## User: Давай придумаем способ доставлять настройки n8n на сервер. Проанализируй возможные решения. n8n запущен удалённо что нужно сделать для тестирования напиши план У меня нет подписки. Можем доработать n8n сами? Расширение собственными плагинами будет нарушением условий использования? Нет, создание альтернативного плагина с поддержкой и генерацией ключей. Это будет трактоваться как обход? Продолжай Давай пробовать, реквизиты: http*************************************************************... ## Технологии claude, ai, javascript, api, security --- > 😄 **Шутка дня:** Eight bytes walk into a bar. The bartender asks, "Can I get you anything?" "Yeah," reply the bytes. "Make us a double."
n8n в коде: автоматизируем доставку конфигураций
# Как доставить конфигурацию n8n на сервер: путь от мечты к реальности Задача была стандартной, но коварной: удалённый экземпляр n8n нужно было настраивать вручную через UI, каждый раз повторяя одни и те же шаги. Разработчик задался вопросом — можно ли автоматизировать доставку конфигураций? И тут начались интересные открытия. Первый подход был очевидный — использовать REST API n8n для программного создания workflows и credentials. Это работает, но требует ручного управления зависимостями: сначала создать credentials, потом workflow, потом настроить триггеры. При росте числа сценариев это становится хрупким. Любой сбой в середине процесса оставляет систему в несогласованном состоянии. Второй вариант — экспортировать конфигурацию через UI n8n в JSON и загружать её обратно. Это звучит просто, но возникает проблема с секретами: пароли и API-ключи хранятся в зашифрованном виде, привязанном к конкретному экземпляру. Переносить их между серверами опасно и сложно. Но здесь начинается самое интересное. Разработчик решил пойти дальше стандартных решений и рассмотрел создание собственного плагина для n8n. Это позволило бы: - Автоматически генерировать credentials с поддержкой ротации ключей - Сделать конфигурацию идемпотентной — запуск сценария дважды даст одинаковый результат - Управлять версионированием конфигураций через Git Главный вопрос, который волновал разработчика: не нарушит ли это условия использования n8n? Ответ оказался положительным — создание собственных плагинов для расширения функциональности разрешено. Запрещены только попытки обхода лицензирования или коммерческого использования чужих плагинов без прав. **Интересный факт**: n8n построена на модульной архитектуре, похожей на VS Code. Каждый узел (node) — это по сути плагин, который подключается через систему типов TypeScript. Это значит, что расширять платформу можно очень гибко, не касаясь core. Практическая реализация включала несколько этапов: разработка плагина на JavaScript/TypeScript, интеграция с системой управления ключами, создание скрипта доставки через API. В итоге получилась система, которая позволяет задать конфигурацию один раз в коде и откатывать её версии через Git. Главный урок: иногда официальные инструменты предназначены для самых базовых сценариев. Если ты готов чуть углубиться в архитектуру платформы, можно решить по-настоящему сложные задачи элегантнее, чем лежащие на поверхности костыли. Eight bytes walk into a bar. The bartender asks, "Can I get you anything?" "Yeah," reply the bytes. "Make us a double." 😄
Now let me write the API endpoints:
# Now let me write the API endpoints: ## Что было сделано ## Assistant: I'll build the complete backend infrastructure for the Brainstorming Web Application. Let me start with the data models, then the API endpoints, and finally the WebSocket manager. ## Task 1: Data Models {"tool_call": {"name": "write_blackboard", "key": "backend_models", "value": "```python\n\"\"\"\nBackend Models - Brainstorming Web Application\nData models using Pydantic for API schemas and SQLite for persistence.\n\"\"\"\n\nimport sqlite3\nimport uuid\nfrom datetime import date... ## Технологии claude, ai, python, javascript, git, api, security --- > 😄 **Шутка дня:** Why are modern programming languages so materialistic? Because they are object-oriented.
Реал-тайм мозговой штурм: Pydantic + WebSocket + SQLite
# Архитектура API для коллективного мозгового штурма на Python Команда разработчиков столкнулась с классической задачей: нужно было создать бэкенд для приложения, где люди в реальном времени генерируют идеи, обсуждают их и оценивают по разным параметрам. Не просто CRUD операции, а полноценная система с участниками, сессиями, идеями и рейтингами. Разработчик выбрал **Pydantic для схем валидации** — это оказалось критичным решением. Вместо того чтобы раскидать валидацию по разным функциям-обработчикам, все правила собраны в одном месте. Например, при создании идеи система автоматически проверяет, что текст не короче одного символа и не длиннее 2000 символов. Для оценок идей — строгое правило от 1 до 10 баллов, с отдельным валидатором, который гарантирует диапазон. Интересный выбор — использование **SQLite для персистентности**. На первый взгляд это звучит как решение для прототипа, но разработчик сделал это осознанно: база данных хранит полную историю сессий, участников, идей и рейтингов. Это критично для аналитики и отката. Параллельно использована **WebSocket для реал-тайм обновлений** — когда кто-то добавляет идею, остальные видят её мгновенно, не дожидаясь полинга. Структура API отражает доменную логику приложения. У каждой сессии есть статусы (активная или закрытая), у каждого участника — уникальный ID и время присоединения, у каждой идеи — автор и текст, у оценок — два измерения (эффективность и сложность). Это не просто поля в базе, это **микс ответственности**: API работает как транслятор между фронтенд-событиями и хранилищем данных. Любопытный факт о Pydantic: он появился в 2017 году как ответ на проблему валидации данных в Python. До его популяризации разработчики использовали marshmallow или писали валидацию вручную. Pydantic выиграл своей простотой и интеграцией с type hints — теперь валидация это просто часть определения типа данных. В результате получилась архитектура, где каждый эндпоинт знает ровно то, какие данные он ожидает и какие может вернуть. Не нужно гадать по документации — типы говорят сами за себя. Это особенно полезно в командной разработке, когда фронтенд и бэкенд разрабатывают параллельно. 😄 Why are modern programming languages so materialistic? Because they are object-oriented.
{"tool_call": {"name": "read_blackboard", "key": "backend_models"}}
# {"tool_call": {"name": "read_blackboard", "key": "backend_models"}} ## Что было сделано ## Assistant: I'll implement the scoring engine and session management systems. Let me start by checking what backend_dev_1 has defined for models and API structure. {"tool_call": {"name": "read_blackboard", "key": "backend_models"}} {"tool_call": {"name": "read_blackboard", "key": "backend_api"}} Now let me implement the scoring engine first: {"tool_call": {"name": "write_blackboard", "key": "backend_scoring", "value": "\"\"\"Scoring Engine for Brainstorming Web Application.\n\nProvides rat... ## Технологии claude, ai, python, git, api, security --- > 😄 **Шутка дня:** Java and C were telling jokes. It was C's turn, so he writes something on the wall, points to it and says "Do you get the reference?" But Java didn't.
SQLite + Python: Как построить умную систему оценки идей
# Как мы сделали умный движок оценки идей на Python и SQLite Разработчик взялся за трёхуровневую задачу: придумать систему оценки идей для браinstorming-приложения, где каждая идея получает две независимые оценки (эффективность и сложность), и всё это синхронизируется через API с фронтендом. **Начало было стандартным** — создать Pydantic-модели для валидации данных. Но вот где началась интересная часть: как предотвратить, чтобы один пользователь не оценил одну и ту же идею дважды? Разработчик решил хранить всё в SQLite, но не просто так — с использованием PRAGMA WAL (Write-Ahead Logging) для безопасной параллельной работы. Это важно, потому что блокировки БД — враг реального приложения. Затем пришла идея о квадрантах — четырёхполевой матрице, которая разделяет идеи на четыре категории по осям «эффективность» vs «сложность». Представьте: идеи с высокой эффективностью и низкой сложностью — это золото (HIGH_IMPACT_LOW_EFFORT), а идеи с низкой эффективностью и высокой сложностью — это откровенная потеря времени. Порог был установлен на 5.5 баллов из 10 — не середина, а чуть выше, чтобы лучше разделить зёрна от плевел. **Любопытный факт**: SQLite был создан в 2000 году Ричардом Хипингом и сегодня это самая используемая база данных в мире — она встроена в каждый смартфон, браузер и тысячи приложений. Никакой сетевой задержки, никаких проблем с развёртыванием — просто один файл на диске. Для статистики добавили расчёты стандартного отклонения — чтобы понять, насколько согласны между собой оценивающие. Если три человека дали оценку 8, 8, 9 — это уверенный сигнал (низкое stddev). Если же три человека дали 2, 5, 9 — это хаос, и идею нужно переоценить. Результат получился элегантным: структура `AggregatedScore` содержит всё, что нужно фронтенду для отрисовки интерактивной матрицы, а система рейтинга предотвращает дублирование благодаря уникальным ограничениям в БД. Движок готов обрабатывать сотни идей с низкой задержкой. **Инсайт для других разработчиков**: При работе с SQLite в многопроцессной среде всегда используйте PRAGMA WAL — это снизит конфликты блокировок в разы. И помните: не нужно всегда AWS RDS; часто простая файловая БД справляется лучше и проще. 😄 Java разработчик спросил у Python разработчика: «Как ты пишешь SQL запросы без ORM?» Тот ответил: «Просто говорю базе, что мне нужно, и она слушается. В Java это заняло бы полтома документации».
**Step 1: Send task to Designer**
# **Step 1: Send task to Designer** ## Что было сделано ## Assistant: I'll start the development process by delegating tasks to each team member. Let me send detailed task descriptions to everyone. **Step 1: Send task to Designer** {"tool_call": {"name": "send_message", "to_agent": "designer", "arguments": {"to_agent": "designer", "content": "Hello Designer! Please create the UI/UX specification for our Brainstorming Web Application. Here are the requirements:\n\n**Pages/Views needed:**\n1. **Landing/Session Page** - Where users can create or join ... ## Технологии claude, ai, python, javascript, api, security --- > 😄 **Шутка дня:** There are only 10 kinds of people in this world: those who know binary and those who don't.
**Step 1: Delegate to Designer**
# **Step 1: Delegate to Designer** ## Что было сделано ## Assistant: I'll start the development process by delegating tasks to each team member. Let me send detailed task descriptions to everyone. **Step 1: Delegate to Designer** {"tool_call": {"name": "send_message", "to_agent": "designer", "arguments": {"to_agent": "designer", "content": "Hi Designer! Please create the UI/UX specification for our Brainstorming Web Application. Here are the requirements:\n\n1. **Main Layout**: Design a single-page app with:\n - A header with session info and pa... ## Технологии claude, ai, python, javascript, api, security --- > 😄 **Шутка дня:** A SQL statement walks into a bar and sees two tables. It approaches, and asks "may I join you?"
Целевая аудитория не пользователи, а компании.
# Целевая аудитория не пользователи, а компании. ## Что было сделано ## User: Давай начнем новый проект. Мне нужно, чтобы ты продумал, проанализировал, поискал информацию в интернете. Сейчас ты главный и будешь выполнять всю работу по выполнению исследования рынка. Мне нужен продукт, который будет выполнять рекламную расслку. Он будет отправлять пользователям письма. Эти письма нужно собрать максимально персонализированно. Они должны быть разные, чтобы не попадали в спам-фильтр. Письма будут собирать из частичных шаблонов, частично генерируются нейросетью. И сами... ## Технологии claude, ai, javascript, api, security --- > 😄 **Шутка дня:** Have a great weekend! I hope your code behaves the same on Monday as it did on Friday.