# LLM Integration for Topic Interaction ## Overview MQTT Explorer now includes an AI-powered assistant to help users understand and interact with MQTT topics and their data. This feature uses Large Language Models (LLMs) to provide intelligent insights, explanations, and suggestions about your MQTT data. ## Features ### AI Assistant Panel The AI Assistant appears in the Details tab when you select any topic in the tree. It provides: - **Quick Suggestions**: Pre-generated questions based on the selected topic - **Interactive Chat**: Ask custom questions about the topic, its data, or MQTT concepts - **Context-Aware**: Automatically includes topic metadata and message details in queries - **Conversation History**: Maintains context across multiple questions - **Collapsible Interface**: Minimizes when not needed to save screen space ### Capabilities The AI Assistant can help you: 1. **Understand Data Structures**: Get explanations of JSON payloads and complex data formats 2. **Interpret Values**: Learn what specific values mean in the context of IoT devices 3. **Analyze Patterns**: Understand message patterns and frequencies 4. **Discover Possibilities**: Learn what actions you can perform with specific topics 5. **Learn MQTT Concepts**: Get answers about QoS, retained messages, and MQTT protocol features ## Configuration ### Setting Up Your API Key The AI Assistant uses a **backend proxy architecture** for security. API keys are configured server-side only and are never exposed to the frontend. #### For Server/Docker Deployments Configure the AI Assistant using environment variables: ```bash # Provider selection (optional, defaults to 'openai') export LLM_PROVIDER=openai # or 'gemini' # API Keys - provider-specific or generic export OPENAI_API_KEY=sk-... # For OpenAI export GEMINI_API_KEY=AIza... # For Gemini export LLM_API_KEY=... # Generic fallback for either provider # Token limit for neighboring topics context (optional, defaults to 500) # Increased from 100 to 500 for better device relationship and hierarchy detection export LLM_NEIGHBORING_TOPICS_TOKEN_LIMIT=500 # Start the server node dist/src/server.js ``` **Architecture**: - Backend reads API keys from environment variables - Backend proxies all LLM API requests via WebSocket RPC (`llm/chat` event) - Frontend only receives an availability flag (no credentials) - API keys never leave the server - Communication happens over the existing WebSocket connection **Environment Variable Priority:** 1. Provider-specific keys (`OPENAI_API_KEY`, `GEMINI_API_KEY`) are checked first 2. Generic `LLM_API_KEY` is used as fallback **Note**: If no LLM environment variables are set, the AI Assistant feature will be completely hidden from all users. ### Getting API Keys #### OpenAI API Key 1. Visit [https://platform.openai.com/api-keys](https://platform.openai.com/api-keys) 2. Sign up or log in to your OpenAI account 3. Create a new API key 4. Set `OPENAI_API_KEY` environment variable on your server **Note**: Using the AI Assistant will consume OpenAI API credits based on your usage. Please review OpenAI's pricing at [https://openai.com/pricing](https://openai.com/pricing). #### Google Gemini API Key 1. Visit [https://aistudio.google.com/app/apikey](https://aistudio.google.com/app/apikey) 2. Sign in with your Google account 3. Create a new API key 4. Copy the key and paste it into MQTT Explorer's configuration dialog or set `GEMINI_API_KEY` environment variable **Note**: Google Gemini offers a generous free tier. Review Google's pricing at [https://ai.google.dev/pricing](https://ai.google.dev/pricing). ## Usage ### Basic Interaction 1. **Connect** to your MQTT broker 2. **Select** a topic from the tree 3. **Expand** the "AI Assistant" panel in the Details tab 4. **Click** on a quick suggestion or type your own question 5. **Send** your question and wait for the AI response ### Example Questions - "What does this temperature value represent?" - "How should I interpret this JSON structure?" - "Why is this message retained?" - "What QoS level should I use for this topic?" - "How can I monitor changes to this value?" - "What devices typically publish to topics like this?" ### Quick Suggestions The AI Assistant provides contextual suggestions based on the selected topic: - **"Explain this data structure"**: Get a breakdown of complex payloads - **"What does this value mean?"**: Understand specific measurements or states - **"Summarize all subtopics"**: Get an overview of nested topic hierarchies - **"What can I do with this topic?"**: Discover possible actions and integrations ### Context Intelligence The AI Assistant automatically includes relevant context with your questions: - **Current Topic**: The selected topic path and its current value (with preview for large payloads) - **Neighboring Topics**: Related topics with hierarchical context (parent, siblings, children, grandchildren, cousins), limited to 500 tokens by default (increased from 100 for better device relationship detection) - **Topic Metadata**: Message count, subtopic count, and retained status - **Smart Truncation**: Large values and topic lists are intelligently truncated to stay within token limits The neighboring topics context can be adjusted using the `LLM_NEIGHBORING_TOPICS_TOKEN_LIMIT` environment variable. We recommend 500-1000 tokens for production deployments to enable better multi-device and room-level automation proposals. ## Privacy & Security ### Data Handling - **API Keys**: Stored locally in browser localStorage, never transmitted to MQTT Explorer servers - **Topic Data**: Topic paths and message payloads are sent to OpenAI's API to provide context - **Conversation History**: Maintained client-side and reset when you clear the chat ### Best Practices 1. **Sensitive Data**: Be cautious when using the AI Assistant with topics containing sensitive information 2. **API Key Security**: Never share your OpenAI API key with others 3. **Rate Limiting**: The service implements error handling for rate limits 4. **Offline Operation**: The AI Assistant requires internet connectivity to function ## Technical Details ### Architecture - **Frontend**: React component with Material-UI styling - **Service Layer**: Singleton LLM service for API communication - **API Integration**: OpenAI Chat Completions API (GPT-4o Mini by default) - **Context Generation**: Automatic extraction of topic metadata for relevant queries ### Implementation The AI Assistant uses: - **OpenAI SDK**: Official `openai` package (v6.16.0) for reliable OpenAI API communication - Automatic retry logic with exponential backoff - Built-in timeout handling (30 seconds) - TypeScript type safety - Better error messages - **Axios**: Direct HTTP calls for Gemini API (Google doesn't provide official Node.js SDK) - **Model**: `gpt-5-mini` (latest OpenAI mini model, 400K context window) - **Architecture**: Server-side proxy - API keys never sent to browser ### Configuration Options The LLM service supports: - **Custom API Endpoints**: Can be configured to use compatible APIs - **Model Selection**: Defaults to `gpt-5-mini` (latest OpenAI mini model) - **Conversation History**: Automatically manages context (keeps last 10 messages) - **Timeout Handling**: 30-second timeout for API requests with automatic retries - **Debug Mode**: View complete API request and response data via debug button ## Troubleshooting ### "Please configure your OpenAI API key first" **Solution**: Click the settings icon and add your API key. ### "Invalid API key" **Solutions**: - Verify the API key is correct - Check that your OpenAI account is active - Ensure you have available API credits ### "Rate limit exceeded" **Solutions**: - Wait a few minutes before trying again - Check your OpenAI API usage dashboard - Consider upgrading your OpenAI plan if needed ### "Request timeout" **Solutions**: - Check your internet connection - Try asking a simpler question - Verify OpenAI's service status ## Limitations - Requires active internet connection - Needs valid OpenAI API key with available credits - Responses are limited to 500 tokens for performance - May not have knowledge of proprietary or custom MQTT implementations - Beta feature - under active development ## Future Enhancements Potential improvements being considered: - Support for additional LLM providers (Anthropic, Azure OpenAI, etc.) - Ability to save and share helpful conversations - Integration with automation and scripting features - Custom prompts and templates for specific use cases - Offline mode with cached responses for common questions ## Feedback This is a beta feature. If you encounter issues or have suggestions, please open an issue on the [GitHub repository](https://github.com/thomasnordquist/MQTT-Explorer/issues).