Skip to content

이벤트 핸들러

에이전트 워크플로우 도중 발생하는 특정 이벤트를 로깅, 테스트, 디버깅하거나 에이전트의 동작을 확장하기 위해 이벤트 핸들러를 사용하여 모니터링하고 대응할 수 있습니다.

기능 개요

EventHandler 기능은 다양한 에이전트 이벤트에 후킹(hook)할 수 있게 해줍니다. 이는 다음과 같은 이벤트 위임 메커니즘 역할을 합니다:

  • AI 에이전트 작업의 생명 주기(lifecycle)를 관리합니다.
  • 워크플로우의 다양한 단계에 대해 모니터링하고 대응할 수 있는 훅(hook)을 제공합니다.
  • 에러 처리 및 복구를 가능하게 합니다.
  • 도구 호출 추적 및 결과 처리를 용이하게 합니다.

설치 및 설정

EventHandler 기능은 EventHandler 클래스를 통해 에이전트 워크플로우와 통합됩니다. 이 클래스는 다양한 에이전트 이벤트에 대한 콜백을 등록하는 방법을 제공하며, 에이전트 설정에서 기능(feature)으로 설치할 수 있습니다. 자세한 내용은 API 레퍼런스를 참고하세요.

기능을 설치하고 에이전트의 이벤트 핸들러를 설정하려면 다음과 같이 하세요:

kotlin
handleEvents {
    // 도구 호출 처리
    onToolCallStarting { eventContext ->
        println("Tool called: ${eventContext.toolName} with args ${eventContext.toolArgs}")
    }
    // 에이전트 실행이 완료되었을 때 트리거되는 이벤트 처리
    onAgentCompleted { eventContext ->
        println("Agent finished with result: ${eventContext.result}")
    }

    // 기타 이벤트 핸들러
}

이벤트 핸들러 설정에 대한 더 자세한 내용은 API 레퍼런스를 참고하세요.

또한 에이전트를 생성할 때 handleEvents 확장 함수를 사용하여 이벤트 핸들러를 설정할 수도 있습니다. 이 함수는 이벤트 핸들러 기능을 설치하고 에이전트의 이벤트 핸들러를 함께 설정합니다. 다음은 예시입니다:

kotlin
val agent = AIAgent(
    promptExecutor = simpleOllamaAIExecutor(),
    llmModel = OllamaModels.Meta.LLAMA_3_2,
){
    handleEvents {
        // 도구 호출 처리
        onToolCallStarting { eventContext ->
            println("Tool called: ${eventContext.toolName} with args ${eventContext.toolArgs}")
        }
        // 에이전트 실행이 완료되었을 때 트리거되는 이벤트 처리
        onAgentCompleted { eventContext ->
            println("Agent finished with result: ${eventContext.result}")
        }

        // 기타 이벤트 핸들러
    }
}