Logic functions are server-side TypeScript functions that run on the Twenty platform. They can be triggered by HTTP requests, cron schedules, or database events — and can also be exposed as tools for AI agents.Documentation Index
Fetch the complete documentation index at: https://docs.get-clara.tech/llms.txt
Use this file to discover all available pages before exploring further.
defineLogicFunction
Definisci funzioni logiche e i relativi trigger
defineLogicFunction
Definisci funzioni logiche e i relativi trigger
defineLogicFunction() per esportare una configurazione con un handler e trigger opzionali.- httpRoute: Espone la tua funzione su un percorso e metodo HTTP sotto l’endpoint
/s/:
ad es.path: '/post-card/create'è invocabile suhttps://your-twenty-server.com/s/post-card/create
- cron: Esegue la tua funzione secondo una pianificazione utilizzando un’espressione CRON.
- databaseEvent: Viene eseguito sugli eventi del ciclo di vita degli oggetti dello spazio di lavoro. Quando l’operazione dell’evento è
updated, è possibile specificare campi specifici da monitorare nell’arrayupdatedFields. Se lasciato non definito o vuoto, qualsiasi aggiornamento attiverà la funzione.
ad es.person.updated,*.created,company.*
Payload del trigger di route
Quando un trigger di tipo route invoca la tua funzione logica, questa riceve un oggettoRoutePayload che segue il formato AWS HTTP API v2.
Importa il tipo RoutePayload da twenty-sdk:RoutePayload ha la seguente struttura:| Proprietà | Tipo | Descrizione | Esempio |
|---|---|---|---|
headers | Record\<string, string | undefined> | Intestazioni HTTP (solo quelle elencate in forwardedRequestHeaders) | vedi la sezione sotto |
queryStringParameters | Record\<string, string | undefined> | Parametri della query string (valori multipli uniti da virgole) | /users?ids=1&ids=2&ids=3&name=Alice -> { ids: '1,2,3', name: 'Alice' } |
pathParameters | Record\<string, string | undefined> | Parametri di percorso estratti dal pattern della route | /users/:id, /users/123 -> { id: '123' } |
body | object | null | Corpo della richiesta analizzato (JSON) | { id: 1 } -> { id: 1 } |
isBase64Encoded | boolean | Indica se il corpo è codificato in base64 | |
requestContext.http.method | string | Metodo HTTP (GET, POST, PUT, PATCH, DELETE) | |
requestContext.http.path | string | Percorso della richiesta non elaborato |
forwardedRequestHeaders
Per impostazione predefinita, le intestazioni HTTP delle richieste in ingresso non vengono passate alla tua funzione logica per motivi di sicurezza. Per accedere a intestazioni specifiche, elencale nell’arrayforwardedRequestHeaders:event.headers['content-type']).Esporre una funzione come strumento
Le funzioni logiche possono essere esposte come strumenti per gli agenti di IA e i flussi di lavoro. Quando una funzione è contrassegnata come strumento, diventa individuabile dalle funzionalità di IA di Twenty e può essere utilizzata nelle automazioni dei flussi di lavoro.Per contrassegnare una funzione logica come strumento, impostaisTool: true:- Puoi combinare
isToolcon i trigger — una funzione può essere sia uno strumento (invocabile dagli agenti IA) sia attivata da eventi allo stesso tempo. toolInputSchema(opzionale): un oggetto JSON Schema che descrive i parametri accettati dalla funzione. Lo schema viene calcolato automaticamente dall’analisi statica del codice sorgente, ma puoi impostarlo esplicitamente:
description. Gli agenti IA fanno affidamento sul campo description della funzione per decidere quando usare lo strumento. Sii specifico su cosa fa lo strumento e quando dovrebbe essere invocato.definePostInstallLogicFunction
Definisci una funzione logica di post-installazione (una per app)
definePostInstallLogicFunction
Definisci una funzione logica di post-installazione (una per app)
- Le funzioni di post-installazione utilizzano
definePostInstallLogicFunction()— una variante specializzata che omette le impostazioni dei trigger (cronTriggerSettings,databaseEventTriggerSettings,httpRouteTriggerSettings,isTool). - L’handler riceve un
InstallPayloadcon{ previousVersion?: string; newVersion: string }—newVersionè la versione in fase di installazione epreviousVersionè la versione installata in precedenza (oppureundefinedin caso di nuova installazione). Usa questi valori per distinguere le nuove installazioni dagli aggiornamenti e per eseguire logiche di migrazione specifiche per versione. - Quando viene eseguito l’hook: solo sulle nuove installazioni, per impostazione predefinita. Passa
shouldRunOnVersionUpgrade: truese vuoi che venga eseguito anche quando l’app viene aggiornata da una versione precedente. Se omesso, il flag èfalseper impostazione predefinita e gli aggiornamenti saltano l’hook. - Modello di esecuzione — asincrono per impostazione predefinita, sincrono su richiesta: il flag
shouldRunSynchronouslycontrolla come viene eseguito il post-install.shouldRunSynchronously: false(default) — l’hook viene messo in coda nella coda dei messaggi conretryLimit: 3ed eseguito in modo asincrono in un worker. La risposta di installazione viene restituita non appena il job è messo in coda, quindi un handler lento o in errore non blocca il chiamante. Il worker riproverà fino a tre volte. Usalo per job di lunga durata — popolamento di dataset di grandi dimensioni, chiamate a API di terze parti lente, provisioning di risorse esterne, qualsiasi cosa che possa superare una finestra di risposta HTTP ragionevole.shouldRunSynchronously: true— l’hook viene eseguito inline durante il flusso di installazione (stesso executor del pre-install). La richiesta di installazione rimane bloccata finché l’handler non termina e, se genera un’eccezione, il chiamante dell’installazione riceve unPOST_INSTALL_ERROR. Nessun tentativo automatico. Usalo per attività rapide che devono completarsi prima della risposta — ad esempio, emettere un errore di validazione all’utente, oppure un setup rapido di cui il client avrà bisogno immediatamente dopo il ritorno della chiamata di installazione. Tieni presente che la migrazione dei metadati è già stata applicata quando viene eseguito il post-install, quindi un errore in modalità sincrona non annulla le modifiche allo schema — si limita a far emergere l’errore.
- Assicurati che il tuo handler sia idempotente. In modalità asincrona la coda può riprovare fino a tre volte; in entrambe le modalità l’hook può essere eseguito di nuovo durante gli aggiornamenti quando
shouldRunOnVersionUpgrade: true. - Le variabili d’ambiente
APPLICATION_ID,APP_ACCESS_TOKENeAPI_URLsono disponibili all’interno dell’handler (come in qualsiasi altra funzione logica), quindi puoi chiamare le API di Twenty con un token di accesso applicativo con ambito sulla tua app. - È consentita una sola funzione di post-installazione per applicazione. La build del manifesto genererà un errore se ne viene rilevata più di una.
- I campi
universalIdentifier,shouldRunOnVersionUpgradeeshouldRunSynchronouslydella funzione vengono associati automaticamente al manifest dell’applicazione nel campopostInstallLogicFunctiondurante la build — non è necessario referenziarli indefineApplication(). - Il timeout predefinito è impostato a 300 secondi (5 minuti) per consentire attività di configurazione più lunghe, come il popolamento dei dati.
- Non eseguito in modalità dev: quando un’app è registrata in locale (tramite
yarn twenty dev), il server salta completamente il flusso di installazione e sincronizza i file direttamente tramite il watcher della CLI — quindi il post-install non viene mai eseguito in modalità dev, indipendentemente dashouldRunSynchronously. Usayarn twenty exec --postInstallper attivarlo manualmente su un workspace in esecuzione.
definePreInstallLogicFunction
Definisci una funzione logica di pre-installazione (una per app)
definePreInstallLogicFunction
Definisci una funzione logica di pre-installazione (una per app)
InstallPayload), ma è posizionata prima nel flusso di installazione così da poter preparare lo stato da cui dipenderà la migrazione imminente — usi tipici includono il backup dei dati, la validazione della compatibilità con il nuovo schema o l’archiviazione di record che stanno per essere ristrutturati o eliminati.- Le funzioni di pre-install usano
definePreInstallLogicFunction()— stessa configurazione specialistica del post-install, solo agganciata a uno slot di ciclo di vita diverso. - Sia gli handler di pre- sia quelli di post-install ricevono lo stesso tipo
InstallPayload:{ previousVersion?: string; newVersion: string }. Importalo una volta e riutilizzalo per entrambi gli hook. - Quando viene eseguito l’hook: posizionato appena prima della migrazione dei metadati del workspace (
synchronizeFromManifest). Prima dell’esecuzione, il server esegue una “sincronizzazione ridotta” puramente additiva che registra nei metadati del workspace la funzione di pre-install della versione nuova — nient’altro viene toccato — e poi la esegue. Poiché questa sincronizzazione è solo additiva, gli oggetti, i campi e i dati della versione precedente restano intatti quando il tuo handler viene eseguito: puoi leggere ed eseguire in sicurezza il backup dello stato pre-migrazione. - Modello di esecuzione: il pre-install è eseguito in modo sincrono e blocca l’installazione. Se l’handler genera un’eccezione, l’installazione viene interrotta prima che vengano applicate modifiche allo schema — il workspace rimane sulla versione precedente in uno stato coerente. Questo è intenzionale: il pre-install è la tua ultima possibilità per rifiutare un aggiornamento rischioso.
- Come per il post-install, è consentita una sola funzione di pre-installazione per applicazione. Viene collegata automaticamente al manifest dell’applicazione nel campo
preInstallLogicFunctiondurante la build. - Non eseguito in modalità dev: come per il post-install — il flusso di installazione viene completamente saltato per le app registrate localmente, quindi il pre-install non viene mai eseguito con
yarn twenty dev. Usayarn twenty exec --preInstallper attivarlo manualmente.
Pre-install vs post-install: quando usare l'uno o l'altro
Scegliere l'hook di installazione giusto
Pre-install vs post-install: quando usare l'uno o l'altro
Scegliere l'hook di installazione giusto
InstallPayload. La differenza è quando vengono eseguiti rispetto alla migrazione dei metadati del workspace, e questo modifica quali dati possono gestire in sicurezza.shouldRunSynchronously: true. Vedi l’accordion definePostInstallLogicFunction sopra per quando usare ciascuna modalità.Usa post-install per tutto ciò che richiede l’esistenza del nuovo schema. Questo è il caso più comune:- Popolamento di dati predefiniti (creazione di record iniziali, viste predefinite, contenuti demo) su oggetti e campi appena aggiunti.
- Registrazione di webhook con servizi di terze parti ora che l’app ha le proprie credenziali.
- Chiamare la tua API per completare il setup che dipende dai metadati sincronizzati.
- Logica idempotente di “ensure this exists” che dovrebbe riconciliare lo stato a ogni aggiornamento — da combinare con
shouldRunOnVersionUpgrade: true.
PostCard predefinito dopo l’installazione:pre-install quando una migrazione altrimenti distruggerebbe o corromperebbe i dati esistenti. Poiché il pre-install viene eseguito contro lo schema precedente e un suo fallimento annulla l’aggiornamento, è il posto giusto per qualsiasi operazione rischiosa:- Eseguire il backup dei dati che stanno per essere eliminati o ristrutturati — ad esempio, stai rimuovendo un campo nella v2 e devi copiarne i valori in un altro campo o esportarli su uno storage prima che venga eseguita la migrazione.
- Archiviare i record che un nuovo vincolo renderebbe non validi — ad esempio, un campo sta diventando
NOT NULLe devi prima eliminare o correggere le righe con valori nulli. - Validare la compatibilità e rifiutare l’aggiornamento se i dati attuali non possono essere migrati correttamente — genera un’eccezione dall’handler e l’installazione si interrompe senza applicare modifiche. Questo è più sicuro che scoprire l’incompatibilità a migrazione in corso.
- Rinominare o rigenerare le chiavi dei dati prima di una modifica dello schema che farebbe perdere l’associazione.
| You want to… | Usa |
|---|---|
| Popolare dati predefiniti, configurare il workspace, registrare risorse esterne | post-install |
| Eseguire seeding di lunga durata o chiamate a terze parti che non dovrebbero bloccare la risposta dell’installazione | post-install (predefinito — shouldRunSynchronously: false, con retry del worker) |
| Eseguire un setup rapido di cui il chiamante farà affidamento immediatamente dopo il ritorno della chiamata di installazione | post-install con shouldRunSynchronously: true |
| Leggere o eseguire il backup dei dati che la prossima migrazione perderebbe | pre-install |
| Rifiutare un aggiornamento che corromperebbe i dati esistenti | pre-install (genera un’eccezione dall’handler) |
| Eseguire la riconciliazione a ogni aggiornamento | post-install con shouldRunOnVersionUpgrade: true |
| Eseguire un setup una tantum solo alla prima installazione | post-install con shouldRunOnVersionUpgrade: false (predefinito) |
Client API tipizzati (twenty-client-sdk)
Il pacchettotwenty-client-sdk fornisce due client GraphQL tipizzati per interagire con l’API di Twenty dalle tue funzioni logiche e dai componenti front-end.
| Client | Importa | Endpoint | Generato? |
|---|---|---|---|
CoreApiClient | twenty-client-sdk/core | /graphql — dati dello spazio di lavoro (record, oggetti) | Sì, in fase di dev/build |
MetadataApiClient | twenty-client-sdk/metadata | /metadata — configurazione dello spazio di lavoro, caricamenti di file | No, fornito pronto all’uso |
CoreApiClient
Esegui query e modifica i dati dello spazio di lavoro (record, oggetti)
CoreApiClient
Esegui query e modifica i dati dello spazio di lavoro (record, oggetti)
CoreApiClient è il client principale per interrogare e modificare i dati dello spazio di lavoro. Viene generato dallo schema del tuo spazio di lavoro durante yarn twenty dev o yarn twenty build, quindi è completamente tipizzato per corrispondere ai tuoi oggetti e campi.true per includere un campo, usa __args per gli argomenti e annida oggetti per le relazioni. Ottieni completamento automatico e controllo dei tipi completi basati sullo schema del tuo spazio di lavoro.yarn twenty dev o yarn twenty build, genera un errore. La generazione avviene automaticamente — la CLI esegue l’introspezione dello schema GraphQL del tuo spazio di lavoro e genera un client tipizzato usando @genql/cli.Utilizzo di CoreSchema per le annotazioni di tipo
CoreSchema fornisce tipi TypeScript corrispondenti agli oggetti del tuo spazio di lavoro — utile per tipizzare lo stato dei componenti o i parametri delle funzioni:MetadataApiClient
Configurazione dello spazio di lavoro, applicazioni e caricamenti di file
MetadataApiClient
Configurazione dello spazio di lavoro, applicazioni e caricamenti di file
MetadataApiClient è fornito pronto all’uso con l’SDK (nessuna generazione richiesta). Interroga l’endpoint /metadata per la configurazione dello spazio di lavoro, le applicazioni e i caricamenti di file.Caricamento dei file
MetadataApiClient include un metodo uploadFile per allegare file ai campi di tipo file:| Parametro | Tipo | Descrizione |
|---|---|---|
fileBuffer | Buffer | Il contenuto grezzo del file |
filename | string | Il nome del file (utilizzato per l’archiviazione e la visualizzazione) |
contentType | string | Tipo MIME (predefinito su application/octet-stream se omesso) |
fieldMetadataUniversalIdentifier | string | L’universalIdentifier del campo di tipo file nel tuo oggetto |
- Usa l’
universalIdentifierdel campo (non il suo ID specifico dello spazio di lavoro), quindi il tuo codice di upload funziona in qualsiasi spazio di lavoro in cui la tua app è installata. - L’
urlrestituito è un URL firmato che puoi usare per accedere al file caricato.
TWENTY_API_URL— URL di base dell’API di TwentyTWENTY_APP_ACCESS_TOKEN— Chiave a breve durata con ambito al ruolo funzione predefinito della tua applicazione
process.env. I permessi della chiave API sono determinati dal ruolo referenziato in defaultRoleUniversalIdentifier nel tuo application-config.ts.