Tornando Chamadas de Ferramentas de API Robusas
Em produção, a ferramenta convert_currency() do servidor de câmbio não deve travar se a API de taxas de câmbio estiver lenta ou indisponível. Para mitigar isso, você vai implementar um timeout na requisição e garantir que qualquer falha retorne uma mensagem de erro curta e clara para o usuário em vez de uma exceção bruta.
Um servidor MCP já foi instanciado e armazenado na variável mcp.
Este exercicio faz parte do curso
Introdução ao Model Context Protocol (MCP)
Instruções do exercicio
- Implemente a lógica com try-except que tentará a requisição à API e falhará de forma elegante caso ocorra um erro, capturando a exceção.
- Adicione um timeout de 10 segundos à chamada
requests.get()para que a requisição não fique pendente indefinidamente.
exercicio interativo prático
Tente este exercicio completando este código de exemplo.
@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"))