Приложения 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 на этапе сборки и формирует манифест — полное описание того, что ваше приложение добавляет в рабочее пространство. Эти функции проверяют вашу конфигурацию на этапе сборки и обеспечивают автодополнение в IDE и безопасность типов.
Организация файлов — на ваше усмотрение. Обнаружение сущностей основано на AST — SDK находит вызовы
export default defineEntity(...) независимо от расположения файла. Структура папок выше — это соглашение, а не требование.Типы сущностей
| Сущность | Назначение | Документация |
|---|---|---|
| Приложение | Идентификация приложения, роль по умолчанию, переменные | Конфигурация приложения |
| Роль | Наборы прав для объектов и полей | Роли и разрешения |
| Объект | Пользовательские типы записей с полями | Объекты |
| Поле | Добавляйте поля к объектам из других приложений | Расширение объектов |
| Связь | Двунаправленные связи между объектами | Связи |
| Логическая функция | Серверный TypeScript с триггерами | Логические функции |
| Навык | Повторно используемые инструкции для ИИ-агента | Навыки и агенты |
| Агент | ИИ-агенты с пользовательскими промптами | Навыки и агенты |
| Провайдер подключения | Учётные данные OAuth для сторонних API | Подключения |
| Представление | Преднастроенные представления списков записей | Представления |
| Пункт меню навигации | Пользовательские элементы боковой панели | Элементы меню навигации |
| Макет страницы | Вкладки и виджеты на странице сведений о записи | Макеты страниц |
| Компонент фронтенда | Изолированный в песочнице интерфейс React внутри Twenty | Компоненты фронтенда |
| Элемент меню команд | Быстрые действия и элементы Cmd+K | Элементы меню команд |
Изоляция в песочнице
- Логические функции выполняются в изолированных процессах 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 и формирует манифест.- Хуки до/после установки — необязательные функции, которые выполняются во время установки. См. раздел Install Hooks для подробностей.
Следующие шаги
Конфигурация
Идентификация приложения, роль по умолчанию и хуки установки.
Данные
Объекты, поля и двунаправленные связи.
Логика
Логические функции, навыки, агенты и OAuth-подключения.
Макет
Представления, навигация, макеты страниц, фронтенд-компоненты.
Операции
CLI, тестирование, удаленные окружения, CI и публикация вашего приложения.