/*---------------------------------------------------------------------------------------------
* Copyright (c) Microsoft Corporation. All rights reserved.
*--------------------------------------------------------------------------------------------*/
package com.github.copilot.sdk.json;
import java.util.concurrent.CompletableFuture;
/**
* Handler for pre-tool-use hooks.
*
* This hook is called before a tool is executed, allowing you to:
*
* - Approve or deny tool execution
* - Modify tool arguments
* - Add additional context for the model
*
*
* @since 1.0.6
*/
@FunctionalInterface
public interface PreToolUseHandler {
/**
* Handles a pre-tool-use hook invocation.
*
* @param input
* the hook input containing tool name and arguments
* @param invocation
* context information about the invocation
* @return a future that resolves with the hook output, or {@code null} to use
* defaults
*/
CompletableFuture handle(PreToolUseHookInput input, HookInvocation invocation);
}