
mcpclient
Client to demonstrate the test of an MCP server with OpenAI LLM
Repository Info
About This Server
Client to demonstrate the test of an MCP server with OpenAI LLM
Model Context Protocol (MCP) - This server can be integrated with AI applications to provide additional context and capabilities, enabling enhanced AI interactions and functionality.
Documentation
MCP CLIENT
- USE MCP A lightweight React hook for connecting to Model Context Protocol (MCP) servers. Simplifies authentication and tool calling for AI systems implementing the MCP standard.
https://github.com/modelcontextprotocol/use-mcp
https://blog.cloudflare.com/connect-any-react-application-to-an-mcp-server-in-three-lines-of-code/
- OPENAI AGENTS https://openai.github.io/openai-agents-js/guides/voice-agents/
https://x.com/OpenAIDevs/status/1929950678799266253
- AGENT PRODUCTION https://github.com/NirDiamant/agents-towards-production
SUPABASE CONNECTION
https://supabase.com/ui
https://supabase.com/ui/docs/getting-started/introduction
CloudFlare verified bots program https://blog.cloudflare.com/verified-bots-with-cryptography/
Vapi Expressive Voice with Hume
https://dashboard.vapi.ai/
PUBLIC APIs https://github.com/public-apis/public-apis
ai sdk and gtoc Grok 4 live on @aisdk
𝚒𝚖𝚙𝚘𝚛𝚝 { 𝚐𝚎𝚗𝚎𝚛𝚊𝚝𝚎𝚃𝚎𝚡𝚝 } 𝚏𝚛𝚘𝚖 '𝚊𝚒' 𝚌𝚘𝚗𝚜𝚝 { 𝚝𝚎𝚡𝚝 } = 𝚊𝚠𝚊𝚒𝚝 𝚐𝚎𝚗𝚎𝚛𝚊𝚝𝚎𝚃𝚎𝚡𝚝({ 𝚖𝚘𝚍𝚎𝚕: '𝚡𝚊𝚒/𝚐𝚛𝚘𝚔-𝟺', 𝚙𝚛𝚘𝚖𝚙𝚝: 'T𝚑𝚎 𝚊𝚗𝚜𝚠𝚎𝚛 𝚝𝚘 𝚕𝚒𝚏𝚎' })
This is an example implementation of the Model Context Protocol SDK's client code with the Vercel AI SDK which simplifies handling an LLM chat in the browser. Check out how to make your own mcp servers quick here
How It Works
- Connect to an MCP server with SSE through the UI ( you can learn more about creating mcp servers with SSE)
- The system automatically discovers available tools
- Ask it to use the tool
Getting Started
# Install dependencies
npm install
# Run the development server
npm run dev
Then go to http://localhost:3000
INSPECT
npx @modelcontextprotocol/inspector
RESEARCH
https://component-playground-eight.vercel.app/
project management https://github.com/ln-dev7/circle
SBA Supplier Portal https://www.industrynet.com/madeinamerica/ https://www.thomasnet.com/suppliers/madeinamerica https://i5services-20596380.hs-sites.com/made-in-america
Documentation on modules
- SessionManager (useSessionManager) Purpose: Manages the WebRTC connection lifecycle (connect, disconnect, audio playback) and provides the dataChannel.
Why Separate: WebRTC connections involve complex setup (e.g., fetching ephemeral keys, creating RTCPeerConnection, handling audio streams), which is isolated to avoid cluttering MetaAgent. This abstraction makes it reusable for other components needing WebRTC.
Collapse Potential: Could be partially inlined into MetaAgent if WebRTC is only used here, but this would make MetaAgent harder to maintain and test. Keeping it separate improves modularity.
- HandleServerEvent (useHandleServerEvent) Purpose: Processes a wide range of ServerEvent types from the OpenAI Realtime API, updating transcriptItems, sessionStatus, or selectedAgentName.
Why Separate: The complexity of handling multiple event types (e.g., messages, transcriptions, function calls) justifies a dedicated hook. It encapsulates business logic and reduces MetaAgent’s responsibility to just wiring events to handlers.
Collapse Potential: Inlining into MetaAgent would bloat the component with a large switch statement, reducing readability and testability. A partial collapse (e.g., moving transcript-specific logic to useTranscript) is possible but would require restructuring useTranscript to handle raw ServerEvents.
- useTranscript (TranscriptContext) Purpose: Manages the transcriptItems state and provides update functions for messages and breadcrumbs.
Why Separate: Using React Context allows transcriptItems to be shared across components (e.g., if another component needs access). It also centralizes state management, keeping MetaAgent focused on UI and orchestration.
Collapse Potential: If transcriptItems is only used in MetaAgent, the state and update functions could be moved to MetaAgent or a custom hook, eliminating the context. However, this assumes no other components need transcriptItems, which may not hold as the app grows.
- MessageHandler (useMessageHandler) Purpose: Handles outgoing client events (e.g., sending user text, canceling assistant speech) and simulated messages.
Why Separate: Isolates the logic for sending WebRTC messages, ensuring MetaAgent doesn’t directly interact with dataChannel for sending events. This abstraction supports reusability and simplifies testing.
Collapse Potential: Could be inlined into MetaAgent, but this would mix UI logic with event-sending logic, reducing clarity. The hook’s small size makes it a lightweight abstraction.
- AgentSession (useAgentSession) Purpose: Configures the OpenAI Realtime API session with agent-specific settings (e.g., instructions, tools, voice).
Why Separate: Session configuration is a distinct concern from UI rendering or event handling, and the logic (e.g., constructing session.update events) is complex enough to warrant isolation.
Collapse Potential: Inlining into MetaAgent would add more useEffect logic, making the component harder to read. A partial merge with MessageHandler (since both deal with sendClientEvent) is possible but would reduce clarity unless carefully structured.
- MappedMessages (useMappedMessages) Purpose: Transforms transcriptItems and loggedEvents into Conversation and logs formats for potential use by AI agents.
Why Separate: The transformation logic is specific to agent requirements and may be reused elsewhere. It avoids cluttering MetaAgent with data mapping.
Collapse Potential: If logs and conversation are only used in MetaAgent and not by other components, the mapping could be done inline. However, keeping it separate supports future scalability (e.g., if other components need the mapped data).
Quick Start
Clone the repository
git clone https://github.com/pdhoward/mcpclientInstall dependencies
cd mcpclient
npm installFollow the documentation
Check the repository's README.md file for specific installation and usage instructions.
Repository Details
Recommended MCP Servers
Discord MCP
Enable AI assistants to seamlessly interact with Discord servers, channels, and messages.
Knit MCP
Connect AI agents to 200+ SaaS applications and automate workflows.
Apify MCP Server
Deploy and interact with Apify actors for web scraping and data extraction.
BrowserStack MCP
BrowserStack MCP Server for automated testing across multiple browsers.
Zapier MCP
A Zapier server that provides automation capabilities for various apps.