Skip to content

A Home Assistant custom component that provides an AI-powered agent capable of generating automations based on natural language queries. The agent connects to all entities in your Home Assistant instance and uses OpenAI's or Llama API to translate user requests into valid Home operations including creating automations for you!

License

Notifications You must be signed in to change notification settings

sbenodiz/ai_agent_ha

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 

AI Agent HA

A powerful Home Assistant custom integration that connects your Home Assistant instance with multiple AI providers (OpenAI, Google Gemini, Anthropic (Claude), OpenRouter, and Llama) to translate user requests into valid Home Assistant operations, including creating automations automatically!

๐Ÿš€ Quick Install

Open your Home Assistant instance and open a repository inside the Home Assistant Community Store.

Click the button above to install AI Agent HA directly through HACS, or see the detailed installation instructions below.

โ˜• Support the Project

If you find this integration helpful and would like to support its development, you can buy me a coffee! Your support helps keep this project active and maintained. Currently I am the only Dev on that project and looking to have more paretners here.

Buy Me A Coffee

Every contribution, no matter how small, is greatly appreciated and helps fund the continued development and improvement of AI Agent HA.

Another way to support me will be to try my new project. Askie - AI for kids. I am looking for feedback on this one: โ Web: https://kidsai.app โ€ข โ iOS: https://apps.apple.com/app/id6749299565 โ Android: https://play.google.com/store/apps/details?id=com.askie.app

โœจ Features

  • ๐Ÿค– Multiple AI Provider Support: OpenAI, Google Gemini, Anthropic (Claude), OpenRouter, and Llama
  • ๐ŸŽฏ Model Selection: Choose from predefined models or use custom model names
  • ๐Ÿ  Smart Home Control: Turn lights on/off, control climate, and manage devices
  • โšก Automation Creation: Automatically create automations based on natural language
  • ๐Ÿ“‹ Dashboard Creation: Create and customize Home Assistant dashboards through natural language
  • ๐Ÿ“Š Data Access: Get entity states, history, weather, and more
  • ๐Ÿ”’ Secure: API keys stored securely in Home Assistant
  • ๐ŸŽจ Beautiful UI: Clean, modern chat interface
  • ๐Ÿ”„ Real-time: Instant responses and updates

๐Ÿ“ธ Screenshots

Automation Creation

AI Agent HA Automation Creation

๐Ÿ“‹ Dashboard Creation

AI Agent HA now supports creating and managing Home Assistant dashboards through natural language conversations! Simply describe what you want, and the AI will create a complete dashboard for you.

How Dashboard Creation Works

  1. Natural Language Request: Ask the AI to create a dashboard for any purpose
  2. Entity Discovery: The AI automatically finds relevant entities in your Home Assistant
  3. Smart Organization: Entities are organized by room, functionality, or domain
  4. Dashboard Generation: Complete dashboard with proper cards and layout is created
  5. Integration: Dashboard is automatically added to your Home Assistant sidebar
  6. Restart Required: You'll need to restart Home Assistant to see the new dashboard in your sidebar

Dashboard Creation Examples

Simple Room Dashboard

"Create a dashboard for my living room lights"

The AI will find all living room light entities and create a dashboard with appropriate light control cards.

Security Dashboard

"Create a security dashboard with all door sensors, cameras, and alarm controls"

The AI will create a comprehensive security monitoring dashboard with sensor states, camera feeds, and alarm controls. After creation, restart Home Assistant to see the new dashboard in your sidebar.

Energy Monitoring Dashboard

"I want an energy dashboard showing power consumption and usage graphs"

The AI will create an energy monitoring dashboard with real-time power gauges, usage graphs, and cost tracking.

Climate Control Dashboard

"Create a climate dashboard for temperature control throughout the house"

The AI will organize thermostats, temperature sensors, and HVAC controls in a logical layout.

Supported Dashboard Features

  • Smart Card Selection: Appropriate card types for each entity (lights, sensors, media players, etc.)
  • Room-Based Organization: Entities automatically grouped by area when possible
  • Interactive Clarification: AI asks follow-up questions to refine your requirements
  • Template-Based Creation: Built-in templates for common dashboard types (security, energy, climate, etc.)
  • Dynamic Layout: Optimized card arrangements and view organization
  • Icon Integration: Automatic Material Design icon selection

Dashboard Types the AI Can Create

  • Room-Specific: Living room, bedroom, kitchen, etc.
  • Functional: Security, energy, climate, media, lighting
  • Device-Specific: All lights, all sensors, all switches
  • Scenario-Based: Morning routine, evening security, vacation mode
  • Custom: Any combination based on your specific needs

For detailed dashboard creation documentation, see: Dashboard Creation Guide

๐Ÿš€ Supported AI Providers

OpenAI

  • Models: GPT-3.5 Turbo, GPT-4, GPT-4 Turbo, GPT-4o, GPT-5, O1-Preview, O1-Mini
  • Setup: Get API key from OpenAI Platform

Google Gemini

  • Models: Gemini 1.5 Flash, Gemini 1.5 Pro, Gemini 1.0 Pro, Gemini 2.0 Flash Exp
  • Setup: Get API key from Google AI Studio

Anthropic (Claude)

  • Models: Claude 3.5 Sonnet, Claude 3.5 Haiku, Claude 3 Opus, Claude 3 Sonnet, Claude 3 Haiku
  • Setup: Get API key from Anthropic Console
  • Popular Models:
    • claude-3-5-sonnet-20241022 (Latest and most capable)
    • claude-3-5-haiku-20241022 (Fast and efficient)
    • claude-3-opus-20240229 (Most powerful for complex tasks)

OpenRouter

  • Models: Access to 100+ models including Claude, Llama, Mistral, and more
  • Setup: Get API key from OpenRouter
  • Popular Models:
    • anthropic/claude-3.5-sonnet
    • meta-llama/llama-3.1-70b-instruct
    • mistralai/mixtral-8x7b-instruct

Llama

  • Models: Llama 4 Maverick, Llama 3.1, Llama 3.2
  • Setup: Get API key from your Llama provider

๐Ÿ“ฆ Installation

HACS Installation (Recommended)

Use the Quick Install button at the top of this README for the easiest installation, or manually add the repository:

  1. Open HACS in your Home Assistant instance
  2. Click on "Integrations"
  3. Click the three dots in the top right corner
  4. Select "Custom repositories"
  5. Add this repository: https://github.com/sbenodiz/ai_agent_ha
  6. Select "Integration" as the category
  7. Click "Add"
  8. Find "AI Agent HA" in the integration list
  9. Click "Download"
  10. Restart Home Assistant
  11. Go to Settings โ†’ Devices & Services โ†’ Add Integration
  12. Search for "AI Agent HA"
  13. Follow the setup wizard to configure your preferred AI provider

Manual Installation

  1. Download the latest release from the releases page
  2. Extract the files
  3. Copy the custom_components/ai_agent_ha folder to your Home Assistant custom_components directory
  4. Restart Home Assistant
  5. Go to Settings โ†’ Devices & Services โ†’ Add Integration
  6. Search for "AI Agent HA"
  7. Follow the setup wizard to configure your preferred AI provider

โš™๏ธ Configuration

The integration uses a two-step configuration process:

Step 1: Choose AI Provider

Select your preferred AI provider from the dropdown:

  • OpenAI
  • Google Gemini
  • Anthropic (Claude)
  • OpenRouter
  • Llama

Step 2: Configure Provider

Enter your API credentials and optionally select a model:

  • API Key/Token: Your provider-specific API key
  • Model: Choose from predefined models or enter a custom model name

Configuration Examples

# Example configuration.yaml (optional - integration supports config flow only)
ai_agent_ha:
  ai_provider: anthropic
  anthropic_token: "sk-ant-..."
  models:
    anthropic: "claude-3-5-sonnet-20241022"

๐ŸŽฎ Usage

Chat Interface

Access the beautiful chat interface at:

  • Sidebar: AI Agent HA panel
  • URL: http://your-ha-instance:8123/ai_agent_ha

๐Ÿ”ง Advanced Features

Custom Models

Enter any model name in the "Custom Model" field:

  • OpenAI: gpt-4-0125-preview
  • Anthropic: claude-3-opus-20240229
  • OpenRouter: anthropic/claude-3-opus
  • Gemini: gemini-pro-vision

Automation Creation

The AI can create automations automatically:

  1. Ask: "Create an automation to turn on lights at sunset"
  2. Review the generated automation
  3. Approve or reject the suggestion
  4. Automation is added to your Home Assistant

Dashboard Creation

The AI can create custom dashboards through conversation:

  1. Ask: "Create a security dashboard with cameras and sensors"
  2. AI discovers relevant entities and asks clarifying questions
  3. Dashboard is generated with appropriate cards and layout
  4. Dashboard is automatically added to your Home Assistant sidebar
  5. Restart Home Assistant to see the new dashboard

Data Access

The AI can access comprehensive Home Assistant data:

  • Entity states and history
  • Weather information
  • Person locations
  • Device registry
  • Area/room information
  • Statistics and analytics

๐Ÿ› ๏ธ Development

Contributing

We welcome contributions from the community! Whether you're fixing bugs, adding features, or improving documentation, your help is appreciated.

Please check out our contribution guidelines for detailed information on how to contribute to this project.

Quick Start

  1. Fork the repository
  2. Create a feature branch
  3. Make your changes
  4. Test thoroughly
  5. Submit a pull request

For security issues, please review our security policy.

Local Frontend Testing

You can test the frontend UI locally without deploying to Home Assistant:

  1. Start the local test server:

    cd tests/frontend
    python3 serve.py
  2. Open your browser: Navigate to http://localhost:8000/test_panel.html

  3. Test the interface: The test page provides a mock Home Assistant environment where you can test UI changes, styling, and component behavior without needing a full Home Assistant installation.

Test files location:

  • tests/frontend/test_panel.html - Standalone test page
  • tests/frontend/serve.py - Simple HTTP server for testing

This is particularly useful for:

  • Testing CSS changes and styling
  • Verifying UI layout and responsiveness
  • Debugging frontend JavaScript issues
  • Quick iteration on visual changes

CI/CD Workflows

This project uses GitHub Actions to ensure code quality and reliability:

  • Quality Checks: Runs all checks in a single workflow (Python 3.12)
  • Python Linting: Checks code style with flake8, black, and isort
  • Python Type Checking: Verifies typing with mypy (Python 3.12 compatibility)
  • Python Tests: Runs tests with pytest (Python 3.12)
  • Security Scan: Checks for security vulnerabilities with Bandit
  • Home Assistant Validation: Validates the integration with hassfest
  • HACS Validation: Ensures compatibility with HACS

All workflows run automatically on push and pull requests using Python 3.12 to ensure compatibility with the latest Home Assistant versions. You can also run them manually via the "Actions" tab in the GitHub repository.

API Structure

The integration provides these main components:

  • AI Clients: Modular providers (OpenAI, Gemini, Claude, OpenRouter, Llama)
  • Agent: Core logic for processing requests
  • Config Flow: Setup and options management
  • Frontend: Chat interface
  • Dashboard Templates: Templates for dashboard creation

๐Ÿ“‹ Requirements

  • Home Assistant 2023.3+
  • Python 3.12+ (required for compatibility with Home Assistant 2025.1.x+)
  • One of the supported AI provider API keys

Python Version Note

Important: Starting with version 0.99.3, this integration requires Python 3.12 or later. This change was made to ensure compatibility with Home Assistant 2025.1.x and later versions, which use syntax features only available in Python 3.12+.

If you're running an older Home Assistant version with Python 3.11, please use version 0.99.2 or earlier of this integration.

๐Ÿ”’ Security

  • API keys are stored securely in Home Assistant's encrypted storage
  • All communication uses HTTPS
  • No data is stored outside your Home Assistant instance
  • Provider-specific security practices are followed

๐Ÿ“ License

This project is licensed under the MIT License - see the LICENSE file for details.

๐Ÿ†˜ Support

๐Ÿ™ Acknowledgments

  • Home Assistant community for the excellent platform
  • All AI providers for their powerful APIs
  • Special thanks to @RmG152 for their valuable help with development
  • Contributors and testers who help improve this integration

Made with โค๏ธ for the Home Assistant community

About

A Home Assistant custom component that provides an AI-powered agent capable of generating automations based on natural language queries. The agent connects to all entities in your Home Assistant instance and uses OpenAI's or Llama API to translate user requests into valid Home operations including creating automations for you!

Topics

Resources

License

Code of conduct

Contributing

Security policy

Stars

Watchers

Forks

Packages

No packages published