Use os recursos do SDK (tipos e configuração)
O twenty-sdk fornece blocos de construção tipados e funções utilitárias que você usa dentro do seu aplicativo. A seguir estão as partes principais que você usará com mais frequência.Funções utilitárias
O SDK fornece funções utilitárias para definir as entidades do seu app. Conforme descrito em Detecção de entidades, você deve usarexport default define<Entity>({...}) para que suas entidades sejam detectadas:
| Função | Finalidade |
|---|---|
defineApplication | Configurar metadados do aplicativo (obrigatório, um por app) |
defineObject | Define objetos personalizados com campos |
defineLogicFunction | Defina funções de lógica com handlers |
definePreInstallLogicFunction | Defina uma função de lógica de pré-instalação (uma por aplicativo) |
definePostInstallLogicFunction | Defina uma função de lógica de pós-instalação (uma por aplicativo) |
defineFrontComponent | Definir componentes de front-end para UI personalizada |
defineRole | Configura permissões de papéis e acesso a objetos |
defineField | Estender objetos existentes com campos adicionais |
defineView | Define visualizações salvas para objetos |
defineNavigationMenuItem | Define links de navegação da barra lateral |
defineSkill | Define habilidades de agente de IA |
Definindo objetos
Objetos personalizados descrevem tanto o esquema quanto o comportamento de registros no seu espaço de trabalho. UsedefineObject() para definir objetos com validação integrada:
- Use
defineObject()para validação integrada e melhor suporte na IDE. - O
universalIdentifierdeve ser exclusivo e estável entre implantações. - Cada campo requer
name,type,labele seu própriouniversalIdentifierestável. - O array
fieldsé opcional — você pode definir objetos sem campos personalizados. - Você pode criar novos objetos usando
yarn twenty entity:add, que orienta você sobre nomeação, campos e relacionamentos.
Os campos base são criados automaticamente. Quando você define um objeto personalizado, o Twenty adiciona automaticamente campos padrão
como
id, name, createdAt, updatedAt, createdBy, updatedBy e deletedAt.
Você não precisa definir esses no seu array fields — adicione apenas seus campos personalizados.
Você pode substituir os campos padrão definindo um campo com o mesmo nome no seu array fields,
mas isso não é recomendado.Configuração do aplicativo (application-config.ts)
Todo aplicativo tem um único arquivoapplication-config.ts que descreve:
- O que é o aplicativo: identificadores, nome de exibição e descrição.
- Como suas funções são executadas: qual papel usam para permissões.
- Variáveis (opcional): pares chave–valor expostos às suas funções como variáveis de ambiente.
- (Opcional) função de pré-instalação: uma função de lógica que é executada antes da instalação do aplicativo.
- (Opcional) função de pós-instalação: uma função de lógica que é executada após a instalação do aplicativo.
defineApplication() para definir a configuração do seu aplicativo:
universalIdentifiersão IDs determinísticos que você controla; gere-os uma vez e mantenha-os estáveis entre sincronizações.applicationVariablestornam-se variáveis de ambiente para suas funções (por exemplo,DEFAULT_RECIPIENT_NAMEfica disponível comoprocess.env.DEFAULT_RECIPIENT_NAME).defaultRoleUniversalIdentifierdeve corresponder ao arquivo do papel (veja abaixo).- As funções de pré-instalação e pós-instalação são detectadas automaticamente durante a geração do manifesto. Consulte Funções de pré-instalação e Funções de pós-instalação.
Papéis e permissões
Os aplicativos podem definir papéis que encapsulam permissões sobre os objetos e ações do seu espaço de trabalho. O campodefaultRoleUniversalIdentifier em application-config.ts designa o papel padrão usado pelas funções de lógica do seu app.
- A chave de API em tempo de execução, injetada como
TWENTY_API_KEY, é derivada desse papel padrão de função. - O cliente tipado ficará restrito às permissões concedidas a esse papel.
- Siga o princípio do menor privilégio: crie um papel dedicado com apenas as permissões de que suas funções precisam e, em seguida, faça referência ao seu identificador universal.
Papel de função padrão (*.role.ts)
Ao criar um novo aplicativo com o scaffold, a CLI também cria um arquivo de papel padrão. UsedefineRole() para definir papéis com validação integrada:
universalIdentifier desse papel é então referenciado em application-config.ts como defaultRoleUniversalIdentifier. Em outras palavras:
- *.role.ts define o que o papel de função padrão pode fazer.
- application-config.ts aponta para esse papel para que suas funções herdem suas permissões.
- Comece pelo papel gerado pelo scaffold e depois restrinja-o progressivamente seguindo o princípio do menor privilégio.
- Substitua
objectPermissionsefieldPermissionspelos objetos/campos de que suas funções precisam. permissionFlagscontrolam o acesso a recursos em nível de plataforma. Mantenha-os mínimos; adicione apenas o que for necessário.- Veja um exemplo funcional no app Hello World:
packages/twenty-apps/hello-world/src/roles/function-role.ts.
Configuração de função de lógica e ponto de entrada
Cada arquivo de função usadefineLogicFunction() para exportar uma configuração com um handler e gatilhos opcionais.
- route: Expõe sua função em um caminho e método HTTP no endpoint
/s/:
por exemplo,path: '/post-card/create',-> chamar em<APP_URL>/s/post-card/create
- cron: Executa sua função em um agendamento usando uma expressão CRON.
- databaseEvent: Executa em eventos do ciclo de vida de objetos do espaço de trabalho. Quando a operação do evento é
updated, campos específicos a serem observados podem ser especificados no arrayupdatedFields. Se deixar indefinido ou vazio, qualquer atualização acionará a função.
por exemplo, person.updated
Notas:
- O array
triggersé opcional. Funções sem gatilhos podem ser usadas como funções utilitárias chamadas por outras funções. - Você pode misturar vários tipos de gatilho em uma única função.
Funções de pré-instalação
Uma função de pré-instalação é uma função de lógica que é executada automaticamente antes de o seu aplicativo ser instalado em um espaço de trabalho. Isso é útil para tarefas de validação, verificações de pré-requisitos ou para preparar o estado do espaço de trabalho antes que a instalação principal prossiga. Ao criar a estrutura de um novo app comcreate-twenty-app, uma função de pré-instalação é gerada para você em src/logic-functions/pre-install.ts:
- As funções de pré-instalação usam
definePreInstallLogicFunction()— uma variante especializada que omite as configurações de gatilho (cronTriggerSettings,databaseEventTriggerSettings,httpRouteTriggerSettings,isTool). - O manipulador recebe um
InstallLogicFunctionPayloadcom{ previousVersion: string }— a versão do app que foi instalada anteriormente (ou uma string vazia para instalações novas). - É permitida apenas uma função de pré-instalação por app. A geração do manifesto apresentará erro se mais de uma for detectada.
- O
universalIdentifierda função é definido automaticamente comopreInstallLogicFunctionUniversalIdentifierno manifesto do aplicativo durante a geração — você não precisa referenciá-lo emdefineApplication(). - O tempo limite padrão é definido como 300 segundos (5 minutos) para permitir tarefas de preparação mais longas.
- As funções de pré-instalação não precisam de gatilhos — elas são invocadas pela plataforma antes da instalação ou manualmente via
function:execute --preInstall.
Funções de pós-instalação
Uma função de pós-instalação é uma função de lógica que é executada automaticamente após o seu aplicativo ser instalado em um espaço de trabalho. Isso é útil para tarefas de configuração únicas, como preencher dados padrão, criar registros iniciais ou configurar as configurações do espaço de trabalho. Ao criar a estrutura de um novo app comcreate-twenty-app, uma função de pós-instalação é gerada para você em src/logic-functions/post-install.ts:
- As funções de pós-instalação usam
definePostInstallLogicFunction()— uma variante especializada que omite as configurações de gatilho (cronTriggerSettings,databaseEventTriggerSettings,httpRouteTriggerSettings,isTool). - O manipulador recebe um
InstallLogicFunctionPayloadcom{ previousVersion: string }— a versão do app que foi instalada anteriormente (ou uma string vazia para instalações novas). - É permitida apenas uma função de pós-instalação por app. A geração do manifesto apresentará erro se mais de uma for detectada.
- O
universalIdentifierda função é definido automaticamente comopostInstallLogicFunctionUniversalIdentifierno manifesto do aplicativo durante a geração — você não precisa referenciá-lo emdefineApplication(). - O tempo limite padrão é definido como 300 segundos (5 minutos) para permitir tarefas de configuração mais longas, como o pré-carregamento de dados.
- As funções de pós-instalação não precisam de gatilhos — elas são invocadas pela plataforma durante a instalação ou manualmente via
function:execute --postInstall.
Payload de gatilho de rota
Quando um gatilho de rota invoca sua função de lógica, ela recebe um objetoRoutePayload que segue o formato do AWS HTTP API v2. Importe o tipo de twenty-sdk:
RoutePayload tem a seguinte estrutura:
| Propriedade | Tipo | Descrição |
|---|---|---|
headers | Record<string, string | undefined> | Cabeçalhos HTTP (apenas aqueles listados em forwardedRequestHeaders) |
queryStringParameters | Record<string, string | undefined> | Parâmetros de query string (valores múltiplos unidos por vírgulas) |
pathParameters | Record<string, string | undefined> | Parâmetros de caminho extraídos do padrão de rota (por exemplo, /users/:id → { id: '123' }) |
body | object | null | Corpo da requisição analisado (JSON) |
isBase64Encoded | boolean | Se o corpo está codificado em base64 |
requestContext.http.method | string | Método HTTP (GET, POST, PUT, PATCH, DELETE) |
requestContext.http.path | string | Caminho bruto da requisição |
Encaminhamento de cabeçalhos HTTP
Por padrão, os cabeçalhos HTTP das requisições recebidas não são repassados para sua função de lógica por motivos de segurança. Para acessar cabeçalhos específicos, liste-os explicitamente no arrayforwardedRequestHeaders:
Os nomes dos cabeçalhos são normalizados para minúsculas. Acesse-os usando chaves em minúsculas (por exemplo,
event.headers['content-type']).- Gerado automaticamente: Execute
yarn twenty entity:adde escolha a opção para adicionar uma nova função de lógica. Isso gera um arquivo inicial com um handler e configuração. - Manual: Crie um novo arquivo
*.logic-function.tse usedefineLogicFunction(), seguindo o mesmo padrão.
Marcar uma função lógica como ferramenta
Funções lógicas podem ser expostas como ferramentas para agentes de IA e fluxos de trabalho. Quando uma função é marcada como ferramenta, ela fica disponível para os recursos de IA do Twenty e pode ser selecionada como uma etapa em automações de fluxos de trabalho. Para marcar uma função lógica como ferramenta, definaisTool: true e forneça um toolInputSchema descrevendo os parâmetros de entrada esperados usando JSON Schema:
isTool(boolean, padrão:false): Quando definido comotrue, a função é registrada como uma ferramenta e fica disponível para agentes de IA e automações de fluxos de trabalho.toolInputSchema(object, opcional): Um objeto JSON Schema que descreve os parâmetros que sua função aceita. Os agentes de IA usam esse esquema para entender quais entradas a ferramenta espera e para validar as chamadas. Se omitido, o esquema tem como padrão{ type: 'object', properties: {} }(sem parâmetros).- Funções com
isTool: false(ou não definido) não são expostas como ferramentas. Elas ainda podem ser executadas diretamente ou chamadas por outras funções, mas não aparecerão na descoberta de ferramentas. - Nomenclatura de ferramentas: Quando exposta como uma ferramenta, o nome da função é automaticamente normalizado para
logic_function_<name>(em minúsculas, caracteres não alfanuméricos substituídos por sublinhados). Por exemplo,enrich-companytorna-selogic_function_enrich_company. - Você pode combinar
isToolcom gatilhos — uma função pode ser ao mesmo tempo uma ferramenta (chamável por agentes de IA) e acionada por eventos (cron, eventos de banco de dados, rotas) simultaneamente.
Escreva uma boa
description. Os agentes de IA dependem do campo description da função para decidir quando usar a ferramenta. Seja específico sobre o que a ferramenta faz e quando ela deve ser chamada.Componentes de front-end
Componentes de front-end permitem criar componentes React personalizados que são renderizados na UI do Twenty. UsedefineFrontComponent() para definir componentes com validação integrada:
- Componentes de front-end são componentes React que renderizam em contextos isolados dentro do Twenty.
- O campo
componentfaz referência ao seu componente React. - Os componentes são compilados e sincronizados automaticamente durante
yarn twenty app:dev.
- Gerado automaticamente: Execute
yarn twenty entity:adde escolha a opção para adicionar um novo componente de front-end. - Manual: Crie um novo arquivo
.tsxe usedefineFrontComponent(), seguindo o mesmo padrão.
Habilidades
As habilidades definem instruções e capacidades reutilizáveis que os agentes de IA podem usar no seu espaço de trabalho. UsedefineSkill() para definir habilidades com validação integrada:
nameé uma string de identificador exclusivo para a habilidade (recomenda-se kebab-case).labelé o nome de exibição legível por humanos mostrado na UI.contentcontém as instruções da habilidade — este é o texto que o agente de IA usa.icon(opcional) define o ícone exibido na UI.description(opcional) fornece contexto adicional sobre a finalidade da habilidade.
- Gerado automaticamente: Execute
yarn twenty entity:adde escolha a opção para adicionar uma nova habilidade. - Manual: Crie um novo arquivo e use
defineSkill(), seguindo o mesmo padrão.
Clientes tipados gerados
Dois clientes tipados são gerados automaticamente peloyarn twenty app:dev e armazenados em node_modules/twenty-sdk/generated com base no esquema do seu espaço de trabalho:
CoreApiClient— consulta o endpoint/graphqlpara dados do espaço de trabalhoMetadataApiClient— consulta o endpoint/metadatapara obter a configuração do espaço de trabalho e o carregamento de arquivos
yarn twenty app:dev sempre que seus objetos ou campos forem alterados.
Credenciais em tempo de execução em funções de lógica
Quando sua função é executada no Twenty, a plataforma injeta credenciais como variáveis de ambiente antes da execução do seu código:TWENTY_API_URL: URL base da API do Twenty que seu aplicativo usa como alvo.TWENTY_API_KEY: Chave de curta duração com escopo para o papel de função padrão do seu aplicativo.
- Você não precisa passar a URL ou a chave de API para o cliente gerado. Ele lê
TWENTY_API_URLeTWENTY_API_KEYde process.env em tempo de execução. - As permissões da chave de API são determinadas pelo papel referenciado no seu
application-config.tsviadefaultRoleUniversalIdentifier. Este é o papel padrão usado pelas funções de lógica do seu app. - Os aplicativos podem definir papéis para seguir o princípio do menor privilégio. Conceda apenas as permissões de que suas funções precisam e, em seguida, aponte
defaultRoleUniversalIdentifierpara o identificador universal desse papel.
Carregamento de arquivos
OMetadataApiClient gerado inclui um método uploadFile para anexar arquivos a campos do tipo arquivo nos objetos do seu espaço de trabalho. Como os clientes GraphQL padrão não suportam nativamente o carregamento de arquivos multipart, o cliente fornece este método dedicado que implementa, nos bastidores, a especificação de solicitações multipart do GraphQL.
| Parâmetro | Tipo | Descrição |
|---|---|---|
fileBuffer | Buffer | O conteúdo bruto do arquivo |
filename | string | O nome do arquivo (usado para armazenamento e exibição) |
contentType | string | Tipo MIME do arquivo (padrão para application/octet-stream se omitido) |
fieldMetadataUniversalIdentifier | string | O universalIdentifier do campo do tipo arquivo no seu objeto |
- O método
uploadFileestá disponível noMetadataApiClientporque a mutação de upload é resolvida pelo endpoint/metadata. - Ele usa o
universalIdentifierdo campo (não o ID específico do espaço de trabalho), de modo que seu código de upload funcione em qualquer espaço de trabalho onde seu app esteja instalado — consistente com a forma como os apps referenciam campos em qualquer outro lugar. - A
urlretornada é um URL assinado que você pode usar para acessar o arquivo enviado.