Перейти к основному содержанию

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.

Приложения Twenty — это пакеты TypeScript, которые расширяют ваше рабочее пространство пользовательскими объектами, логикой, компонентами интерфейса и возможностями ИИ. Они работают на платформе Twenty с полной изоляцией в песочнице и контролем прав доступа.

Как работают приложения

Приложение — это набор сущностей, объявленных с помощью функций defineEntity() из пакета twenty-sdk. SDK обнаруживает эти объявления посредством анализа AST на этапе сборки и формирует манифест — полное описание того, что ваше приложение добавляет в рабочее пространство.
your-app/
├── src/
│   ├── application-config.ts    ← defineApplication (required, one per app)
│   ├── roles/                   ← defineRole
│   ├── objects/                 ← defineObject
│   ├── fields/                  ← defineField
│   ├── logic-functions/         ← defineLogicFunction
│   ├── front-components/        ← defineFrontComponent
│   ├── skills/                  ← defineSkill
│   ├── agents/                  ← defineAgent
│   ├── views/                   ← defineView
│   ├── navigation-menu-items/   ← defineNavigationMenuItem
│   └── page-layouts/            ← definePageLayout
├── public/                      ← Static assets (images, icons)
└── package.json
Организация файлов — на ваше усмотрение. Обнаружение сущностей основано на 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().

Жизненный цикл приложения

┌─────────────────────────────────────────────────────────┐
│ Development                                             │
│   npx create-twenty-app → yarn twenty dev (live sync)   │
├─────────────────────────────────────────────────────────┤
│ Build & Deploy                                          │
│   yarn twenty build → yarn twenty deploy                │
├─────────────────────────────────────────────────────────┤
│ Install flow                                            │
│   upload → [pre-install] → metadata migration →         │
│   generate SDK → [post-install]                         │
├─────────────────────────────────────────────────────────┤
│ Publish                                                 │
│   npm publish → appears in Twenty marketplace           │
└─────────────────────────────────────────────────────────┘
  • yarn twenty dev — следит за исходными файлами и синхронизирует изменения в реальном времени с подключённым сервером Twenty. Типизированный клиент API автоматически пересоздаётся при изменении схемы.
  • yarn twenty build — компилирует TypeScript, упаковывает логические функции и фронтенд-компоненты с помощью esbuild и формирует манифест.
  • Хуки до/после установки — необязательные логические функции, которые выполняются во время установки. См. Логические функции для подробностей.

Следующие шаги

Модель данных

Определяйте объекты, поля, роли и связи.

Логические функции

Серверные функции с HTTP-, cron- и событийными триггерами.

Компоненты фронтенда

Изолированные в песочнице компоненты React внутри интерфейса Twenty.

Макет

Представления, пункты навигации и макеты страниц записей.

Навыки и агенты

ИИ-навыки и агенты с пользовательскими промптами.

CLI и тестирование

Команды CLI, тестирование, ассеты, удалённые модули и CI.

Публикация

Разверните на сервере или опубликуйте в маркетплейсе.