001/* 002 * Copyright 2022-2026 Revetware LLC. 003 * 004 * Licensed under the Apache License, Version 2.0 (the "License"); 005 * you may not use this file except in compliance with the License. 006 * You may obtain a copy of the License at 007 * 008 * http://www.apache.org/licenses/LICENSE-2.0 009 * 010 * Unless required by applicable law or agreed to in writing, software 011 * distributed under the License is distributed on an "AS IS" BASIS, 012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 013 * See the License for the specific language governing permissions and 014 * limitations under the License. 015 */ 016 017package com.soklet; 018 019import org.jspecify.annotations.NonNull; 020 021import javax.annotation.concurrent.ThreadSafe; 022import java.util.Optional; 023 024/** 025 * Programmatic MCP prompt handler contract. 026 * 027 * @author <a href="https://www.revetkn.com">Mark Allen</a> 028 */ 029@ThreadSafe 030public interface McpPromptHandler { 031 /** 032 * Provides the MCP prompt name. 033 * 034 * @return the prompt name 035 */ 036 @NonNull 037 String getName(); 038 039 /** 040 * Provides the MCP prompt description. 041 * 042 * @return the prompt description 043 */ 044 @NonNull 045 String getDescription(); 046 047 /** 048 * Provides optional prompt title metadata. 049 * 050 * @return the prompt title, if available 051 */ 052 @NonNull 053 default Optional<String> getTitle() { 054 return Optional.empty(); 055 } 056 057 /** 058 * Provides the argument schema used for validation and prompt argument advertisement. 059 * 060 * @return the prompt argument schema 061 */ 062 @NonNull 063 McpSchema getArgumentsSchema(); 064 065 /** 066 * Handles an MCP {@code prompts/get} request. 067 * 068 * @param context the prompt handler context 069 * @return the prompt result 070 * @throws Exception if prompt generation fails 071 */ 072 @NonNull 073 McpPromptResult handle(@NonNull McpPromptHandlerContext context) throws Exception; 074}