Приложения Twenty — это пакеты TypeScript, которые расширяют ваше рабочее пространство пользовательскими объектами, логикой, компонентами интерфейса и возможностями ИИ. Они работают на платформе Twenty с полной изоляцией в песочнице и контролем прав доступа.Documentation Index
Fetch the complete documentation index at: https://docs.twenty.com/llms.txt
Use this file to discover all available pages before exploring further.
Как работают приложения
Приложение — это набор сущностей, объявленных с помощью функцийdefineEntity() из пакета twenty-sdk. SDK обнаруживает эти объявления посредством анализа AST на этапе сборки и формирует манифест — полное описание того, что ваше приложение добавляет в рабочее пространство.
Организация файлов — на ваше усмотрение. Обнаружение сущностей основано на AST — SDK находит вызовы
export default defineEntity(...) независимо от расположения файла. Структура папок выше — это соглашение, а не требование.Типы сущностей
| Сущность | Назначение | Документация |
|---|---|---|
| Приложение | Идентификация приложения, права доступа, переменные | Модель данных |
| Роль | Наборы прав для объектов и полей | Модель данных |
| Object | Пользовательские таблицы данных с полями | Модель данных |
| Поле | Расширение существующих объектов, определение связей | Модель данных |
| Логическая функция | Серверный TypeScript с триггерами | Логические функции |
| Компонент фронтенда | Изолированный в песочнице интерфейс React на странице Twenty | Компоненты фронтенда |
| Навык | Повторно используемые инструкции для ИИ-агента | Навыки и агенты |
| Агент | ИИ-агенты с пользовательскими промптами | Навыки и агенты |
| Представление | Преднастроенные представления списков записей | Макет |
| Пункт меню навигации | Пользовательские элементы боковой панели | Макет |
| Макет страницы | Пользовательские вкладки и виджеты страницы записи | Макет |
Изоляция в песочнице
- Логические функции выполняются в изолированных процессах Node.js на сервере. Они получают доступ к данным только через типизированный клиент API, ограниченный правами роли приложения.
- Компоненты фронтенда запускаются в Web Workers с использованием Remote DOM — изолированы от основной страницы, но при этом рендерят нативные элементы DOM (не iframes). Они взаимодействуют с Twenty через хостовый API обмена сообщениями.
- Права доступа применяются на уровне API. Токен времени выполнения (
TWENTY_APP_ACCESS_TOKEN) выводится из роли, определённой вdefineApplication().
Жизненный цикл приложения
yarn twenty dev— следит за исходными файлами и синхронизирует изменения в реальном времени с подключённым сервером Twenty. Типизированный клиент API автоматически пересоздаётся при изменении схемы.yarn twenty build— компилирует TypeScript, упаковывает логические функции и фронтенд-компоненты с помощью esbuild и формирует манифест.- Хуки до/после установки — необязательные логические функции, которые выполняются во время установки. См. Логические функции для подробностей.
Следующие шаги
Модель данных
Определяйте объекты, поля, роли и связи.
Логические функции
Серверные функции с HTTP-, cron- и событийными триггерами.
Компоненты фронтенда
Изолированные в песочнице компоненты React внутри интерфейса Twenty.
Макет
Представления, пункты навигации и макеты страниц записей.
Навыки и агенты
ИИ-навыки и агенты с пользовательскими промптами.
CLI и тестирование
Команды CLI, тестирование, ассеты, удалённые модули и CI.
Публикация
Разверните на сервере или опубликуйте в маркетплейсе.