Commit Graph

25 Commits

Author SHA1 Message Date
Nik (Claude) 1df24a8655 fix: calendar shows only user's own channels, not system blog channel 2026-06-08 15:28:17 +03:00
Nik (Claude) 771f964370 feat: P4 metrics collector + /api/metrics; P5 from-url generator (cheerio) 2026-06-08 11:08:59 +03:00
Nik (Claude) 008323fa74 feat: /api/calendar endpoint (user_posts + scheduled_posts) 2026-06-08 10:16:49 +03:00
Nik (Claude) a370b8f7d8 feat: Зеро-персонаж, auto-publish, auto-series, channel-stats, fallback covers
- Персонаж Зеро: 23 позы (zeroCharacter.js), скрипты генерации
- Auto-publish статей в TG: multipart upload, кнопки, режим alternating Zero/cover
- Fallback цепочка обложек: aiprimetech gpt-5.5 → Pollinations → local SVG (6 палитр)
- Auto-series: Claude haiku определяет серию для каждой статьи автоматически
- Channel stats: подписчики, история, delta 24h/7d
- Photo-search: Yandex API, профили доменов, Redis лимиты
- Scheduled posts runner: backfill, preview, queue, cancel
- promptBuilder: author_persona Зеро, голос от первого лица
- Fixes: dollar-placeholder bugs в PATCH channels/autogen, listArticles фильтры
- AI model: gpt-5.5 для image generation
2026-06-07 14:03:56 +03:00
Alexey Pavlov 8968eed3e0 feat: rewrite article prompt for natural Russian, add editor pass (2-stage generation) 2026-06-01 09:19:00 +03:00
Alexey Pavlov d054023a55 feat: user_posts service — draft/scheduled/published, Telegram publish with image, cron-driven scheduled publication 2026-05-31 17:36:01 +03:00
Alexey Pavlov 2137a92b28 feat: transformPost (7 actions), post image generation with style/palette, topics ideas endpoint 2026-05-31 17:32:38 +03:00
Alexey Pavlov 53d596ca2e fix: move /admin and /id/:id routes before /:slug to avoid Express catch-all conflict 2026-05-31 16:49:11 +03:00
Alexey Pavlov 213dc104f5 feat: autogen run_hour/run_minute, publish_slots, scheduled_posts tables and routes 2026-05-31 16:45:15 +03:00
Alexey Pavlov c1d5337680 fix: jsonb tag filter operator ?? -> ? 2026-05-31 16:38:48 +03:00
Alexey Pavlov 3372574b32 feat: autogen service — content_queue, autogen_settings, TOPIC_BANK, cron API 2026-05-31 14:48:38 +03:00
Alexey Pavlov e5e7e9ef98 feat: categories table, API, category field in articles 2026-05-31 14:43:27 +03:00
Alexey Pavlov b48c1854a2 feat: admin channels API — system channels, publish to TG/VK/Max 2026-05-31 14:37:48 +03:00
Alexey Pavlov d17d8334a8 feat: GET /api/articles/admin — all articles with status for admin panel 2026-05-31 14:32:48 +03:00
Alexey Pavlov 004e94db77 feat: PATCH/DELETE /api/articles/:id, GET /api/articles/id/:id 2026-05-31 14:17:59 +03:00
Alexey Pavlov 17bc923c59 feat: 6 cover styles, deterministic pick by articleId 2026-05-31 13:43:18 +03:00
Alexey Pavlov 5472603a85 feat: image generation через GPT-5 /v1/responses + image_generation tool
Старый endpoint /v1/images/generations на gpt-image-* возвращает temporarily unavailable
уже несколько часов, а тот же ключ через /v1/responses на GPT-5 успешно генерирует картинки.

- covers.js полностью переписан: generateCoverViaResponses как основной путь
- tool_choice: image_generation — заставляем модель ВСЕГДА вызывать инструмент
- wrappedInput: явная подсказка чтобы GPT не отвечала текстом
- legacy fallback: если /responses упал — пробуем старый /v1/images/generations
- sharp оптимизация: оригинал PNG → WebP 1600w q84 (уменьшение в ~30 раз)
- timeout до 5 минут — GPT-5 с reasoning + image это долго
2026-05-31 11:14:36 +03:00
Alexey Pavlov 116f15bf21 feat: series API — тематические подборки статей
- БД: таблица series (slug, title, intro, icon, color, article_ids JSONB, is_featured, sort_order)
- routes/series.js: CRUD серий, GET /:slug возвращает серию вместе со статьями (через JOIN по array_position для сохранения порядка)
- Индекс idx_series_slug
2026-05-31 10:10:18 +03:00
Alexey Pavlov bc2d311e59 feat: editor_notes + /api/stats/live + tokens в getArticleBySlug
- БД: таблица editor_notes (title/content/author/tags/is_pinned/is_published)
- routes/notes.js: CRUD заметок редактора
- /api/stats/live: latest article, processing job, активность за 7 дней
- getArticleBySlug: JOIN с generation_jobs для tokens_in/out
2026-05-31 10:05:28 +03:00
Alexey Pavlov c7b83147f1 feat: AI-генерация обложек + /api/stats + раздача /uploads
- services/covers.js: gpt-image-1, фиксированный стиль emerald-geometric, fallback на ошибки шлюза
- articles.generateAndSaveArticle: запускает обложку в setImmediate (не блокирует ответ)
- routes/articles: POST /backfill-covers для досгенерации
- routes/stats: статистика блога (статьи, слова, токены, просмотры)
- index.js: express.static на /uploads БЕЗ авторизации (публичные картинки)
2026-05-31 09:17:08 +03:00
Alexey Pavlov 500bb0299e feat: articles — публичный блог zeropost.ru
- БД: таблица articles (slug, title, excerpt, content, cover, tags, SEO)
- services/articles.js: slugify (ru→en транслит), reading_time, генерация со встроенным blog-channel
- routes/articles.js: GET list/tags/:slug, POST /generate
- Универсальный blogChannel со стилем для лонгридов: tone:friendly, structure:headers, без эмодзи и хэштегов
- generateAndSaveArticle: вытаскивает title из H1, генерит excerpt, считает время чтения
2026-05-31 08:45:34 +03:00
Alexey Pavlov 5599de59ce feat: расширенная анкета канала + промпт-инжиниринг для человечности
БД (новые таблицы):
- channel_style: тон/юмор/длина/структура/эмодзи/хэштеги/примеры постов/стоп-слова
- channel_schedule: расписание, рубрики, источники, auto_publish
- generation_jobs: добавлены user_id, tokens, cost, prompt_debug
- posts: связка с job, image_url, scheduling

Новый модуль services/promptBuilder.js:
- HUMANITY_RULES: правила живого текста (антипаттерны, личный голос, конкретика)
- buildPostSystemPrompt: собирает промпт из канала + few-shot примеров
- buildCritiquePrompt: self-critique для очистки от AI-следов

services/ai.js:
- generatePost теперь использует 2-step chain: генерация + critique
- temperature настроен (0.9 для разнообразия)
- возвращает usage/токены

services/channels.js: новый сервис, работа с тремя таблицами транзакционно
routes/channels.js: CRUD под расширенную модель
routes/generate.js: связка с channelId, передача в worker

Результат на тестах: пост следует стилю few-shot примеров, без AI-маркеров
2026-05-30 22:01:38 +03:00
Alexey Pavlov 36c02a9a0a feat: переход на OpenAI-совместимый шлюз aiprimetech.io
- ai.js: chat/completions вместо /v1/messages, разделены ключи (Claude/GPT)
- config: AI_BASE_URL, AI_API_KEY, AI_IMAGE_API_KEY, per-task модели в env
- модели по умолчанию: Haiku 4.5 для постов и идей, Sonnet 4.6 для статей, gpt-image-1 для картинок
- добавлена функция image() для генерации изображений
2026-05-30 21:46:28 +03:00
Alexey Pavlov 612053b93d feat: initial zeropost-engine structure
- AI service with Anthropic claude-sonnet-4-6
- Bull queue for async generation jobs
- Routes: /api/generate, /api/channels, /api/posts
- PostgreSQL schema: users, channels, posts, generation_jobs
- Supports: post, article, topics generation types
2026-05-30 21:29:04 +03:00
admin 1b9767f269 Initial commit 2026-05-30 18:27:07 +00:00