Skip to main content
Glama
CiscoDevNet

ThousandEyes MCP

by CiscoDevNet
te_client_read.py6.6 kB
# Copyright 2025 Cisco Systems, Inc. and its affiliates # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. # # SPDX-License-Identifier: Apache-2.0 # src/clients/te_client.py import os, httpx BASE = "https://api.thousandeyes.com/v7" TOKEN = os.getenv("TE_TOKEN") HDRS = {"Authorization": f"Bearer {TOKEN}", "Accept": "application/json"} TIMEOUT = httpx.Timeout(connect=5.0, read=25.0, write=10.0, pool=5.0) #Tests and Related Data async def list_tests(aid=None): if not TOKEN: raise RuntimeError("TE_TOKEN is not set") params = {"aid": aid} if aid else None async with httpx.AsyncClient( base_url=BASE, headers=HDRS, timeout=TIMEOUT, http2=False, trust_env=True ) as c: r = await c.get("/tests", params=params) r.raise_for_status() return r.json().get("tests", []) async def get_test_results(test_id, test_type, window=None, start=None, end=None, aid=None, agent_id=None): if not TOKEN: raise RuntimeError("TE_TOKEN is not set") params = {} if window: params["window"] = window if start: params["startDate"] = start if end: params["endDate"] = end if aid: params["aid"] = aid if agent_id: params["agentId"] = agent_id async with httpx.AsyncClient(base_url=BASE, headers=HDRS, timeout=TIMEOUT, http2=False, trust_env=True) as c: r = await c.get(f"/test-results/{test_id}/{test_type}", params=params) r.raise_for_status() return r.json() async def get_path_vis(test_id, window=None, start=None, end=None, aid=None, agent_id=None, direction=None): if not TOKEN: raise RuntimeError("TE_TOKEN is not set") params = {} if window: params["window"] = window if start: params["startDate"] = start if end: params["endDate"] = end if aid: params["aid"] = aid if agent_id: params["agentId"] = agent_id if direction: params["direction"] = direction headers = {"Authorization": f"Bearer {TOKEN}", "Accept": "application/json"} timeout = httpx.Timeout(connect=5.0, read=25.0, write=10.0, pool=5.0) async with httpx.AsyncClient(base_url=BASE, headers=headers, timeout=timeout, http2=False, trust_env=True) as c: r = await c.get(f"/test-results/{test_id}/path-vis", params=params) r.raise_for_status() return r.json() #Dashboards and Related Data async def list_dashboards(aid=None): if not TOKEN: raise RuntimeError("TE_TOKEN is not set") params = {"aid": aid} if aid else None async with httpx.AsyncClient( base_url=BASE, headers=HDRS, timeout=TIMEOUT, http2=False, trust_env=True ) as c: try: r = await c.get("/dashboards", params=params) # common path r.raise_for_status() data = r.json() except httpx.HTTPStatusError as e: if e.response.status_code == 404: r = await c.get("/dashboard", params=params) # alternative path r.raise_for_status() data = r.json() else: raise return data if isinstance(data, list) else data.get("dashboards", []) async def get_dashboard(dashboard_id, aid=None): if not TOKEN: raise RuntimeError("TE_TOKEN is not set") params = {"aid": aid} if aid else None async with httpx.AsyncClient(base_url=BASE, headers=HDRS, timeout=TIMEOUT, http2=False, trust_env=True) as c: r = await c.get(f"/dashboards/{dashboard_id}", params=params) r.raise_for_status() return r.json() async def get_dashboard_widget(dashboard_id, widget_id, start=None, end=None, aid=None, window=None): if not TOKEN: raise RuntimeError("TE_TOKEN is not set") params = {} if aid: params["aid"] = aid if window: params["window"] = window if start: params["startDate"] = start if end: params["endDate"] = end async with httpx.AsyncClient(base_url=BASE, headers=HDRS, timeout=TIMEOUT, http2=False, trust_env=True) as c: r = await c.get(f"/dashboards/{dashboard_id}/widgets/{widget_id}", params=params) r.raise_for_status() return r.json() # Account Management async def get_account_groups(): if not TOKEN: raise RuntimeError("TE_TOKEN is not set") async with httpx.AsyncClient( base_url=BASE, headers=HDRS, timeout=TIMEOUT, http2=False, trust_env=True ) as c: r = await c.get("/account-groups") r.raise_for_status() return r.json().get("accountGroups", []) async def get_users(): if not TOKEN: raise RuntimeError("TE_TOKEN is not set") async with httpx.AsyncClient( base_url=BASE, headers=HDRS, timeout=TIMEOUT, http2=False, trust_env=True ) as c: r = await c.get("/users") r.raise_for_status() return r.json().get("users", []) #Agents and Related Data async def list_agents_filtered(expand: list[str] | None = None, agentTypes: list[str] | None = None, labels: list[str] | None = None): if not TOKEN: raise RuntimeError("TE_TOKEN is not set") headers = { "Authorization": f"Bearer {TOKEN}", "Accept": "application/hal+json" } params = {} # Default to enterprise + enterprise-cluster unless overridden if agentTypes is None: params["agentTypes"] = ["enterprise", "enterprise-cluster"] else: params["agentTypes"] = agentTypes if expand: params["expand"] = expand if labels: params["labels"] = labels async with httpx.AsyncClient(base_url=BASE, headers=headers, timeout=TIMEOUT) as c: r = await c.get("/agents", params=params) r.raise_for_status() data = r.json().get("agents", []) return [ { "agentState": a.get("agentState"), "agentId": a.get("agentId"), "agentName": a.get("agentName"), "agentType": a.get("agentType"), "location": a.get("location") } for a in data ]

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/CiscoDevNet/thousandeyes-mcp-community'

If you have feedback or need assistance with the MCP directory API, please join our Discord server