Show raw JSON evidence
{
"checks": {
"action_safety_probe": {
"details": {
"auth_present": false,
"confirmation_signals": [],
"safeguard_count": 2,
"summary": {
"bulk_access_tools": 5,
"capability_distribution": {
"admin": 3,
"delete": 1,
"exec": 4,
"export": 5,
"network": 4,
"read": 19,
"secrets": 3,
"write": 12
},
"destructive_tools": 1,
"egress_tools": 1,
"exec_tools": 4,
"high_risk_tools": 4,
"risk_distribution": {
"critical": 3,
"high": 1,
"low": 3,
"medium": 12
},
"secret_tools": 3,
"tool_count": 19
}
},
"latency_ms": null,
"status": "error"
},
"advanced_capabilities_probe": {
"details": {
"capabilities": {
"completions": false,
"elicitation": false,
"prompts": true,
"resource_links": false,
"resources": true,
"roots": false,
"sampling": false,
"structured_outputs": false
},
"enabled": [
"prompts",
"resources"
],
"enabled_count": 2,
"initialize_capability_keys": [
"tools"
]
},
"latency_ms": null,
"status": "warning"
},
"connector_publishability_probe": {
"details": {
"blockers": [
"action_safety",
"server_card"
],
"criteria": {
"action_safety": false,
"auth_flow": true,
"connector_replay": true,
"initialize": true,
"protocol_version": true,
"remote_transport": true,
"request_association": true,
"server_card": false,
"session_resume": true,
"step_up_auth": true,
"tool_surface": true,
"tools_list": true,
"transport_compliance": true
},
"high_risk_tools": 4,
"tool_count": 19,
"transport": "streamable-http"
},
"latency_ms": null,
"status": "warning"
},
"connector_replay_probe": {
"details": {
"added_tools": [],
"additive_output_changes": [],
"backward_compatible": true,
"output_breaks": [],
"removed_tools": [],
"required_arg_breaks": [],
"would_break_after_refresh": false
},
"latency_ms": null,
"status": "ok"
},
"determinism_probe": {
"details": {
"attempts": 2,
"baseline_signature": "73d64dab0e41c2ed5c1b2e4746064da9e9f7bcd7afe8ea29023a3e5e501bea85",
"errors": [],
"matches": 2,
"stable_ratio": 1.0,
"successful": 2
},
"latency_ms": 139.37,
"status": "ok"
},
"initialize": {
"details": {
"headers": {
"content-type": "text/event-stream"
},
"http_status": 200,
"payload": {
"id": 1,
"jsonrpc": "2.0",
"result": {
"capabilities": {
"tools": {}
},
"protocolVersion": "2025-03-26",
"serverInfo": {
"name": "mcp-server-platform",
"version": "1.0.0"
}
}
},
"url": "https://mcp-server-295985738387.europe-west1.run.app/mcp"
},
"latency_ms": 117.6,
"status": "ok"
},
"interactive_flow_probe": {
"details": {
"oauth_supported": false,
"prompt_available": false,
"risk_hits": [],
"safe_hits": [
"login"
]
},
"latency_ms": null,
"status": "ok"
},
"oauth_authorization_server": {
"details": {
"reason": "no_authorization_server"
},
"latency_ms": null,
"status": "missing"
},
"oauth_protected_resource": {
"details": {
"error": "Client error '404 Not Found' for url 'https://mcp-server-295985738387.europe-west1.run.app/.well-known/oauth-protected-resource'\nFor more information check: https://developer.mozilla.org/en-US/docs/Web/HTTP/Status/404",
"url": "https://mcp-server-295985738387.europe-west1.run.app/.well-known/oauth-protected-resource"
},
"latency_ms": 114.13,
"status": "error"
},
"official_registry_probe": {
"details": {
"direct_match": true,
"official_peer_count": 1,
"registry_identifier": "ai.bankee/inferventis-mcp",
"registry_source": "official_registry"
},
"latency_ms": null,
"status": "ok"
},
"openid_configuration": {
"details": {
"reason": "no_authorization_server"
},
"latency_ms": null,
"status": "missing"
},
"probe_noise_resilience": {
"details": {
"headers": {
"content-type": "application/json; charset=utf-8"
},
"http_status": 404,
"url": "https://mcp-server-295985738387.europe-west1.run.app/robots.txt"
},
"latency_ms": 111.4,
"status": "ok"
},
"prompt_get": {
"details": {
"reason": "not_advertised"
},
"latency_ms": null,
"status": "missing"
},
"prompts_list": {
"details": {
"error": "Client error '401 Unauthorized' for url 'https://mcp-server-295985738387.europe-west1.run.app/mcp'\nFor more information check: https://developer.mozilla.org/en-US/docs/Web/HTTP/Status/401",
"headers": {
"content-type": "application/json; charset=utf-8"
},
"http_status": 401,
"payload": {},
"reason": "auth_required",
"url": "https://mcp-server-295985738387.europe-west1.run.app/mcp"
},
"latency_ms": 117.68,
"status": "auth_required"
},
"protocol_version_probe": {
"details": {
"claimed_version": "2025-03-26",
"lag_days": 244,
"latest_known_version": "2025-11-25",
"releases_behind": 2,
"validator_protocol_version": "2025-03-26"
},
"latency_ms": null,
"status": "warning"
},
"provenance_divergence_probe": {
"details": {
"direct_official_match": true,
"drift_fields": [],
"metadata_document_count": 2,
"registry_homepage": null,
"registry_repository": null,
"registry_title": null,
"registry_version": null,
"server_card_homepage": null,
"server_card_repository": null,
"server_card_title": null,
"server_card_version": null
},
"latency_ms": null,
"status": "ok"
},
"request_association_probe": {
"details": {
"reason": "no_request_association_capabilities_advertised"
},
"latency_ms": null,
"status": "missing"
},
"resource_read": {
"details": {
"reason": "not_advertised"
},
"latency_ms": null,
"status": "missing"
},
"resources_list": {
"details": {
"error": "Client error '401 Unauthorized' for url 'https://mcp-server-295985738387.europe-west1.run.app/mcp'\nFor more information check: https://developer.mozilla.org/en-US/docs/Web/HTTP/Status/401",
"headers": {
"content-type": "application/json; charset=utf-8"
},
"http_status": 401,
"payload": {},
"reason": "auth_required",
"url": "https://mcp-server-295985738387.europe-west1.run.app/mcp"
},
"latency_ms": 111.63,
"status": "auth_required"
},
"server_card": {
"details": {
"error": "Client error '404 Not Found' for url 'https://mcp-server-295985738387.europe-west1.run.app/.well-known/mcp/server-card.json'\nFor more information check: https://developer.mozilla.org/en-US/docs/Web/HTTP/Status/404",
"url": "https://mcp-server-295985738387.europe-west1.run.app/.well-known/mcp/server-card.json"
},
"latency_ms": 162.17,
"status": "error"
},
"session_resume_probe": {
"details": {
"protocol_version": "2025-03-26",
"reason": "no_session_id",
"resume_expected": true,
"transport": "streamable-http"
},
"latency_ms": null,
"status": "warning"
},
"step_up_auth_probe": {
"details": {
"auth_required_checks": [
"prompts_list",
"resources_list"
],
"broad_scopes": [],
"challenge_headers": [],
"minimal_scope_documented": false,
"oauth_present": false,
"scope_specificity_ratio": 0.0,
"step_up_signals": [],
"supported_scopes": []
},
"latency_ms": null,
"status": "warning"
},
"tool_snapshot_probe": {
"details": {
"added": [],
"changed_outputs": [],
"current_tool_count": 19,
"previous_tool_count": 19,
"removed": [],
"similarity": 1.0
},
"latency_ms": null,
"status": "ok"
},
"tools_list": {
"details": {
"headers": {
"content-type": "text/event-stream"
},
"http_status": 200,
"payload": {
"id": 2,
"jsonrpc": "2.0",
"result": {
"tools": [
{
"description": "Retrieves bank account details and recent transaction history via a connected bank API integration. Returns a list of transactions for the specified account, or for all linked accounts when no account ID is provided. Use bank_accounts when an agent needs to inspect account balances, review recent spending, categorise transactions, or reconcile records against a specific bank account. Prefer open_banking_transactions when the integration uses a PSD2 Open Banking provider (TrueLayer) covering 300+ UK and European banks \u2014 open_banking_transactions returns richer transaction metadata including merchant names, categories, and running balances. Prefer stripe_payments when the source of payments is a Stripe merchant account rather than a retail bank account. This tool requires a valid bank API credential to be configured on the server.",
"inputSchema": {
"properties": {
"account_id": {
"description": "Identifier of the specific bank account to query. When omitted, transactions across all linked accounts are returned.",
"type": "string"
},
"limit": {
"description": "Maximum number of transactions to return. Defaults to 20. Maximum 100.",
"type": "number"
}
},
"required": [],
"type": "object"
},
"name": "bank_accounts"
},
{
"description": "Retrieves real-time price data for any cryptocurrency listed on CoinGecko. Returns the current price in any fiat currency, 24-hour percentage change, market capitalisation, and 24-hour trading volume. Supports all major cryptocurrencies including Bitcoin (BTC), Ethereum (ETH), Solana (SOL), XRP, Cardano (ADA), Dogecoin (DOGE), Polygon (MATIC), Chainlink (LINK), Avalanche (AVAX), and 10,000+ additional coins. Use crypto_price when an agent needs the full market picture for a digital asset \u2014 price, change, market cap, and volume in one call. Prefer crypto_price_lite when only the spot price and 24h change are needed and a smaller response payload is preferred. Use crypto_fx_rates (via CoinAPI) when converting a specific amount between a cryptocurrency and fiat, or between two cryptocurrencies. Do not use this tool for fiat-to-fiat currency conversion (e.g. USD to EUR) \u2014 use currency_convert instead. Do not use when historical price data for a specific past date is required \u2014 this tool returns live spot prices only.",
"inputSchema": {
"properties": {
"coin": {
"description": "Cryptocurrency name or ticker symbol. Accepts common symbols (BTC, ETH, SOL, XRP, ADA, DOGE, MATIC, LINK, AVAX) or full names (bitcoin, ethereum, solana). Case-insensitive.",
"type": "string"
},
"currency": {
"description": "Target fiat currency code for the price. Must be a valid ISO 4217 code. Defaults to USD. Examples: usd, eur, gbp, jpy, chf, aud, cad.",
"type": "string"
},
"include_market_data": {
"description": "Whether to include market capitalisation and 24-hour trading volume alongside the price. Defaults to true. Set to false for a lighter response when only the price is needed.",
"type": "boolean"
}
},
"required": [
"coin"
],
"type": "object"
},
"name": "crypto_price"
},
{
"description": "Retrieves the current spot price and 24-hour change for any cryptocurrency using the CoinGecko public API. Returns price, percentage change, and a timestamp. This is a lightweight variant of crypto_price that omits extended market data (market cap, volume) \u2014 use it when only the raw price and 24h direction are needed. Prefer crypto_price when the agent also needs market capitalisation, trading volume, or richer structured output. Use crypto_fx_rates when converting a specific amount between a cryptocurrency and fiat (e.g. 'convert 0.5 BTC to USD') rather than looking up a spot price. Supports all major coins including BTC, ETH, SOL, XRP, ADA, DOGE, and 10,000+ CoinGecko-listed assets. Accepts ticker symbols (BTC, ETH) or full names (bitcoin, ethereum). Target currency defaults to USD but accepts any ISO 4217 code.",
"inputSchema": {
"properties": {
"coin": {
"description": "Cryptocurrency ticker symbol (BTC, ETH, SOL) or full CoinGecko name (bitcoin, ethereum, solana). Case-insensitive.",
"type": "string"
},
"currency": {
"description": "ISO 4217 fiat currency code for the returned price. Defaults to 'usd'. Examples: usd, eur, gbp, jpy.",
"type": "string"
}
},
"required": [
"coin"
],
"type": "object"
},
"name": "crypto_price_lite"
},
{
"description": "Converts a monetary amount from one currency to another using live exchange rates sourced from the Frankfurter API (European Central Bank data). Returns the converted amount, the exact exchange rate applied, and the timestamp of the rate. Supports 30+ currencies including USD, EUR, GBP, JPY, CHF, AUD, CAD, SEK, NOK, DKK, SGD, HKD, and all major ISO 4217 codes. Use currency_convert when an agent needs to convert prices, invoices, salaries, payments, or any financial figure between fiat currencies in real time with full ECB-backed rate metadata. Prefer currency_convert_lite or currency_fx_lite when only the numeric converted amount and rate are needed without metadata. Use currency_rates when the conversion must use a historical rate from a specific past date. Do not use this tool for cryptocurrency conversion \u2014 use crypto_fx_rates (amount conversion via CoinAPI) or crypto_price (spot price lookup via CoinGecko).",
"inputSchema": {
"properties": {
"amount": {
"description": "The monetary amount to convert. Must be a positive number. Decimals are supported. Example: 1500.50 to convert one thousand five hundred and fifty cents.",
"type": "number"
},
"from": {
"description": "The source currency code in ISO 4217 format. Must be uppercase. Examples: USD, GBP, EUR, JPY, CHF, AUD, CAD.",
"type": "string"
},
"to": {
"description": "The target currency code in ISO 4217 format. Must be uppercase. Examples: EUR, JPY, CHF, SGD, HKD, SEK.",
"type": "string"
}
},
"required": [
"amount",
"from",
"to"
],
"type": "object"
},
"name": "currency_convert"
},
{
"description": "Converts a monetary amount between any two fiat currencies using live exchange rates from the Frankfurter API (European Central Bank data). Returns the converted amount and the exchange rate applied. This is a lightweight variant of currency_convert \u2014 minimal response without rate timestamp or source attribution. Use currency_convert_lite when only the converted value and rate are needed and ECB/Frankfurter-sourced rates are preferred. Prefer currency_convert when the agent also needs rate timestamp and richer structured output. Prefer currency_fx_lite for the same minimal output (amount + rate) when the ECB data source is not specifically required \u2014 both return identical fields but draw from different rate providers. Use currency_rates when a historical rate from a specific past date is required (e.g. accounting, tax, or audit). Use currency_convert_open as a fallback when Frankfurter is unavailable or rate-limited. Does not support cryptocurrency pairs \u2014 use crypto_price or crypto_fx_rates for crypto-to-fiat conversions. Accepts all major ISO 4217 currency codes (USD, EUR, GBP, JPY, CHF, AUD, CAD, SGD, NOK, SEK, DKK, PLN, CZK, HUF, etc.).",
"inputSchema": {
"properties": {
"amount": {
"description": "Monetary amount to convert. Must be a positive number.",
"type": "number"
},
"from": {
"description": "ISO 4217 code of the source currency (e.g. 'USD', 'GBP', 'EUR'). Case-insensitive.",
"type": "string"
},
"to": {
"description": "ISO 4217 code of the target currency (e.g. 'EUR', 'JPY', 'CHF'). Case-insensitive.",
"type": "string"
}
},
"required": [
"amount",
"from",
"to"
],
"type": "object"
},
"name": "currency_convert_lite"
},
{
"description": "Performs precise financial calculations across six calculation types entirely locally with no external API dependency. compound_interest computes the final value and total interest earned on a principal over time at a given annual rate. loan_repayment calculates the monthly payment, total repayable amount, and total interest for a mortgage or loan given the principal, annual rate, and term in months. roi returns return on investment as a percentage and absolute profit or loss, with optional annualised ROI when a holding period is provided. present_value discounts a future cash amount back to its current value using a discount rate. future_value projects a present amount forward at a compounding annual rate. break_even finds the unit volume and revenue at which fixed and variable costs are fully covered by sales. Use this tool when an agent needs to perform any structured financial calculation \u2014 loan affordability, investment return, discounted cash flow, or cost analysis. Prefer financial_calculator_lite when only the single headline result is needed rather than a full structured breakdown. Do not use this tool to fetch live market prices or exchange rates \u2014 use stock_quote for stock prices, crypto_price for cryptocurrency prices, or currency_convert for FX rates.",
"inputSchema": {
"properties": {
"calculator_type": {
"description": "The type of financial calculation to perform. Must be one of: compound_interest, loan_repayment, roi, present_value, future_value, break_even.",
"type": "string"
},
"discount_rate": {
"description": "Annual discount rate as a percentage for present value calculations. Represents the required rate of return or cost of capital.",
"type": "number"
},
"final_value": {
"description": "Ending value of an investment or asset. Used for roi and present_value calculations.",
"type": "number"
},
"fixed_costs": {
"description": "Total fixed costs of the business or project that do not vary with output volume. Used for break_even calculations.",
"type": "number"
},
"future_amount": {
"description": "The target future cash amount to discount back to present value. Used for present_value calculations.",
"type": "number"
},
"initial_value": {
"description": "Starting value of an investment or asset. Used for roi calculations.",
"type": "number"
},
"periods": {
"description": "Number of time periods. For compound_interest and future_value: years. For loan_repayment: months. For roi: years used for annualised ROI.",
"type": "number"
},
"price_per_unit": {
"description": "The selling price per unit of product or service. Used for break_even calculations.",
"type": "number"
},
"principal": {
"description": "Starting amount or loan amount in your chosen currency. Used for compound_interest, loan_repayment, and future_value calculations.",
"type": "number"
},
"rate": {
"description": "Annual interest or discount rate expressed as a percentage. Example: 5 for 5% per year. Used for compound_interest, loan_repayment, present_value, and future_value.",
"type": "number"
},
"variable_cost_per_unit": {
"description": "The variable cost incurred for each unit produced or sold. Used for break_even calculations.",
"type": "number"
}
},
"required": [
"calculator_type"
],
"type": "object"
},
"name": "financial_calculator"
},
{
"description": "Performs common financial calculations locally with no external API dependency. Supports compound interest, loan repayment, return on investment (ROI), present value, future value, and break-even analysis. Returns a single numeric result for the requested calculation type. This is a lightweight variant of financial_calculator \u2014 it returns only the result number rather than a full structured breakdown (monthly payment, total interest, annualised ROI, etc.). Use financial_calculator_lite when only the headline figure is needed. Prefer financial_calculator when the agent needs a full breakdown, multiple sub-values, or labelled output fields for compound interest earned, total repayable, or annualised returns. Neither this tool nor financial_calculator fetches live market data \u2014 for live prices use stock_quote, crypto_price, or currency_convert.",
"inputSchema": {
"properties": {
"calculator_type": {
"description": "Type of calculation to perform. Accepted values: 'compound_interest', 'loan_repayment', 'roi', 'present_value', 'future_value', 'break_even'.",
"type": "string"
},
"final_value": {
"description": "Final investment value. Required for roi calculations.",
"type": "number"
},
"initial_value": {
"description": "Initial investment amount. Required for roi calculations.",
"type": "number"
},
"periods": {
"description": "Number of compounding periods (years) or loan term in months depending on calculator_type. Required for compound_interest, loan_repayment, future_value, and present_value.",
"type": "number"
},
"principal": {
"description": "Starting amount or loan principal in currency units. Required for compound_interest, loan_repayment, present_value, and future_value.",
"type": "number"
},
"rate": {
"description": "Annual interest or discount rate as a decimal (e.g. 0.05 for 5%). Required for compound_interest, loan_repayment, present_value, and future_value.",
"type": "number"
}
},
"required": [
"calculator_type"
],
"type": "object"
},
"name": "financial_calculator_lite"
},
{
"description": "Retrieves real-time stock price quotes and company information for any publicly traded company via the Finnhub API. Returns current price, intraday high and low, percentage change from previous close, previous close price, sector, and exchange. Use stock_quote when an agent needs to look up a stock price, check intraday market performance, retrieve company sector data, monitor equity portfolio values, or answer any question about the current trading price of a publicly listed company. Prefer stock_quote over stock_price_lite when the agent needs price change, intraday range, company name, or sector \u2014 stock_price_lite returns only the raw current price with no additional context. Do not use for cryptocurrency prices \u2014 use crypto_price (CoinGecko, 10,000+ assets) or crypto_price_lite for a lightweight variant. Do not use for fiat currency conversion \u2014 use currency_convert or currency_fx_lite. Requires a Finnhub API key to be configured on the server.",
"inputSchema": {
"properties": {
"include_company_info": {
"description": "Whether to include company name, sector, and exchange details alongside the price quote. Defaults to true. Set to false for a faster, price-only response.",
"type": "boolean"
},
"symbol": {
"description": "Stock ticker symbol in uppercase. Examples: AAPL (Apple), MSFT (Microsoft), TSLA (Tesla), GOOGL (Alphabet), AMZN (Amazon), NVDA (Nvidia). Must be a valid exchange-listed ticker symbol.",
"type": "string"
}
},
"required": [
"symbol"
],
"type": "object"
},
"name": "stock_quote"
},
{
"description": "Converts a foreign exchange (FX) amount between two fiat currencies using live mid-market rates. Returns the converted amount and the exchange rate applied. Use currency_fx_lite when only the numeric result is required and the ECB/Frankfurter data source is not specifically needed. Prefer currency_convert when richer metadata (rate timestamp, ECB-backed Frankfurter source) is needed. Prefer currency_convert_lite for the same minimal output (amount + rate) when ECB/Frankfurter rates are specifically required \u2014 both tools return identical fields but draw from different rate providers. Use currency_rates when a historical rate from a specific past date is required. Use currency_convert_open as an alternative open-rate source. Does not support cryptocurrency pairs \u2014 use crypto_fx_rates for crypto-to-fiat or crypto-to-crypto conversions, or crypto_price_lite for a spot price lookup. Accepts all major ISO 4217 currency codes.",
"inputSchema": {
"properties": {
"amount": {
"description": "Monetary amount to convert. Must be a positive number.",
"type": "number"
},
"from": {
"description": "ISO 4217 source currency code (e.g. 'USD', 'GBP', 'EUR', 'JPY'). Case-insensitive.",
"type": "string"
},
"to": {
"description": "ISO 4217 target currency code (e.g. 'EUR', 'CHF', 'AUD', 'CAD'). Case-insensitive.",
"type": "string"
}
},
"required": [
"amount",
"from",
"to"
],
"type": "object"
},
"name": "currency_fx_lite"
},
{
"description": "Retrieves the latest real-time news headlines and article summaries from BBC News and The Guardian across nine topic categories. Returns structured articles with headline, description, source name, article URL, and publication date \u2014 sorted most recent first. No API key required. Use this tool when an agent needs current news about a specific topic, wants to summarise today's headlines, needs to research recent events, monitor a subject area for new developments, or build a news briefing. Do not use this tool to read the full content of a specific article \u2014 use web_url_reader instead, passing the article URL returned by this tool. Do not use when news from sources outside BBC News and The Guardian is required.",
"inputSchema": {
"properties": {
"keyword": {
"description": "Optional search keyword to filter headlines. Only articles whose title or description contains this keyword will be returned. Case-insensitive. Examples: 'OpenAI', 'interest rates', 'climate change'. Omit to return all headlines for the chosen topic.",
"type": "string"
},
"limit": {
"description": "Maximum number of articles to return. Integer between 1 and 20. Defaults to 10. Use a lower number for a quick briefing and a higher number for comprehensive coverage.",
"type": "number"
},
"topic": {
"description": "News topic category to retrieve headlines for. Accepted values: 'general' (top stories across all categories), 'technology' (tech industry and digital news), 'business' (markets, economy, and corporate news), 'science' (research, environment, and discoveries), 'health' (medical and public health news), 'politics' (government and political news), 'sport' (sports and athletics), 'ai' (artificial intelligence and machine learning news), 'world' (international and global news). Defaults to 'general' if omitted or unrecognised.",
"type": "string"
}
},
"required": [],
"type": "object"
},
"name": "web_news_headlines"
},
{
"description": "Retrieves bank account balances and transaction history via PSD2 Open Banking (TrueLayer), covering 300+ UK and European banks. Returns the account balance, ISO 4217 currency code, and up to 100 recent transactions \u2014 each with date, merchant description, amount, and category. Supports optional date filtering to narrow the transaction window. Use this tool when an agent needs to inspect a user's spending history, verify a payment has cleared, assess account affordability, categorise recent bank transactions, or produce a financial summary from live bank data. Do not use for payment initiation \u2014 this tool is strictly read-only. Do not use for Stripe-specific payment records, subscription billing, or failed charge investigation \u2014 use stripe_payments instead. Requires a TrueLayer access token; returns structured mock data if no token is configured.",
"inputSchema": {
"properties": {
"account_id": {
"description": "TrueLayer account ID to retrieve transactions for. Obtain from a prior account-listing call. Omit to return data for the first connected account.",
"type": "string"
},
"from_date": {
"description": "Optional start date for filtering transactions. ISO 8601 date format: YYYY-MM-DD. Example: 2026-01-01 to retrieve transactions from 1 January 2026 onwards.",
"type": "string"
},
"limit": {
"description": "Maximum number of transactions to return. Integer between 1 and 100. Defaults to 10.",
"type": "number"
}
},
"required": [],
"type": "object"
},
"name": "open_banking_transactions"
},
{
"description": "Retrieves payment and charge records from a Stripe merchant account. Returns a list of payment records filtered by the requested query type. Use stripe_payment_records when an agent needs to review recent charges, refunds, disputes, or subscription payments from a Stripe account. This is a lightweight variant of stripe_payments \u2014 it returns a simple records array rather than the full structured Stripe response with customer details, metadata, and pagination cursors. Prefer stripe_payments when the agent needs complete Stripe charge objects including customer IDs, payment method details, metadata fields, and processing status breakdowns. Prefer open_banking_transactions or bank_accounts when the payment data source is a bank account rather than a Stripe merchant account. Requires a Stripe API key to be configured on the server.",
"inputSchema": {
"properties": {
"limit": {
"description": "Maximum number of records to return. Defaults to 10. Maximum 50.",
"type": "number"
},
"query_type": {
"description": "Type of payment records to retrieve. Accepted values: 'recent_payments' (latest charges), 'refunds' (refund records), 'disputes' (disputed charges), 'subscriptions' (recurring subscription payments).",
"type": "string"
}
},
"required": [
"query_type"
],
"type": "object"
},
"name": "stripe_payment_records"
},
{
"description": "Converts an amount between any cryptocurrency and fiat currency pair, or between two cryptocurrencies, using real-time exchange rates sourced from CoinAPI. Supports all crypto-to-fiat (BTC/USD, ETH/EUR), fiat-to-crypto (USD/BTC), and cross-crypto (BTC/ETH) conversions. Use crypto_fx_rates when the conversion involves at least one cryptocurrency and a specific amount must be converted. Prefer crypto_price when only the spot price of a coin in fiat is needed without converting a specific amount, or prefer crypto_price_lite for the same spot price with a minimal response schema. Prefer currency_convert or currency_fx_lite when both currencies are fiat \u2014 those tools use ECB/Frankfurter or mid-market rates and do not consume a CoinAPI quota. Requires a CoinAPI key to be configured on the server.",
"inputSchema": {
"properties": {
"amount": {
"description": "Amount to convert. Must be a positive number. Denominated in the 'from' currency.",
"type": "number"
},
"from": {
"description": "Source currency code. Accepts ISO 4217 fiat codes (USD, EUR, GBP) or cryptocurrency ticker symbols (BTC, ETH, SOL, XRP). Case-insensitive.",
"type": "string"
},
"to": {
"description": "Target currency code. Accepts ISO 4217 fiat codes (USD, EUR, GBP) or cryptocurrency ticker symbols (BTC, ETH, SOL, XRP). Case-insensitive.",
"type": "string"
}
},
"required": [
"amount",
"from",
"to"
],
"type": "object"
},
"name": "crypto_fx_rates"
},
{
"description": "Retrieves live and historical fiat currency exchange rates from the Frankfurter API (sourced from the European Central Bank). Supports both real-time conversion and historical rate lookup for any past date, making it the preferred tool when auditable, ECB-sourced rate data is required. Use currency_rates when a rate from a specific past date is required (e.g. accounting, tax, or audit), or when the ECB source must be documented. Prefer currency_convert when only a live conversion is needed with a richer structured response. Prefer currency_convert_lite for lightweight live ECB conversions without historical requirements. Prefer currency_fx_lite when ECB sourcing is not required and only a lightweight live result is needed. Use currency_convert_open when a non-ECB rate source is acceptable and Frankfurter is unavailable. Does not support cryptocurrency pairs \u2014 use crypto_fx_rates for any conversion involving a digital asset.",
"inputSchema": {
"properties": {
"amount": {
"description": "Monetary amount to convert. Must be a positive number.",
"type": "number"
},
"from": {
"description": "ISO 4217 source currency code (e.g. 'USD', 'GBP', 'EUR'). Case-insensitive.",
"type": "string"
},
"to": {
"description": "ISO 4217 target currency code (e.g. 'EUR', 'JPY', 'CHF'). Case-insensitive.",
"type": "string"
}
},
"required": [
"amount",
"from",
"to"
],
"type": "object"
},
"name": "currency_rates"
},
{
"description": "Converts a monetary amount between two fiat currencies using live exchange rates from an open currency exchange API. Returns the converted amount and the rate applied. Use currency_convert_open as an alternative live-rate source when currency_convert (Frankfurter/ECB) or currency_fx_lite are unavailable or rate-limited. The underlying source is an open public exchange rate feed suitable for informational use. Prefer currency_convert or currency_rates when ECB-auditable Frankfurter rates are required for accounting or compliance. Prefer currency_convert_lite for the same minimal output (amount + rate) backed by ECB/Frankfurter rates. Prefer currency_fx_lite for lightweight mid-market conversions. Does not support cryptocurrency pairs \u2014 use crypto_fx_rates for any conversion involving a digital asset.",
"inputSchema": {
"properties": {
"amount": {
"description": "Monetary amount to convert. Must be a positive number.",
"type": "number"
},
"from": {
"description": "ISO 4217 source currency code (e.g. 'USD', 'GBP', 'EUR'). Case-insensitive.",
"type": "string"
},
"to": {
"description": "ISO 4217 target currency code (e.g. 'EUR', 'JPY', 'CHF'). Case-insensitive.",
"type": "string"
}
},
"required": [
"amount",
"from",
"to"
],
"type": "object"
},
"name": "currency_convert_open"
},
{
"description": "Retrieves the current trading price for a publicly listed stock by ticker symbol. Returns the current price as a single numeric value. This is a lightweight variant of stock_quote \u2014 it omits intraday high/low, percentage change, previous close, company name, sector, and exchange metadata. Use stock_price_lite when only the raw current price is needed for a quick lookup or calculation. Prefer stock_quote when the agent also needs price change, intraday range, company information, or a fully structured response suitable for portfolio reporting. Does not support cryptocurrency prices \u2014 use crypto_price for full market data (price, volume, market cap) or crypto_price_lite for a lightweight spot price lookup.",
"inputSchema": {
"properties": {
"symbol": {
"description": "Stock ticker symbol in uppercase. Examples: AAPL (Apple), MSFT (Microsoft), TSLA (Tesla), GOOGL (Alphabet), AMZN (Amazon), NVDA (Nvidia). Must be a valid exchange-listed ticker.",
"type": "string"
}
},
"required": [
"symbol"
],
"type": "object"
},
"name": "stock_price_lite"
},
{
"description": "Retrieves live payment data from a Stripe account via the Stripe API. Supports four query types: recent_payments returns the latest payment intents with status, amount, and currency; failed_charges returns declined or failed charges with failure reasons and error codes; customers returns customer records with name, email, and payment method details; subscriptions returns active and cancelled subscription plans with billing interval and status. Use stripe_payments when an agent needs to investigate payment failures, audit recent transaction activity, retrieve customer billing records, or check subscription status within a Stripe account \u2014 it returns full Stripe charge objects with customer IDs, metadata, and processing details. Prefer stripe_payment_records for a lighter-weight Stripe query returning only a simple records array without full Stripe object structure. Do not use for bank account transactions or PSD2 Open Banking data \u2014 use open_banking_transactions instead. Do not use for generic bank account history \u2014 use bank_accounts instead. Requires a Stripe secret key to be configured on the server.",
"inputSchema": {
"properties": {
"limit": {
"description": "Number of records to return. Integer between 1 and 25. Defaults to 10.",
"type": "number"
},
"query_type": {
"description": "The type of Stripe data to retrieve. Must be one of: recent_payments (latest payment intents), failed_charges (declined or failed charges with failure reasons), customers (customer records with contact and payment method info), subscriptions (billing subscriptions with status and plan details).",
"type": "string"
}
},
"required": [
"query_type"
],
"type": "object"
},
"name": "stripe_payments"
},
{
"description": "Discovers the most relevant tools available on this MCP server for a given task using local semantic search (MiniLM-L6-v2 embeddings). Accepts a plain-English description of what needs to be accomplished and returns the best matching tools ranked by relevance, along with their input schemas, pricing tier, and exact call instructions. Use this tool first when you are connected to this server but do not know which specific tool to call \u2014 describe your goal and let platform_tool_finder identify the right capability. Do not use this tool if you already know the tool name \u2014 call that tool directly instead. Returns up to 10 results ranked by semantic similarity score.",
"inputSchema": {
"properties": {
"intent": {
"description": "Plain-English description of what you need to accomplish. Be specific about the goal, not the tool name. Example: 'I need to convert 500 dollars to euros at the current exchange rate' or 'get the latest technology news headlines'.",
"type": "string"
},
"model_hint": {
"description": "Optional: the name of the calling LLM model. Examples: claude, gpt-4, gemini. Used to apply model-specific manifest variant ranking when available. Omit if unknown.",
"type": "string"
},
"top_k": {
"description": "How many ranked results to return. Integer between 1 and 10. Defaults to 3. Use a higher value when the best tool is ambiguous.",
"type": "number"
}
},
"required": [
"intent"
],
"type": "object"
},
"name": "platform_tool_finder"
},
{
"description": "Fetches any public web page and returns clean, readable plain text stripped of HTML, navigation, scripts, advertisements, and boilerplate. Returns the page title, meta description, word count, and main body text ready for analysis or summarisation. Use this tool when an agent needs to read the content of a specific web page or article URL \u2014 for example to summarise an article, extract facts from a page, verify a claim by reading the source, or convert a web page into plain text to pass to another tool. Pass article URLs returned by web_news_headlines to this tool to read full article content. Do not use this tool to discover current news headlines \u2014 use web_news_headlines instead. Does not execute JavaScript \u2014 best suited for standard HTML content pages. Will not work with paywalled, login-protected, or JavaScript-rendered single-page applications.",
"inputSchema": {
"properties": {
"include_links": {
"description": "Whether to include a list of hyperlinks found on the page alongside the text content. Defaults to false. Set to true when the agent needs to discover further URLs to follow, such as when crawling a site or finding references.",
"type": "boolean"
},
"max_chars": {
"description": "Maximum number of characters to return from the page body text. Defaults to 8000. Set higher (up to 50000) for long articles or documents. Set lower for quick headline extraction. The response indicates whether content was truncated.",
"type": "number"
},
"url": {
"description": "The full public URL to fetch and read. Must include the scheme. Examples: 'https://en.wikipedia.org/wiki/Artificial_intelligence', 'https://www.bbc.com/news/technology-12345678'. Only HTTP and HTTPS URLs are supported.",
"type": "string"
}
},
"required": [
"url"
],
"type": "object"
},
"name": "web_url_reader"
}
]
}
},
"url": "https://mcp-server-295985738387.europe-west1.run.app/mcp"
},
"latency_ms": 173.48,
"status": "ok"
},
"transport_compliance_probe": {
"details": {
"bad_protocol_error": null,
"bad_protocol_headers": {
"content-type": "application/json"
},
"bad_protocol_payload": {
"error": {
"code": -32000,
"message": "Bad Request: Unsupported protocol version: 1999-99-99 (supported versions: 2025-11-25, 2025-06-18, 2025-03-26, 2024-11-05, 2024-10-07)"
},
"id": null,
"jsonrpc": "2.0"
},
"bad_protocol_status_code": 400,
"delete_error": null,
"delete_status_code": null,
"expired_session_error": null,
"expired_session_status_code": null,
"issues": [
"missing_session_id",
"missing_protocol_header"
],
"last_event_id_visible": false,
"protocol_header_present": false,
"requested_protocol_version": "2025-03-26",
"session_id_present": false,
"transport": "streamable-http"
},
"latency_ms": 115.14,
"status": "warning"
},
"utility_coverage_probe": {
"details": {
"completions": {
"advertised": false,
"live_probe": "not_executed",
"sample_target": null
},
"initialize_capability_keys": [
"tools"
],
"pagination": {
"metadata_signal": false,
"next_cursor_methods": [],
"supported": false
},
"tasks": {
"advertised": false,
"http_status": 401,
"probe_status": "auth_required"
}
},
"latency_ms": 104.95,
"status": "ok"
}
},
"failures": {
"oauth_authorization_server": {
"reason": "no_authorization_server"
},
"oauth_protected_resource": {
"error": "Client error '404 Not Found' for url 'https://mcp-server-295985738387.europe-west1.run.app/.well-known/oauth-protected-resource'\nFor more information check: https://developer.mozilla.org/en-US/docs/Web/HTTP/Status/404",
"url": "https://mcp-server-295985738387.europe-west1.run.app/.well-known/oauth-protected-resource"
},
"openid_configuration": {
"reason": "no_authorization_server"
},
"server_card": {
"error": "Client error '404 Not Found' for url 'https://mcp-server-295985738387.europe-west1.run.app/.well-known/mcp/server-card.json'\nFor more information check: https://developer.mozilla.org/en-US/docs/Web/HTTP/Status/404",
"url": "https://mcp-server-295985738387.europe-west1.run.app/.well-known/mcp/server-card.json"
}
},
"remote_url": "https://mcp-server-295985738387.europe-west1.run.app/mcp",
"server_card_payload": null,
"server_identifier": "ai.bankee/inferventis-mcp"
}