O que são Artefatos de IA?
Artefatos de IA são ferramentas poderosas que permitem aos usuários criar, incorporar e interagir com componentes dinâmicos baseados na web diretamente em uma postagem do Discourse. Esses componentes podem conter HTML, CSS e JavaScript personalizados, permitindo uma variedade de casos de uso, como:
- Incorporar questionários ou formulários interativos.
- Visualizar dados com gráficos e animações ricas.
- Integrar aplicativos ou ferramentas web leves.
- Uma ferramenta para aprender sobre frameworks web, bibliotecas JavaScript e muito mais.
Os Artefatos de IA aprimoram perfeitamente as postagens do Discourse, adicionando interatividade e garantindo uma experiência de navegação segura.
Configurações do Site
Os administradores podem configurar várias configurações:
1. Habilitando o Recurso
- Configuração:
discourse_ai_enabled- Certifique-se de que esta configuração global esteja habilitada para que os Artefatos de IA funcionem.
2. Modos de Segurança
- Configuração:
ai_artifact_security- Opções:
disabled: Desabilitar o sistema de artefatoslax: Os artefatos aparecem automaticamente nas postagens sem exigir interação do usuário.strict: Os usuários devem ativar explicitamente os artefatos em seus navegadores clicando em um botão “Ver” ou “Executar”. Esta configuração é recomendada para ambientes com foco em segurança. (padrão)
- Opções:
3. Acesso ao Criador de Artefatos
- Por padrão, a persona Criador de Artefatos é restrita apenas a usuários da equipe. Essa restrição garante que apenas indivíduos confiáveis possam criar artefatos, minimizando o risco de uso inadequado ou malicioso.
- Se um acesso mais amplo for necessário, as permissões precisam ser configuradas manualmente por um administrador do site.
Usando Artefatos de IA em Postagens
Os artefatos são criados automaticamente pela persona Criador de Artefatos sob demanda.
<div class="ai-artifact" data-ai-artifact-version="3" data-ai-artifact-id="71"></div>
O artefato acima foi gerado usando GPT-4o e a biblioteca anime.js
Uma vez criados, eles são privados para você e para a persona Criador de Artefatos. Usuários que podem compartilhar conversas de IA (aqueles que pertencem aos ai bot public sharing allowed groups) também podem tornar um artefato público compartilhando a conversa.
Uma vez compartilhado, você pode usar a seguinte marcação HTML para renderizá-lo em uma postagem:
<div class="ai-artifact" data-ai-artifact-version="3" data-ai-artifact-id="71"></div>
(onde a versão e o ID do artefato são seu artefato versionado)
Considerações de Segurança
Dado que os Artefatos de IA podem executar HTML, CSS e JavaScript personalizados, o Discourse implementou salvaguardas robustas:
1. Sandboxing em iFrames
- Os artefatos são renderizados dentro de contêineres
iframeisolados com atributossandboxpara restringir operações potencialmente inseguras como:- Cross-site scripting.
- Acesso a sites ou APIs externas.
2. Política de Segurança de Conteúdo (CSP)
- Todos os recursos em artefatos (como bibliotecas JavaScript) são restritos a domínios seguros e pré-aprovados, como:
- https://unpkg.com
- https://cdnjs.cloudflare.com
- https://ajax.googleapis.com
- https://cdn.jsdelivr.net
- https://esm.sh
3. Modo de Segurança
- Modo Estrito: Recomenda-se para ambientes onde os artefatos não são totalmente confiáveis. Os usuários precisarão ativar manualmente os artefatos em seus navegadores antes que eles sejam renderizados.
4. Acesso e Permissões
- Os artefatos são visíveis apenas para:
- Seu criador.
- Usuários com as permissões corretas para visualizar a postagem associada (por exemplo, mensagens privadas).
- Artefatos públicos devem ser explicitamente marcados como tal, compartilhando a conversa de IA.
5. Limites de Tamanho
- O tamanho de HTML, CSS e JavaScript em um artefato é limitado a 64 KB cada. Isso garante que os componentes permaneçam leves e não sobrecarreguem os usuários ou sistemas.
Armazenamento de Artefatos
Artefatos da web podem opcionalmente armazenar dados por usuário. Para fazer isso, sugira ao criador do artefato com “usar armazenamento de usuário” ou similar.
Este sistema permite armazenar pares chave, valor:
- Privado (visível apenas para administradores e usuários específicos)
- Público (visível para todos os usuários, incluindo anônimos)
Pares chave-valor são protegidos contra a postagem de origem do artefato, no entanto, se você compartilhar um artefato publicamente, todos poderão adicionar chaves.
Para controlar o armazenamento, você pode usar as configurações ocultas:
ai_artifact_kv_value_max_length(itens padrão podem ter apenas 5000 letras ou menos)ai_artifact_max_keys_per_user_per_artifact(padrão 100)
FAQ
Quem Pode Criar Artefatos de IA?
Por padrão, apenas usuários da equipe (por exemplo, administradores ou moderadores) podem criar artefatos através da Persona Criador de Artefatos. Essa persona simplifica o processo de design de widgets web interativos usando HTML, CSS e JavaScript.
O Que Acontece Se Eu Clicar em um Artefato?
- No modo lax, os artefatos aparecem automaticamente.
- No modo strict, clicar no botão “Executar” ativa o artefato e permite que ele seja carregado em seu navegador.
Artefatos de IA São Seguros?
Sim. Artefatos de IA são executados em ambientes estritamente controlados:
- Eles são isolados e não podem interagir diretamente com o aplicativo Discourse ou o contexto do usuário, apenas via mensagens iframe.
- O modo estrito lhe dá controle sobre a ativação.
- Artefatos são privados por padrão, você precisa compartilhar ativamente para dar acesso global.
Posso Ver o Código Fonte dos Artefatos?
Sim. Quando o Discourse AI gera artefatos, ele incluirá o markup, CSS e JavaScript completos.
Quais LLMs São Suportados?
Artefatos podem ser gerados usando qualquer LLM que você configurou, no entanto, vários LLMs se especializam e são mais ajustados para a criação de artefatos.
Temos visto bons resultados com o3, Anthropic Claude Sonnet 3.7 - 4.0, GPT-4.1, Gemini Pro 2.5 e mais. Geralmente modelos mais avançados terão um desempenho melhor.
Há um grande aspecto de tentativa e erro na criação de artefatos, a experimentação é fundamental.