Visão Geral
Os hooks de ferramenta são executados em dois pontos críticos:- Antes da Chamada de Ferramenta: Modificar entradas, validar parâmetros ou bloquear execução
- Depois da Chamada de Ferramenta: Transformar resultados, sanitizar saídas ou registrar detalhes de execução
Tipos de Hook
Hooks Antes da Chamada de Ferramenta
Executados antes de cada execução de ferramenta, esses hooks podem:- Inspecionar e modificar entradas de ferramenta
- Bloquear execução de ferramenta com base em condições
- Implementar gates de aprovação para operações perigosas
- Validar parâmetros
- Registrar invocações de ferramenta
Hooks Depois da Chamada de Ferramenta
Executados depois de cada execução de ferramenta, esses hooks podem:- Modificar ou sanitizar resultados de ferramenta
- Adicionar metadados ou formatação
- Registrar resultados de execução
- Implementar validação de resultado
- Transformar formatos de saída
Contexto do Hook de Ferramenta
O objetoToolCallHookContext fornece acesso abrangente ao estado de execução da ferramenta:
Modificando Entradas de Ferramenta
Importante: Sempre modifique entradas de ferramenta in-place:Métodos de Registro
1. Registro Baseado em Decoradores (Recomendado)
Use decoradores para sintaxe mais limpa:2. Hooks com Escopo de Crew
Registre hooks para uma instância específica de crew:Casos de Uso Comuns
1. Guardrails de Segurança
2. Gate de Aprovação Humana
3. Validação e Sanitização de Entrada
4. Sanitização de Resultado
5. Análise de Uso de Ferramenta
6. Limitação de Taxa
7. Logging de Debug
Gerenciamento de Hooks
Desregistrando Hooks
Limpando Hooks
Padrões Avançados
Execução Condicional de Hook
Modificação de Entrada com Consciência de Contexto
Melhores Práticas
- Mantenha Hooks Focados: Cada hook deve ter uma responsabilidade única
- Evite Computação Pesada: Hooks executam em cada chamada de ferramenta
- Trate Erros Graciosamente: Use try-except para prevenir falhas de hooks
- Use Type Hints: Aproveite
ToolCallHookContextpara melhor suporte IDE - Documente Condições de Bloqueio: Deixe claro quando/por que ferramentas são bloqueadas
- Teste Hooks Independentemente: Teste unitário de hooks antes de usar em produção
- Limpe Hooks em Testes: Use
clear_all_tool_call_hooks()entre execuções de teste - Modifique In-Place: Sempre modifique
context.tool_inputin-place, nunca substitua - Registre Decisões Importantes: Especialmente ao bloquear execução de ferramenta
- Considere Performance: Cache validações caras quando possível
Tratamento de Erros
Segurança de Tipos
Solução de Problemas
Hook Não Está Executando
- Verifique se hook está registrado antes da execução da crew
- Verifique se hook anterior retornou
False(bloqueia execução e hooks subsequentes) - Garanta que assinatura do hook corresponda ao tipo esperado
Modificações de Entrada Não Funcionam
- Use modificações in-place:
context.tool_input['key'] = value - Não substitua o dict:
context.tool_input = {}
Modificações de Resultado Não Funcionam
- Retorne a string modificada dos hooks posteriores
- Retornar
Nonemantém o resultado original - Garanta que a ferramenta realmente retornou um resultado
Ferramenta Bloqueada Inesperadamente
- Verifique todos os hooks antes por condições de bloqueio
- Verifique ordem de execução do hook
- Adicione logging de debug para identificar qual hook está bloqueando
