Rendre les appels d'outils d'API robustes
En production, l'outil convert_currency() du serveur de devises ne doit pas rester bloqué si l'API de taux de change est lente ou indisponible. Pour atténuer ce risque, vous allez ajouter un timeout à la requête et faire en sorte que toute défaillance renvoie à l'utilisateur un message d'erreur court et clair, plutôt qu'une exception brute.
Un serveur MCP a déjà été instancié et stocké dans la variable mcp.
Cet exercice fait partie du cours
<cours>Introduction au Model Context Protocol (MCP)</cours>Instructions de l’exercice
- Implémentez une logique try-except qui tentera l'appel à l'API et échouera proprement en cas d'erreur en capturant l'exception.
- Ajoutez un délai d'expiration de 10 secondes à l'appel
requests.get()pour éviter que la requête ne reste bloquée indéfiniment.
Exercice interactif pratique
Essayez cet exercice en complétant ce code d’exemple.
@mcp.tool()
def convert_currency(amount: float, from_currency: str, to_currency: str) -> str:
"""
Convert an amount from one currency to another using current exchange rates.
Args:
amount: The amount to convert
from_currency: Source currency code (e.g., 'USD', 'EUR', 'GBP')
to_currency: Target currency code (e.g., 'USD', 'EUR', 'GBP')
Returns:
A string with the conversion result and exchange rate
"""
url = f"https://api.frankfurter.dev/v1/latest?base={from_currency}&symbols={to_currency}"
# Implement try-except to gracefully handle errors
____:
# Add a 10-second timeout so the request does not hang
r = requests.get(url, ____=____)
r.raise_for_status()
data = r.json()
rate = data["rates"].get(to_currency)
if rate is None:
return f"Could not find exchange rate for {from_currency} to {to_currency}"
return f"{amount} {from_currency} = {amount * rate:.2f} {to_currency} (Rate: {rate})"
____ requests.exceptions.RequestException as e:
return f"Error converting currency: {e}"
print(convert_currency(10, "USD", "EUR"))