Календарь, задачи, заметки, почта. Мы используем десятки инструментов, но они не умеют жить вместе. Данные размазаны по сервисам. Команда в Битрикс24, семья в WhatsApp, клуб в Google Calendar. Везде свой интерфейс, свои правила, своя изоляция.

Последний год мы собирали альтернативу. Получился модульный конструктор, где приложение собирается под человека — и тут же подключается к любой форме организации. Семья, рабочая группа, соседский чат, волонтёрский штаб. Один бинарник, два режима работы, общие данные там, где они нужны.
MVP собрано и проходит тестирование. Дальше — рассказ о том, что получилось, и приглашение к обсуждению архитектуры.
Проблема
Рабочий день начинается с того, что я открываю пять приложений. Заметки в Obsidian. Задачи в Todoist. Почта в Spark. Календарь в Google Calendar. Командная вики в Notion.
Между ними нет связи. Письмо превращается в задачу руками. Встреча из календаря не видит заметок к ней. Командные задачи лежат отдельно от личных — хотя часто это части одного дня.
С командой хуже. Чтобы дать доступ к общему календарю, нужно чтобы все зарегистрировались в Google. Чтобы общий список задач — зарегистрировались в Notion. Чтобы чат — в Telegram. Каждый раз: аккаунт, настройки, приглашения, права. Данные команды живут на чужих серверах и под чужими правилами.
Малый бизнес и команды часто сидят на Битрикс24. Это комбайн: CRM, задачи, чат, календарь, диск, телефония — всё в одном. Для отдела продаж на 15 человек — рабочая лошадка. Пока не нужно выйти за пределы экосистемы.
Проблема начинается, когда личное не лезет в Битрикс24. Идея для pet-проекта, семейный список покупок, план ремонта — это не «сделка» и не «задача по CRM». Тащить такое в рабочий контур не хочется. Данные перемешиваются. Уведомления о домашних делах приходят вперемешку с входящими от клиентов. Интерфейс, спроектированный для воронок продаж и канбанов, становится препятствием, а не помощью.
Есть «Яндекс 360 для бизнеса» — почта, диск, календарь, мессенджер. Корпоративный мини-Google. Хорош для почты и файлов. Но модуль задач — это просто списки. Без зависимостей, без проектного трекинга, без связи с календарём в том смысле, в каком это нужно команде разработки или дизайн-бюро.
Есть «Мегаплан» — ещё один комбайн: CRM, задачи, документы, коммуникации. Работает на малый и средний бизнес. Закрывает базовые сценарии. Но опять же: это монолит. Нельзя взять из Мегаплана только календарь и подключить к нему свой интерфейс. Нельзя развернуть семейную версию на домашнем сервере. Нельзя добавить самописный модуль для специфической задачи.
Общая черта этих решений — они спроектированы под организацию. Под компанию с иерархией, отделами, ролями «руководитель — подчинённый». А если организация — это семья? Дачный кооператив? Волонтёрский штаб на десять человек без оргструктуры? Интерфейс Битрикс24 для обсуждения субботнего ужина — это как из пушки по воробьям. Тяжело, непонятно, а главное — данные всё равно на чужом сервере.
Современные инструменты заточены под одиночек или под компании. Середины нет. Нельзя просто взять и завести «общий календарь для дачного кооператива» без того, чтобы не сделать всех рабами чужой инфраструктуры.
Идея
Представьте: одно приложение. Вы запускаете его и выбираете модули, которые нужны. Только календарь и задачи. Или календарь, задачи, заметки и почта. Ничего лишнего.
Теперь вы хотите общий календарь для семьи. Вы запускаете это же приложение на домашнем сервере (или просто на своём компьютере) в режиме ноды. Нода — это организационный узел. Семейная нода содержит общий календарь, список покупок, важные контакты. Вы приглашаете жену, мужа, бабушку. Каждый получает доступ ровно к тому, что ему нужно. Бабушка видит только календарь. Ребёнок — список домашних дел.
Потом вы хотите рабочую ноду. Запускаете ещё один экземпляр в режиме ноды — на сервере компании. Там живут рабочие календари, проектные задачи, командная вики. Вы подключаетесь к ней из того же приложения. Теперь в вашем календаре видны события и из семьи, и с работы. Но семейные данные не утекают в компанию — и наоборот.
Одно приложение. Два режима. Данные там, где вы решаете.
В отличие от Битрикс24 или Мегаплана, нода не навязывает структуру. Нода — это просто контейнер для модулей и прав. Хотите — запустили CRM-модуль и строите воронку продаж. Хотите — только календарь и список покупок. Никаких обязательных «сделок», «контактов», «компаний». Никакой предустановленной бизнес-логики. Пространство под ваши сценарии.
Как это работает
В основе архитектуры — три слоя.
Слой 1: Личный узел
Приложение на компьютере пользователя. Electron + React для интерфейса, Rust-ядро под капотом. Модули — это изолированные движки: движок заметок, движок календаря, движок задач. Они общаются через общую шину событий.
Пользователь собирает интерфейс из виджетов. Нужен календарь — добавил виджет. Нужны задачи — добавил список. Виджеты компонуются в слоты: боковая панель, основная область.
Данные хранятся локально в SQLite. Приложение работает оффлайн. Все изменения сначала сохраняются у пользователя.
Слой 2: Организационная нода
То же приложение, запущенное с флагом --mode node. Может работать без графического интерфейса — как фоновая служба. Содержит общие данные: семейный календарь, рабочие задачи, вики отдела.
Нода управляет правами. Вот конфигурация семейной ноды:
node: type: family name: "Семья Ивановых" port: 9090modules: - calendar: shared: true name: "Семейный календарь" - tasks: shared: true name: "Список покупок" lists: - "Продукты" - "Домашние дела"members: - id: alice role: admin modules: [calendar, tasks] - id: bob role: member modules: [calendar, tasks] - id: grandma role: viewer modules: [calendar]
Права проверяются на каждое действие. Бабушка не может удалить событие. Ребёнок не может изменить состав семьи. Нода ведёт аудит-лог: кто что сделал и когда.
Слой 3: Синхронизация
Личные узлы общаются с нодой по защищённому каналу. Протокол простой: push/pull.
Пользователь создал задачу → изменение ушло на ноду. Нода приняла, проверила права, сохранила, разослала остальным участникам. Если участник был оффлайн — он получит изменения при reconnect.
Синхронизация работает по принципу «звезда»: все общаются через ноду. Не P2P между участниками напрямую. Почему:
-
Нода всегда онлайн (или доступна, когда нужна синхронизация)
-
Нода — единый источник прав
-
Нода хранит полную историю изменений и делает бэкапы
-
Для семьи из 5 человек или команды из 20 задержка «звезды» незаметна
Данные шифруются в покое и при передаче. Ключи хранятся на ноде и выдаются только авторизованным участникам.
Модули и их двойная природа
У каждого модуля два пространства. Локальное — только моё. И общее — то, что синхронизируется с нодой.
В интерфейсе календаря Алиса видит:
-
Свои личные события (йога в 8:00, визит к врачу)
-
События семейной ноды (день рождения мамы, субботний ужин)
-
События рабочей ноды (стендап в 10:00, дедлайн проекта)
Всё в одном окне, но с цветовым разделением: синий — личное, зелёный — семья, оранжевый — работа. Данные не смешиваются. Семейный сервер не видит рабочих событий. Рабочий сервер не видит семейных.
Один интерфейс. Чёткие границы.
AI-агент с доступом ко всем модулям
Отдельный Python-процесс живёт рядом с ядром. Это не облачный сервис — модель работает локально. Она видит данные всех подключённых модулей: календари, задачи, заметки, письма.
Что это даёт: AI может действовать кросс-модульно. «Найди заметки про проект X, проверь календарь на следующую неделю и предложи слоты для созвона». «Прочитай вчерашние письма от клиента, создай задачи по каждому поручению и поставь дедлайны в календарь».
Такого нет ни в Битрикс24 с его CoPilot (он заточен под CRM-сценарии), ни в Яндекс 360 (там AI — это расшифровка звонков и суммаризация писем). Здесь у агента сквозной доступ ко всем данным, включая личные заметки и семейный календарь.
Стек
-
Rust-ядро: tokio, rusqlite, tonic (gRPC), serde. Управление модулями, шина событий, сетевая подсистема, синхронизация.
-
Electron + React: оболочка, система UI-слотов, виджеты модулей.
-
Python (AI sidecar): FastAPI + локальные модели или API OpenAI. Семантический поиск, NLP-команды, умные предложения.
Один репозиторий. Один бинарник на выходе. Флаг --mode определяет поведение.
Сравнение с существующими решениями
|
Критерий |
Наша система |
Битрикс24 |
Мегаплан |
Яндекс 360 |
Obsidian |
|---|---|---|---|---|---|
|
Модульность |
Сборка под пользователя |
Монолит (CRM+задачи+чат+…) |
Монолит (CRM+задачи+доки) |
Почта+диск+календарь+мессенджер |
Ядро + плагины |
|
Развёртывание |
Свой сервер или ПК |
Облако / коробка |
Облако |
Облако |
Локально |
|
Offline-first |
Да |
Нет (ограниченный кеш) |
Нет |
Нет |
Да |
|
Семейные сценарии |
Из коробки |
Нет |
Нет |
Нет |
Только личное |
|
Подключение к нескольким организациям |
Да, несколько нод |
Один портал |
Один портал |
Один домен |
Нет |
|
Кастомизация модулей |
Свои модули на Rust |
Приложения в маркетплейсе |
API |
Нет |
Community-плагины |
|
AI с кросс-модульным доступом |
Да |
CoPilot (только CRM) |
Нет |
Суммаризация писем |
Через плагины (ограниченно) |
|
Данные под вашим контролем |
Полностью |
Только в коробке |
Нет |
Нет |
Да |
Главное отличие: существующие решения — это продукты «для компании» или «для человека». Наша система — это конструктор, который собирается под форму организации. Компания, семья, клуб, штаб — неважно. Вы решаете, какие модули нужны и где хранятся данные.
Что собрано на сейчас
MVP проходит внутреннее тестирование. На этом этапе работает:
-
Локальное ядро с EventBus и регистрацией модулей
-
Модули Заметок и Задач (создание, редактирование, поиск)
-
Запуск приложения в режиме ноды (headless)
-
Протокол синхронизации push/pull между личным узлом и нодой
-
Базовая система прав (роли admin, member, viewer)
-
Приглашения по коду доступа
В ближайших спринтах:
-
Модуль Календаря с синхронизацией
-
AI-агент с доступом к модулям
-
Шифрование данных на ноде
-
Веб-админка для управления нодой
Открытые вопросы — и здесь нужно мнение сообщества
Мы подошли к этапу, где архитектурные решения пора обсуждать с теми, кто в теме. Вот что нас волнует прямо сейчас.
1. Протокол синхронизации
Сейчас у нас простая pull/push-модель через gRPC. Этого хватает для небольших групп. Но что делать с конфликтами при одновременном редактировании? Два варианта:
-
CRDT (Conflict-free Replicated Data Types). Автоматическое разрешение конфликтов без арбитра. Плюс: настоящий offline-first, изменения сливаются корректно при любом порядке. Минус: сложность реализации, особенно для календаря (перемещение события — это не вставка символа в текст).
-
Last-write-wins с историей. Нода принимает изменения и при конфликте сохраняет более позднее, но хранит историю. Плюс: проще. Минус: возможна потеря данных при реальном конфликте.
Что выбрали бы вы для бизнес-модулей вроде календаря и задач? CRDT или достаточно LWW с возможностью ручного отката?
2. Одна нода или федерация
Сейчас архитектура предполагает, что семейная нода и рабочая нода — это разные экземпляры приложения. Они не общаются между собой. Пользователь подключается к нескольким нодам независимо.
Есть альтернатива: федерация нод. Ноды могут обмениваться данными, если администраторы это разрешили. Например, семейный календарь может показать свободные слоты рабочему календарю — без раскрытия деталей событий.
Нужна ли федерация? Или независимые ноды — достаточная модель для реальных сценариев?
3. Права доступа: детализация
Сейчас роли грубые: админ, участник, наблюдатель. Внутри модуля — права на чтение, запись, удаление, администрирование.
Этого достаточно для семьи. Для компании, вероятно, нужна более тонкая настройка: доступ к конкретному проекту, к конкретному календарю, временные права, права на приглашение новых участников.
Насколько детальной должна быть система прав в минимально жизнеспособной версии? Что критично иметь с первого дня, а что можно отложить?
4. Хранение данных на ноде
Сейчас нода хранит всё в SQLite. Для семьи из пяти человек с календарём и списком покупок — ОК. Для компании из 200 человек с вики, задачами и файлами — нет.
Когда нужна нормальная СУБД? Достаточно ли SQLite с WAL-режимом для первых реальных пользователей? Или сразу закладывать PostgreSQL и S3-совместимое хранилище для файлов?
Зачем это всё
Рынок инструментов продуктивности поделён. Одиночки выбирают между Obsidian, Notion, Todoist. Компании в России — между Битрикс24, Мегапланом, Яндекс 360. Но между «я» и «корпорация» — пустота.
Семьи, клубы, волонтёрские штабы, соседские сообщества, маленькие команды — у них нет инструмента. Они вынуждены использовать либо личные приложения (и страдать без общих данных), либо корпоративные комбайны (и страдать от избыточности).
Мы хотим закрыть эту дыру. Дать людям инструмент, который:
-
Собирается под них, а не наоборот
-
Не привязан к чужому облаку
-
Позволяет создать общее пространство без регистрации в десяти сервисах
-
Работает на их оборудовании — от мощного сервера до Raspberry Pi в кладовке
MVP готов и проходит тестирование. Сейчас критически важно услышать мнение сообщества по архитектурным вопросам выше. Потому что дальше — развилки, и свернуть не туда будет дорого.
Если тема близка — добро пожаловать в комментарии. Интересны инженерные мнения, конструктивная критика, реальный опыт похожих систем. Открыты к сотрудничеству с теми, кто хочет покопаться в коде или помочь с развитием.
P.S. Репозиторий готовим к публикации. Пока можно писать в личку на Хабре или в комментарии — вышлю приглашение в закрытую бету.
ссылка на оригинал статьи https://habr.com/ru/articles/1036722/