defineLogicFunction
Définir des fonctions logiques et leurs déclencheurs
defineLogicFunction
Définir des fonctions logiques et leurs déclencheurs
Chaque fichier de fonction utilise Types de déclencheurs disponibles :Le type
Dans votre gestionnaire, accédez aux en-têtes transférés comme ceci :Pour des raisons de sécurité, les en-têtes de réponse sont restreints à une liste d’autorisation. Tout en-tête qui ne figure pas dans la liste (par exemple La charge utile inclut :
Pour les suppressions logiques (soft deletes), Exemple d’événement de création :Exemple d’événement de mise à jour :Déclencher uniquement lors des mises à jour de l’adresse e-mail :Exemple d’événement de destruction :Points clés :
defineLogicFunction() pour exporter une configuration avec un gestionnaire et des déclencheurs facultatifs.src/logic-functions/createPostCard.logic-function.ts
- httpRoute : Expose votre fonction sur un chemin et une méthode HTTP sous l’endpoint
/s/:
p. ex.path: '/post-card/create'est appelable àhttps://your-twenty-server.com/s/post-card/create
Pour appeler une fonction logique déclenchée par une route depuis un composant frontal (sans interface), consultez Appeler une fonction logique.
- cron : Exécute votre fonction selon une planification à l’aide d’une expression CRON.
- databaseEvent: S’exécute lors des événements du cycle de vie des objets de l’espace de travail. Lorsque l’opération de l’événement est
updated, des champs spécifiques à surveiller peuvent être spécifiés dans le tableauupdatedFields. S’il est laissé indéfini ou vide, toute mise à jour déclenchera la fonction.
p. ex.person.updated,*.created,company.*
Vous pouvez également exécuter manuellement une fonction à l’aide de la CLI :Vous pouvez consulter les journaux avec :
Charge utile du déclencheur de route
Lorsqu’un déclencheur de route invoque votre fonction logique, elle reçoit un objetRoutePayload qui suit le
format AWS HTTP API v2.
Importez le type RoutePayload depuis twenty-sdk/logic-function :RoutePayload a la structure suivante :| Nom de la propriété | Type | Description | Exemple |
|---|---|---|---|
headers | Record\<string, string | undefined> | En-têtes HTTP (uniquement ceux répertoriés dans forwardedRequestHeaders) | voir la section ci-dessous |
queryStringParameters | Record\<string, string | undefined> | Paramètres de la chaîne de requête (plusieurs valeurs séparées par des virgules) | /users?ids=1&ids=2&ids=3&name=Alice -> { ids: '1,2,3', name: 'Alice' } |
pathParameters | Record\<string, string | undefined> | Paramètres de chemin extraits du modèle de route | /users/:id, /users/123 -> { id: '123' } |
body | object | null | Corps de la requête analysé (JSON) | { id: 1 } -> { id: 1 } |
rawBody | string | undefined | Corps de la requête UTF-8 d’origine, avant l’analyse JSON. Utile pour vérifier les signatures de webhook de type HMAC (par exemple X-Hub-Signature-256 de GitHub, Stripe). undefined lorsque l’environnement d’exécution ne l’a pas conservé. | |
isBase64Encoded | boolean | Indique si le corps est encodé en base64 | |
requestContext.http.method | string | Méthode HTTP (GET, POST, PUT, PATCH, DELETE) | |
requestContext.http.path | string | Chemin de la requête brut |
forwardedRequestHeaders
Par défaut, les en-têtes HTTP des requêtes entrantes ne sont pas transmis à votre fonction logique pour des raisons de sécurité. Pour accéder à des en-têtes spécifiques, listez-les dans le tableauforwardedRequestHeaders :Les noms d’en-têtes sont normalisés en minuscules. Accédez-y en utilisant des clés en minuscules (p. ex.,
event.headers['content-type']).Réponse HTTP personnalisée
Par défaut, le retour d’une valeur simple depuis votre gestionnaire l’envoie en réponse200 (JSON pour les objets, text/plain pour les chaînes). Pour contrôler le code d’état et les en-têtes de la réponse, retournez un objet Response depuis twenty-sdk/logic-function :Set-Cookie, les en-têtes CORS tels que Access-Control-Allow-Origin, ou les en-têtes personnalisés X-*) est silencieusement supprimé avant l’envoi de la réponse. Les en-têtes de réponse autorisés sont :content-typecontent-languagecontent-dispositioncache-controlretry-after
Le code d’état doit être un code d’état HTTP valide (compris entre 100 et 599). Les noms des en-têtes de réponse sont comparés sans tenir compte de la casse.
Charge utile du déclencheur d’événement de base de données
Lorsqu’un déclencheur d’événement de base de données appelle votre fonction logique, celle-ci reçoit unDatabaseEventPayload par enregistrement modifié. La charge utile combine les métadonnées concernant l’espace de travail et l’objet source avec l’événement au niveau de l’enregistrement.| Propriété | Description |
|---|---|
name | Nom de l’événement, comme person.updated. |
workspaceId | Espace de travail où l’événement s’est produit. |
objectMetadata | Métadonnées pour l’objet qui a été modifié. |
recordId | ID de l’enregistrement modifié. |
userId, userWorkspaceId, workspaceMemberId | Champs de l’acteur lorsque l’événement a été provoqué par un utilisateur de l’espace de travail. |
properties | Données d’enregistrement pour l’événement, avec before, after, diff et updatedFields selon l’opération. |
| Événement | Données d’enregistrement |
|---|---|
person.created | event.properties.after |
person.updated | event.properties.before, event.properties.after, event.properties.diff, event.properties.updatedFields |
person.destroyed | event.properties.before |
.deleted suit la structure de type mise à jour, car le champ deletedAt de l’enregistrement change.
Pour les suppressions permanentes, utilisez .destroyed.databaseEventTriggerSettings.updatedFields filtre les événements de mise à jour qui déclenchent la fonction.
event.properties.updatedFields indique quels champs ont réellement changé pour l’événement actuel.Exposer une fonction en tant qu’outil d’IA ou en tant qu’action de workflow
Les fonctions logiques peuvent être exposées sur deux surfaces, chacune avec son propre déclencheur :toolTriggerSettings— rend la fonction découvrable par les fonctionnalités d’IA de Twenty (chat, MCP, appel de fonctions). Utilise le schéma JSON standard, le format que les LLM comprennent nativement.workflowActionTriggerSettings— fait apparaître la fonction comme une étape dans le concepteur visuel de workflows. Utilise leInputSchemariche de Twenty afin que le concepteur puisse afficher des éditeurs de champs appropriés, des sélecteurs de variables et des libellés.
cronTriggerSettings, databaseEventTriggerSettings et httpRouteTriggerSettings — même modèle, même structure.src/logic-functions/enrich-company.logic-function.ts
- Une fonction peut mélanger les surfaces — déclarez à la fois
toolTriggerSettingsetworkflowActionTriggerSettingspour l’exposer à la fois dans le chat ET dans le concepteur de workflows. toolTriggerSettings.inputSchemaetworkflowActionTriggerSettings.inputSchemasont tous deux facultatifs. Lorsqu’ils sont omis, le générateur de manifeste les déduit à partir du code source du gestionnaire (schéma JSON pour l’outil d’IA,InputSchemade Twenty pour l’action de workflow). Fournissez-en un explicitement lorsque vous souhaitez un typage plus riche — par exemple, avec des champs compatibles avecFieldMetadataTypecommeCURRENCYouRELATIONpour le concepteur de workflows, ou avec des champsdescriptionque l’agent d’IA peut lire :
Rédigez une bonne
description. Les agents IA s’appuient sur le champ description de la fonction pour décider quand utiliser l’outil. Soyez précis sur ce que fait l’outil et quand il doit être appelé.Hooks d’installation — les gestionnaires de pré-installation et de post-installation — partagent ce runtime mais sont déclarés avec leurs propres fonctions define et ne prennent pas de paramètres de déclenchement. Voir hooks d’installation pour
definePreInstallLogicFunction et definePostInstallLogicFunction.Clients d’API typés (twenty-client-sdk)
Le packagetwenty-client-sdk fournit deux clients GraphQL typés pour interagir avec l’API Twenty depuis vos fonctions logiques et vos composants frontaux.
| Client | Importer | Point de terminaison | Généré ? |
|---|---|---|---|
CoreApiClient | twenty-client-sdk/core | /graphql — données de l’espace de travail (enregistrements, objets) | Oui, au moment du dev/build |
MetadataApiClient | twenty-client-sdk/metadata | /metadata — configuration de l’espace de travail, téléversements de fichiers | Non, livré prêt à l’emploi |
CoreApiClient
Interroger et modifier les données de l'espace de travail (enregistrements, objets)
CoreApiClient
Interroger et modifier les données de l'espace de travail (enregistrements, objets)
CoreApiClient est le client principal pour interroger et modifier les données de l’espace de travail. Il est généré à partir du schéma de votre espace de travail lors de l’exécution de yarn twenty dev ou yarn twenty dev:build, il est donc entièrement typé pour correspondre à vos objets et champs.true pour inclure un champ, utilisez __args pour les arguments et imbriquez des objets pour les relations. Vous bénéficiez d’une autocomplétion complète et d’une vérification de types basée sur le schéma de votre espace de travail.CoreApiClient est généré au moment du dev/build. Si vous l’utilisez sans exécuter d’abord
yarn twenty dev ou yarn twenty dev:build, une erreur est levée. La génération se fait automatiquement — la CLI inspecte le schéma GraphQL de votre espace de travail et génère un client typé à l’aide de @genql/cli.Utiliser CoreSchema pour les annotations de type
CoreSchema fournit des types TypeScript correspondant à vos objets d’espace de travail — utile pour typer l’état des composants ou les paramètres de fonction :MetadataApiClient
Configuration de l'espace de travail, applications et téléversements de fichiers
MetadataApiClient
Configuration de l'espace de travail, applications et téléversements de fichiers
MetadataApiClient est livré prêt à l’emploi avec le SDK (aucune génération requise). Il interroge le point de terminaison /metadata pour la configuration de l’espace de travail, les applications et les téléversements de fichiers.Téléverser des fichiers
LeMetadataApiClient inclut une méthode uploadFile pour joindre des fichiers aux champs de type fichier :| Paramètre | Type | Description |
|---|---|---|
fileBuffer | Buffer | Le contenu brut du fichier |
filename | string | Le nom du fichier (utilisé pour le stockage et l’affichage) |
contentType | string | Type MIME (par défaut application/octet-stream s’il est omis) |
fieldMetadataUniversalIdentifier | string | Le universalIdentifier du champ de type fichier de votre objet |
- Utilise le
universalIdentifierdu champ (et non son ID propre à l’espace de travail), de sorte que votre code de téléversement fonctionne dans tout espace de travail où votre application est installée. - L’
urlrenvoyée est une URL signée que vous pouvez utiliser pour accéder au fichier téléversé.
Lorsque votre code s’exécute sur Twenty (fonctions logiques ou composants frontaux), la plateforme injecte des identifiants sous forme de variables d’environnement :
TWENTY_API_URL— URL de base de l’API TwentyTWENTY_APP_ACCESS_TOKEN— Clé de courte durée limitée au rôle de fonction par défaut de votre application
process.env. Les autorisations de la clé API sont déterminées par le rôle déclaré avec defineApplicationRole() (ou référencé via defaultRoleUniversalIdentifier dans application-config.ts).