Utilizați resursele SDK (tipuri și configurare)
Biblioteca twenty-sdk oferă blocuri de bază tipizate și funcții ajutătoare pe care le utilizați în aplicația dvs. Mai jos sunt elementele cheie cu care veți interacționa cel mai des.Funcții ajutătoare
SDK-ul oferă funcții ajutătoare pentru definirea entităților aplicației. După cum este descris în Detectarea entităților, trebuie să folosițiexport default define<Entity>({...}) pentru ca entitățile să fie detectate:
| Funcție | Scop |
|---|---|
defineApplication | Configurați metadatele aplicației (obligatoriu, una per aplicație) |
defineObject | Definiți obiecte personalizate cu câmpuri |
defineLogicFunction | Definiți funcții de logică cu handleri |
definePreInstallLogicFunction | Definește o funcție logică de pre-instalare (una per aplicație) |
definePostInstallLogicFunction | Definește o funcție logică post-instalare (una per aplicație) |
defineFrontComponent | Definiți componente Front pentru interfața de utilizator personalizată |
defineRole | Configurați permisiunile rolurilor și accesul la obiecte |
defineField | Extindeți obiectele existente cu câmpuri suplimentare |
defineView | Definește vizualizări salvate pentru obiecte |
defineNavigationMenuItem | Definește linkuri de navigare în bara laterală |
defineSkill | Definiți abilități pentru agentul AI |
Definirea obiectelor
Obiectele personalizate descriu atât schema, cât și comportamentul înregistrărilor din spațiul dvs. de lucru. UtilizațidefineObject() pentru a defini obiecte cu validare încorporată:
- Folosiți
defineObject()pentru validare încorporată și suport mai bun în IDE. universalIdentifiertrebuie să fie unic și stabil între implementări.- Fiecare câmp necesită un
name, untype, unlabelși propriuluniversalIdentifierstabil. - Matricea
fieldseste opțională — puteți defini obiecte fără câmpuri personalizate. - Puteți genera obiecte noi folosind
yarn twenty entity:add, care vă ghidează prin denumire, câmpuri și relații.
Câmpurile de bază sunt create automat. Când definiți un obiect personalizat, Twenty adaugă automat câmpuri standard
precum
id, name, createdAt, updatedAt, createdBy, updatedBy și deletedAt.
Nu trebuie să le definiți în tabloul fields — adăugați doar câmpurile personalizate proprii.
Puteți suprascrie câmpurile implicite definind un câmp cu același nume în tabloul fields,
dar acest lucru nu este recomandat.Configurația aplicației (application-config.ts)
Fiecare aplicație are un singur fișierapplication-config.ts care descrie:
- Cine este aplicația: identificatori, nume de afișare și descriere.
- Cum rulează funcțiile: ce rol folosesc pentru permisiuni.
- (Opțional) variabile: perechi cheie–valoare expuse funcțiilor ca variabile de mediu.
- (Opțional) funcție de pre-instalare: o funcție logică care rulează înainte ca aplicația să fie instalată.
- (Opțional) funcție post-instalare: o funcție logică care rulează după instalarea aplicației.
defineApplication() pentru a defini configurația aplicației:
- Câmpurile
universalIdentifiersunt ID-uri deterministe pe care le dețineți; generați-le o singură dată și păstrați-le stabile între sincronizări. applicationVariablesdevin variabile de mediu pentru funcțiile dvs. (de exemplu,DEFAULT_RECIPIENT_NAMEeste disponibil caprocess.env.DEFAULT_RECIPIENT_NAME).defaultRoleUniversalIdentifiertrebuie să corespundă fișierului de rol (vedeți mai jos).- Funcțiile de pre-instalare și post-instalare sunt detectate automat în timpul construirii manifestului. Vezi Funcții de pre-instalare și Funcții post-instalare.
Roluri și permisiuni
Aplicațiile pot defini roluri care încapsulează permisiuni asupra obiectelor și acțiunilor din spațiul dvs. de lucru. CâmpuldefaultRoleUniversalIdentifier din application-config.ts desemnează rolul implicit utilizat de funcțiile de logică ale aplicației.
- Cheia API de runtime injectată ca
TWENTY_API_KEYeste derivată din acest rol implicit pentru funcții. - Clientul tipizat va fi restricționat la permisiunile acordate acelui rol.
- Respectați principiul celui mai mic privilegiu: creați un rol dedicat doar cu permisiunile de care au nevoie funcțiile, apoi referiți identificatorul său universal.
Rol implicit pentru funcții (*.role.ts)
Când generați o aplicație nouă, CLI creează și un fișier de rol implicit. FolosițidefineRole() pentru a defini roluri cu validare încorporată:
universalIdentifier al acestui rol este apoi referențiat în application-config.ts ca defaultRoleUniversalIdentifier. Cu alte cuvinte:
- *.role.ts definește ce poate face rolul implicit pentru funcții.
- application-config.ts indică acel rol, astfel încât funcțiile moștenesc permisiunile lui.
- Porniți de la rolul generat, apoi restrângeți-l progresiv urmând principiul celui mai mic privilegiu.
- Înlocuiți
objectPermissionsșifieldPermissionscu obiectele/câmpurile de care au nevoie funcțiile. permissionFlagscontrolează accesul la capabilități la nivelul platformei. Mențineți-le la minimum; adăugați doar ceea ce aveți nevoie.- Vedeți un exemplu funcțional în aplicația Hello World:
packages/twenty-apps/hello-world/src/roles/function-role.ts.
Configurația funcției de logică și punctul de intrare
Fiecare fișier de funcție foloseștedefineLogicFunction() pentru a exporta o configurație cu un handler și declanșatoare opționale.
- route: Expune funcția pe o rută și metodă HTTP sub endpoint-ul
/s/:
de ex.path: '/post-card/create',-> apel pe<APP_URL>/s/post-card/create
- cron: Rulează funcția pe un program folosind o expresie CRON.
- databaseEvent: Rulează la evenimentele ciclului de viață ale obiectelor din spațiul de lucru. Când operațiunea evenimentului este
updated, câmpurile specifice de urmărit pot fi specificate în array-ulupdatedFields. Dacă este lăsat nedefinit sau gol, orice actualizare va declanșa funcția.
de ex. person.updated
Notițe:
- Matricea
triggerseste opțională. Funcțiile fără declanșatoare pot fi folosite ca funcții utilitare apelate de alte funcții. - Puteți combina mai multe tipuri de declanșatoare într-o singură funcție.
Funcții de pre-instalare
O funcție de pre-instalare este o funcție logică ce rulează automat înainte ca aplicația ta să fie instalată într-un spațiu de lucru. Aceasta este utilă pentru sarcini de validare, verificări ale condițiilor prealabile sau pregătirea stării spațiului de lucru înainte ca instalarea principală să continue. Când creezi scheletul unei aplicații noi cucreate-twenty-app, ți se generează o funcție de pre-instalare la src/logic-functions/pre-install.ts:
- Funcțiile de pre-instalare folosesc
definePreInstallLogicFunction()— o variantă specializată care omite setările de declanșare (cronTriggerSettings,databaseEventTriggerSettings,httpRouteTriggerSettings,isTool). - Handlerul primește un
InstallLogicFunctionPayloadcu{ previousVersion: string }— versiunea aplicației care a fost instalată anterior (sau un șir gol pentru instalări noi). - Este permisă o singură funcție de pre-instalare per aplicație. Construirea manifestului va genera o eroare dacă este detectată mai mult de una.
- Proprietatea
universalIdentifiera funcției este setată automat capreInstallLogicFunctionUniversalIdentifierîn manifestul aplicației în timpul build-ului — nu este nevoie să o referi îndefineApplication(). - Timpul de expirare implicit este setat la 300 de secunde (5 minute) pentru a permite sarcini de pregătire mai lungi.
- Funcțiile de pre-instalare nu au nevoie de declanșatoare — sunt invocate de platformă înainte de instalare sau manual prin
function:execute --preInstall.
Funcții post-instalare
O funcție post-instalare este o funcție logică care rulează automat după instalarea aplicației într-un spațiu de lucru. Aceasta este utilă pentru sarcini de configurare unice, cum ar fi popularea cu date implicite, crearea înregistrărilor inițiale sau configurarea setărilor spațiului de lucru. Când creezi scheletul unei aplicații noi cucreate-twenty-app, este generată o funcție post-instalare la src/logic-functions/post-install.ts:
- Funcțiile de post-instalare folosesc
definePostInstallLogicFunction()— o variantă specializată care omite setările de declanșare (cronTriggerSettings,databaseEventTriggerSettings,httpRouteTriggerSettings,isTool). - Handlerul primește un
InstallLogicFunctionPayloadcu{ previousVersion: string }— versiunea aplicației care a fost instalată anterior (sau un șir gol pentru instalări noi). - Este permisă o singură funcție de post-instalare per aplicație. Construirea manifestului va genera o eroare dacă este detectată mai mult de una.
- Proprietatea
universalIdentifiera funcției este setată automat capostInstallLogicFunctionUniversalIdentifierîn manifestul aplicației în timpul build-ului — nu este nevoie să o referi îndefineApplication(). - Timpul de expirare implicit este setat la 300 de secunde (5 minute) pentru a permite sarcini de configurare mai lungi, cum ar fi popularea datelor.
- Funcțiile post-instalare nu au nevoie de declanșatoare — sunt invocate de platformă în timpul instalării sau manual prin
function:execute --postInstall.
Payload-ul declanșatorului de rută
Când un declanșator de rută apelează funcția dvs. de logică, aceasta primește un obiectRoutePayload care urmează formatul AWS HTTP API v2. Importă tipul din twenty-sdk:
RoutePayload are următoarea structură:
| Proprietate | Tip | Descriere |
|---|---|---|
headers | Record<string, string | undefined> | Anteturi HTTP (doar cele listate în forwardedRequestHeaders) |
queryStringParameters | Record<string, string | undefined> | Parametri query string (valorile multiple unite cu virgule) |
pathParameters | Record<string, string | undefined> | Parametri de cale extrași din modelul rutei (de ex., /users/:id → { id: '123' }) |
body | object | null | Corpul cererii analizat (JSON) |
isBase64Encoded | boolean | Indică dacă corpul este codificat în base64 |
requestContext.http.method | string | Metoda HTTP (GET, POST, PUT, PATCH, DELETE) |
requestContext.http.path | string | Calea brută a cererii |
Transmiterea anteturilor HTTP
În mod implicit, anteturile HTTP din cererile de intrare nu sunt transmise funcției dvs. de logică din motive de securitate. Pentru a accesa anumite anteturi, listează-le explicit în array-ulforwardedRequestHeaders:
Numele anteturilor sunt normalizate la litere mici. Accesează-le folosind chei cu litere mici (de exemplu,
event.headers['content-type']).- Generat: Rulați
yarn twenty entity:addși alegeți opțiunea de a adăuga o funcție logică nouă. Aceasta generează un fișier inițial cu un handler și o configurație. - Manual: Creați un fișier nou
*.logic-function.tsși folosițidefineLogicFunction(), urmând același model.
Marcarea unei funcții logice drept instrument
Funcțiile logice pot fi expuse ca instrumente pentru agenți de IA și fluxuri de lucru. Când o funcție este marcată ca instrument, poate fi descoperită de funcționalitățile de IA ale Twenty și poate fi selectată ca pas în automatizări ale fluxurilor de lucru. Pentru a marca o funcție logică drept instrument, setațiisTool: true și furnizați un toolInputSchema care descrie parametrii de intrare așteptați folosind JSON Schema:
isTool(boolean, implicit:false): Când este setat latrue, funcția este înregistrată ca instrument și devine disponibilă pentru agenții AI și automatizările de fluxuri de lucru.toolInputSchema(object, opțional): Un obiect JSON Schema care descrie parametrii pe care îi acceptă funcția dvs. Agenții AI folosesc această schemă pentru a înțelege ce intrări așteaptă instrumentul și pentru a valida apelurile. Dacă este omisă, schema are implicit valoarea{ type: 'object', properties: {} }(fără parametri).- Funcțiile cu
isTool: false(sau nedefinit) nu sunt expuse ca instrumente. Pot totuși fi executate direct sau apelate de alte funcții, dar nu vor apărea în descoperirea instrumentelor. - Denumierea instrumentelor: Când este expusă ca instrument, denumirea funcției este normalizată automat la
logic_function_<name>(convertită la litere mici, iar caracterele non-alfanumerice sunt înlocuite cu caractere de subliniere). De exemplu,enrich-companydevinelogic_function_enrich_company. - Puteți combina
isToolcu declanșatoare — o funcție poate fi atât un instrument (apelabilă de agenții AI), cât și declanșată de evenimente (cron, evenimente de bază de date, rute) în același timp.
Scrieți o
description bună. Agenții AI se bazează pe câmpul description al funcției pentru a decide când să folosească instrumentul. Fiți specifici cu privire la ceea ce face instrumentul și când ar trebui apelat.Componente Front
Componentele Front vă permit să construiți componente React personalizate care sunt randate în interfața Twenty. UtilizațidefineFrontComponent() pentru a defini componente cu validare încorporată:
- Componentele Front sunt componente React care sunt randate în contexte izolate în cadrul Twenty.
- Câmpul
componentface referire la componenta React. - Componentele sunt construite și sincronizate automat în timpul
yarn twenty app:dev.
- Generat: Rulați
yarn twenty entity:addși alegeți opțiunea de a adăuga o componentă frontend nouă. - Manual: Creați un fișier nou
.tsxși folosițidefineFrontComponent(), urmând același model.
Abilități
Abilitățile definesc instrucțiuni și capabilități reutilizabile pe care agenții AI le pot folosi în spațiul dvs. de lucru. FolosițidefineSkill() pentru a defini abilități cu validare încorporată:
nameeste un șir identificator unic pentru abilitate (se recomandă kebab-case).labeleste numele lizibil afișat în interfața cu utilizatorul (UI).contentconține instrucțiunile abilității — acesta este textul pe care agentul AI îl folosește.icon(opțional) setează pictograma afișată în UI.description(opțional) oferă context suplimentar despre scopul abilității.
- Generat: Rulați
yarn twenty entity:addși alegeți opțiunea de a adăuga o abilitate nouă. - Manual: Creați un fișier nou și folosiți
defineSkill(), urmând același model.
Clienți tipizați generați
Doi clienți tipizați sunt generați automat deyarn twenty app:dev și stocați în node_modules/twenty-sdk/generated, pe baza schemei spațiului tău de lucru:
CoreApiClient— interoghează endpointul/graphqlpentru datele spațiului de lucruMetadataApiClient— interoghează endpointul/metadatapentru configurarea spațiului de lucru și încărcarea fișierelor
yarn twenty app:dev ori de câte ori obiectele sau câmpurile tale se schimbă.
Acreditări la runtime în funcțiile de logică
Când funcția rulează pe Twenty, platforma injectează acreditări ca variabile de mediu înainte de execuția codului:TWENTY_API_URL: URL-ul de bază al API-ului Twenty către care țintește aplicația.TWENTY_API_KEY: Cheie cu durată scurtă, limitată la rolul implicit de funcție al aplicației.
- Nu trebuie să transmiteți URL-ul sau cheia API către clientul generat. Acesta citește
TWENTY_API_URLșiTWENTY_API_KEYdin process.env la runtime. - Permisiunile cheii API sunt determinate de rolul referențiat în
application-config.tsprindefaultRoleUniversalIdentifier. Acesta este rolul implicit folosit de funcțiile de logică ale aplicației. - Aplicațiile pot defini roluri pentru a urma principiul celui mai mic privilegiu. Acordați doar permisiunile de care au nevoie funcțiile, apoi setați
defaultRoleUniversalIdentifierla identificatorul universal al acelui rol.
Încărcarea fișierelor
ClientulMetadataApiClient generat include o metodă uploadFile pentru atașarea fișierelor la câmpuri de tip fișier ale obiectelor din spațiul tău de lucru. Deoarece clienții GraphQL standard nu acceptă în mod nativ încărcarea fișierelor multipart, clientul oferă această metodă dedicată care implementează, sub capotă, specificația cererilor GraphQL multipart.
| Parametru | Tip | Descriere |
|---|---|---|
fileBuffer | Buffer | Conținutul brut al fișierului |
filename | string | Numele fișierului (folosit pentru stocare și afișare) |
contentType | string | Tipul MIME al fișierului (are valoarea implicită application/octet-stream dacă este omis) |
fieldMetadataUniversalIdentifier | string | universalIdentifier al câmpului de tip fișier de pe obiectul tău |
- Metoda
uploadFileeste disponibilă peMetadataApiClientdeoarece mutația de încărcare este rezolvată de endpointul/metadata. - Folosește
universalIdentifieral câmpului (nu ID-ul specific spațiului de lucru), astfel încât codul tău de încărcare funcționează în orice spațiu de lucru în care aplicația ta este instalată — în concordanță cu modul în care aplicațiile fac referire la câmpuri în rest. urlreturnat este un URL semnat pe care îl poți folosi pentru a accesa fișierul încărcat.