Construire le message et appeler le LLM
Avec votre fonction utilitaire get_context_from_mcp(user_query) qui renvoie le texte de ressource et le texte d'invite, il est temps de transmettre ces informations au LLM !
Le serveur de devises, get_context_from_mcp(), get_tools_from_mcp(), call_mcp_tool() et le client Claude sont configurés en arrière-plan. Vous devez compléter la fonction qui construit l'invite, appelle le modèle et gère soit un message direct, soit un appel d'outil. On vous a fourni une saisie utilisateur ambiguë et une autre non ambiguë pour voir si vos invites MCP ont fait la différence !
Cet exercice fait partie du cours
<cours>Introduction au Model Context Protocol (MCP)</cours>Instructions de l’exercice
- À la ligne 37, construisez
full_prompten concaténantprompt_text, la chaîne"\n\nSupported currencies:\n", puisresource_text. - À la ligne 47, envoyez le
full_prompt(comme contenu du message utilisateur) ainsi que la listeanthropic_toolsau modèle. - Aux lignes 52-55, si la valeur
stop_reasonde la réponse est"end_turn", retournezstr(text). - Aux lignes 58-60, si la valeur
stop_reasonde la réponse est"tool_use", passez le.nameet le.inputdu bloc d'utilisation d'outil àcall_mcp_tool().
Exercice interactif pratique
Essayez cet exercice en complétant ce code d’exemple.
from mcp import ClientSession, StdioServerParameters
from mcp.client.stdio import stdio_client
async def get_context_from_mcp(user_query: str) -> tuple[str, str]:
params = StdioServerParameters(command=sys.executable, args=["currency_server.py"])
async with stdio_client(params) as (reader, writer):
async with ClientSession(reader, writer) as session:
await session.initialize()
resource_result = await session.read_resource("file://currencies.txt")
resource_text = resource_result.contents[0].text
prompt_result = await session.get_prompt("convert_currency_prompt",
arguments={"currency_request": user_query})
prompt_text = prompt_result.messages[0].content.text
return resource_text, prompt_text
async def get_tools_from_mcp():
params = StdioServerParameters(command=sys.executable, args=["currency_server.py"])
async with stdio_client(params) as (reader, writer):
async with ClientSession(reader, writer) as session:
await session.initialize()
response = await session.list_tools()
return response.tools
async def call_mcp_tool(tool_name: str, arguments: dict) -> str:
params = StdioServerParameters(command=sys.executable, args=["currency_server.py"])
async with stdio_client(params) as (reader, writer):
async with ClientSession(reader, writer) as session:
await session.initialize()
result = await session.call_tool(tool_name, arguments)
return str(result.content[0].text)
async def call_llm_with_context(user_query: str):
"""Call the LLM with resource and prompt context from MCP."""
resource_text, prompt_text = await get_context_from_mcp(user_query)
# Combine the resource and prompt text
full_prompt = ____ + "\n\nSupported currencies:\n" + ____
client = AsyncAnthropic(api_key="")
mcp_tools = await get_tools_from_mcp()
anthropic_tools = [{"name": t.name, "description": t.description or "", "input_schema": t.inputSchema} for t in mcp_tools]
# Send full_prompt (as a user message) and the tools list to the model
response = await client.messages.create(
model="claude-sonnet-4-6",
max_tokens=1024,
messages=[{"role": "user", "content": ____}],
tools=anthropic_tools,
)
# Return the text response
if response.stop_reason == "____":
text = next((block.text for block in response.content if block.type == "text"), "")
print(f"\nAssistant: {text}")
return str(____)
# Call the tool requested in the LLM's tool use
if response.stop_reason == "____":
tool_use = next(block for block in response.content if block.type == "tool_use")
result = await call_mcp_tool(____.name, ____)
followup = await client.messages.create(
model="claude-sonnet-4-6",
max_tokens=1024,
messages=[
{"role": "user", "content": full_prompt},
{"role": "assistant", "content": response.content},
{"role": "user", "content": [{"type": "tool_result", "tool_use_id": tool_use.id, "content": result}]},
],
tools=anthropic_tools,
)
final_text = next((block.text for block in followup.content if block.type == "text"), None)
if final_text:
print(f"\nAssistant: {final_text}")
return str(final_text)
print("=== Ambiguous request (prompt asks for clarification) ===")
asyncio.run(call_llm_with_context("Convert some euros to dollars"))
print("\n=== Unambiguous request (model calls tool) ===")
asyncio.run(call_llm_with_context("How much is 50 GBP in euros?"))