defineLogicFunction
Define funciones de lógica y sus desencadenadores
defineLogicFunction
Define funciones de lógica y sus desencadenadores
Cada archivo de función usa Tipos de desencadenadores disponibles:El tipo
En tu controlador, accede a los encabezados reenviados así:Por razones de seguridad, los encabezados de la respuesta están restringidos a una lista de permitidos. Cualquier encabezado que no esté en la lista (por ejemplo, La carga útil incluye:
Para eliminaciones lógicas (soft deletes), Ejemplo de evento de creación:Ejemplo de evento de actualización:Ejecutar solo en actualizaciones de correo electrónico:Ejemplo de evento de eliminación:Puntos clave:
defineLogicFunction() para exportar una configuración con un controlador y desencadenadores opcionales.src/logic-functions/createPostCard.logic-function.ts
- httpRoute: Expone tu función en una ruta y método HTTP bajo el endpoint
/s/:
p. ej.,path: '/post-card/create'se puede invocar enhttps://your-twenty-server.com/s/post-card/create
Para invocar una función de lógica activada por una ruta desde un componente de frontend (headless), consulta Llamar a una función de lógica.
- cron: Ejecuta tu función en un horario usando una expresión CRON.
- databaseEvent: Se ejecuta en eventos del ciclo de vida de objetos del espacio de trabajo. Cuando la operación del evento es
updated, se pueden especificar campos específicos que se deben escuchar en la matrizupdatedFields. Si se deja sin definir o vacío, cualquier actualización activará la función.
p. ej.person.updated,*.created,company.*
También puedes ejecutar manualmente una función usando la CLI:Puedes ver los registros con:
Carga útil del disparador de ruta
Cuando un desencadenador de ruta invoca tu función de lógica, esta recibe un objetoRoutePayload que sigue el
formato AWS HTTP API v2.
Importa el tipo RoutePayload desde twenty-sdk/logic-function:RoutePayload tiene la siguiente estructura:| Propiedad | Tipo | Descripción | Ejemplo |
|---|---|---|---|
headers | Record\<string, string | undefined> | Encabezados HTTP (solo aquellos listados en forwardedRequestHeaders) | consulta la sección de abajo |
queryStringParameters | Record\<string, string | undefined> | Parámetros de consulta (valores múltiples unidos con comas) | /users?ids=1&ids=2&ids=3&name=Alice -> { ids: '1,2,3', name: 'Alice' } |
pathParameters | Record\<string, string | undefined> | Parámetros de ruta extraídos del patrón de la ruta | /users/:id, /users/123 -> { id: '123' } |
body | object | null | Cuerpo de la solicitud analizado (JSON) | { id: 1 } -> { id: 1 } |
rawBody | string | undefined | Cuerpo de la solicitud UTF-8 original, antes del análisis de JSON. Útil para verificar firmas de webhooks de estilo HMAC (p. ej., X-Hub-Signature-256 de GitHub, Stripe). undefined cuando el entorno de ejecución no lo conservó. | |
isBase64Encoded | boolean | Indica si el cuerpo está codificado en base64 | |
requestContext.http.method | string | Método HTTP (GET, POST, PUT, PATCH, DELETE) | |
requestContext.http.path | string | Ruta de la solicitud sin procesar |
forwardedRequestHeaders
De forma predeterminada, los encabezados HTTP de las solicitudes entrantes no se pasan a tu función de lógica por razones de seguridad. Para acceder a encabezados específicos, enuméralos explícitamente en el arregloforwardedRequestHeaders:Los nombres de los encabezados se normalizan a minúsculas. Accede a ellos usando claves en minúsculas (p. ej.,
event.headers['content-type']).Respuesta HTTP personalizada
De forma predeterminada, devolver un valor sencillo desde tu controlador lo envía de vuelta como una respuesta200 (JSON para objetos, text/plain para cadenas). Para controlar el código de estado y los encabezados de la respuesta, devuelve un Response desde twenty-sdk/logic-function:Set-Cookie, encabezados CORS como Access-Control-Allow-Origin, o encabezados personalizados X-*) se descarta silenciosamente antes de que se envíe la respuesta. Los encabezados de respuesta permitidos son:content-typecontent-languagecontent-dispositioncache-controlretry-after
El código de estado debe ser un código de estado HTTP válido (entre 100 y 599). Los nombres de los encabezados de respuesta se comparan sin distinguir mayúsculas de minúsculas.
Payload del disparador de evento de base de datos
Cuando un disparador de evento de base de datos invoca tu función de lógica, esta recibe unDatabaseEventPayload por cada registro modificado. El payload combina metadatos sobre el espacio de trabajo y el objeto de origen con el evento a nivel de registro.| Propiedad | Descripción |
|---|---|
name | Nombre del evento, como person.updated. |
workspaceId | Espacio de trabajo donde ocurrió el evento. |
objectMetadata | Metadatos del objeto que cambió. |
recordId | Id del registro que cambió. |
userId, userWorkspaceId, workspaceMemberId | Campos del actor cuando el evento fue causado por un usuario del espacio de trabajo. |
propiedades | Datos del registro para el evento, con before, after, diff y updatedFields según la operación. |
| Evento | Datos del registro |
|---|---|
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 sigue la estructura de estilo de actualización porque el campo deletedAt del registro cambia.
Para eliminaciones permanentes, usa .destroyed.databaseEventTriggerSettings.updatedFields filtra qué eventos de actualización activan la función.
event.properties.updatedFields te indica qué campos realmente cambiaron en el evento actual.Exponer una función como herramienta de IA o acción de flujo de trabajo
Las funciones lógicas pueden exponerse en dos ámbitos, cada uno con su propio disparador:toolTriggerSettings— hace que la función sea descubrible por las funciones de IA de Twenty (chat, MCP, llamadas a funciones). Usa el JSON Schema estándar, el formato que los LLM entienden de forma nativa.workflowActionTriggerSettings— hace que la función aparezca como un paso en el constructor visual de flujos de trabajo. Usa elInputSchemacompleto de Twenty para que el constructor pueda renderizar editores de campos adecuados, selectores de variables y etiquetas.
cronTriggerSettings, databaseEventTriggerSettings y httpRouteTriggerSettings — mismo patrón, misma estructura.src/logic-functions/enrich-company.logic-function.ts
- Una función puede mezclar superficies — declara tanto
toolTriggerSettingscomoworkflowActionTriggerSettingspara exponerla en el chat Y en el constructor de flujos de trabajo. - Ambos,
toolTriggerSettings.inputSchemayworkflowActionTriggerSettings.inputSchema, son opcionales. Cuando se omiten, el generador del manifiesto los infiere a partir del código fuente del controlador (JSON Schema para la herramienta de IA,InputSchemade Twenty para la acción de flujo de trabajo). Proporciona uno explícitamente cuando quieras un tipado más rico — por ejemplo, con campos compatibles conFieldMetadataTypecomoCURRENCYoRELATIONpara el constructor de flujos de trabajo, o con camposdescriptionque el agente de IA pueda leer:
Escribe una buena
description. Los agentes de IA dependen del campo description de la función para decidir cuándo usar la herramienta. Sé específico acerca de lo que hace la herramienta y cuándo debe invocarse.Hooks de instalación — los controladores de preinstalación y postinstalación — comparten este entorno de ejecución, pero se declaran con sus propias funciones ‘define’ y no aceptan configuraciones de disparador. Consulta Hooks de instalación para
definePreInstallLogicFunction y definePostInstallLogicFunction.Clientes de API tipados (twenty-client-sdk)
El paquetetwenty-client-sdk proporciona dos clientes GraphQL tipados para interactuar con la API de Twenty desde tus funciones de lógica y componentes de frontend.
| Cliente | Importar | Endpoint | ¿Generado? |
|---|---|---|---|
CoreApiClient | twenty-client-sdk/core | /graphql — datos del espacio de trabajo (registros, objetos) | Sí, en tiempo de desarrollo/compilación |
MetadataApiClient | twenty-client-sdk/metadata | /metadata — configuración del espacio de trabajo, cargas de archivos | No, viene preconstruido |
CoreApiClient
Consultar y modificar datos del espacio de trabajo (registros, objetos)
CoreApiClient
Consultar y modificar datos del espacio de trabajo (registros, objetos)
CoreApiClient es el cliente principal para consultar y mutar datos del espacio de trabajo. Se genera a partir del esquema de tu espacio de trabajo durante yarn twenty dev o yarn twenty dev:build, por lo que está completamente tipado para coincidir con tus objetos y campos.true para incluir un campo, usa __args para los argumentos y anida objetos para las relaciones. Obtienes autocompletado completo y verificación de tipos basados en el esquema de tu espacio de trabajo.CoreApiClient se genera en tiempo de desarrollo/compilación. Si intentas usarlo sin ejecutar primero
yarn twenty dev o yarn twenty dev:build, lanzará un error. La generación ocurre automáticamente: la CLI inspecciona el esquema GraphQL de tu espacio de trabajo y genera un cliente tipado usando @genql/cli.Uso de CoreSchema para anotaciones de tipos
CoreSchema proporciona tipos de TypeScript que coinciden con los objetos de tu espacio de trabajo; útil para tipar el estado de componentes o parámetros de funciones:MetadataApiClient
Configuración del espacio de trabajo, aplicaciones y cargas de archivos
MetadataApiClient
Configuración del espacio de trabajo, aplicaciones y cargas de archivos
MetadataApiClient viene preconstruido con el SDK (no se requiere generación). Consulta el endpoint /metadata para la configuración del espacio de trabajo, las aplicaciones y las cargas de archivos.Subir archivos
ElMetadataApiClient incluye un método uploadFile para adjuntar archivos a los campos de tipo archivo:| Parámetro | Tipo | Descripción |
|---|---|---|
fileBuffer | Buffer | El contenido sin procesar del archivo |
filename | string | El nombre del archivo (se utiliza para el almacenamiento y la visualización) |
contentType | string | Tipo MIME (de forma predeterminada es application/octet-stream si se omite) |
fieldMetadataUniversalIdentifier | string | El universalIdentifier del campo de tipo de archivo de tu objeto |
- Utiliza el
universalIdentifierdel campo (no su ID específico del espacio de trabajo), por lo que tu código de carga funciona en cualquier espacio de trabajo donde esté instalada tu aplicación. - La
urldevuelta es una URL firmada que puedes usar para acceder al archivo cargado.
Cuando tu código se ejecuta en Twenty (funciones de lógica o componentes de frontend), la plataforma inyecta credenciales como variables de entorno:
TWENTY_API_URL— URL base de la API de TwentyTWENTY_APP_ACCESS_TOKEN— Token de corta duración con alcance al rol de función predeterminado de tu aplicación
process.env automáticamente. Los permisos de la clave de API están determinados por el rol declarado con defineApplicationRole() (o referenciado mediante defaultRoleUniversalIdentifier en application-config.ts).