An open API service indexing awesome lists of open source software.

https://github.com/smkrv/ha-text-ai

Cutting-edge AI solution for Home Assistant. Multi-LLM provider support to transform your smart home experience with intelligent, adaptive automation.
https://github.com/smkrv/ha-text-ai

ai anthropic anthropic-claude artificial-intelligence deepseek deepseek-api gpt hacs hacs-custom hacs-integration home-assistant home-assistant-integration homeassistant llm natural-language-processing openai-api openrouter openrouter-api sonnet text-analysis

Last synced: 6 months ago
JSON representation

Cutting-edge AI solution for Home Assistant. Multi-LLM provider support to transform your smart home experience with intelligent, adaptive automation.

Awesome Lists containing this project

README

          

# ๐Ÿค– HA Text AI for Home Assistant

![GitHub release](https://img.shields.io/github/v/release/smkrv/ha-text-ai?style=flat-square) ![GitHub last commit](https://img.shields.io/github/last-commit/smkrv/ha-text-ai?style=flat-square) [![License: CC BY-NC-SA 4.0](https://img.shields.io/badge/License-CC%20BY--NC--SA%204.0-lightgrey.svg?style=flat-square)](https://creativecommons.org/licenses/by-nc-sa/4.0/) [![hacs_badge](https://img.shields.io/badge/HACS-Custom-41BDF5.svg?style=flat-square)](https://github.com/hacs/integration)
![Deutsch](https://img.shields.io/badge/lang-DE-blue?style=flat-square) ![English](https://img.shields.io/badge/lang-EN-blue?style=flat-square) ![Espaรฑol](https://img.shields.io/badge/lang-ES-blue?style=flat-square) ![เคนเคฟเคจเฅเคฆเฅ€](https://img.shields.io/badge/lang-HI-blue?style=flat-square) ![Italiano](https://img.shields.io/badge/lang-IT-blue?style=flat-square) ![ะ ัƒััะบะธะน](https://img.shields.io/badge/lang-RU-blue?style=flat-square) ![ะกั€ะฟัะบะธ](https://img.shields.io/badge/lang-SR-blue?style=flat-square) ![ไธญๆ–‡](https://img.shields.io/badge/lang-ZH-blue?style=flat-square)

HA Text AI

### Advanced AI Integration for [Home Assistant](https://www.home-assistant.io/) with LLM multi-provider support


Transform your smart home experience with powerful AI assistance powered by multiple AI providers including OpenAI GPT, DeepSeek and Anthropic Claude models. Get intelligent responses, automate complex scenarios, and enhance your home automation with advanced natural language processing.

---

> [!IMPORTANT]
> ๐Ÿค Community Driven: for more details on the integration,
> check out the discussion on the **[Home Assistant Community forum](https://community.home-assistant.io/t/ha-text-ai-transforming-home-automation-through-multi-llm-integration/799741)**
>
>
>
> [Screenshots](assets/images/screenshots/screenshot.jpg)

## ๐ŸŒŸ Features

- ๐Ÿง  **Multi-Provider AI Integration**: Support for OpenAI GPT, DeepSeek and Anthropic Claude models
- ๐Ÿ’ฌ **Advanced Language Processing**: Context-aware, multi-turn conversations
- ๐Ÿ“ **Enhanced Memory Management**: Secure file-based history storage
- โšก **Performance Optimization**: Efficient token usage and smart rate limiting
- ๐ŸŽฏ **Advanced Customization**: Per-request model and parameter selection
- ๐Ÿ”’ **Enhanced Security**: Secure API key management and usage monitoring
- ๐ŸŽจ **Improved User Experience**: Intuitive configuration and rich interfaces
- ๐Ÿ”„ **Automation Integration**: Event-driven responses and template compatibility

๐Ÿ“ฆ Detailed Feature Breakdown

### ๐Ÿง  **Multi-Provider AI Integration**
- Support for OpenAI GPT models
- Anthropic Claude integration
- DeepSeek integration
- Custom API endpoints
- Flexible model selection

### ๐Ÿ’ฌ **Advanced Language Processing**
- Context-aware responses
- Multi-turn conversations
- Custom system instructions
- Natural conversation flow

### ๐Ÿ“ **Enhanced Memory Management**
- File-based conversation history storage
- Automatic history rotation
- Configurable history size limits
- Secure storage in Home Assistant

### โšก **Performance Optimization**
- Efficient token usage
- Smart rate limiting
- Response caching
- Request interval control

### ๐ŸŽฏ **Advanced Customization**
- Per-request model selection
- Adjustable parameters
- Custom system prompts
- Temperature control

### ๐Ÿ”’ **Enhanced Security**
- Secure API key storage
- Rate limiting protection
- Error handling
- Usage monitoring

### ๐ŸŽจ **Improved User Experience**
- Intuitive configuration UI
- Detailed sensor attributes
- Rich service interface
- Model selection UI

### ๐Ÿ”„ **Automation Integration**
- Event-driven responses
- Conditional logic support
- Template compatibility
- Model-specific automation

#### ๐ŸŒ Translations

| Code | Language | Status |
|------|----------|--------|
| ๐Ÿ‡ฉ๐Ÿ‡ช de | Deutsch | Full |
| ๐Ÿ‡ฌ๐Ÿ‡ง en | English | Primary |
| ๐Ÿ‡ช๐Ÿ‡ธ es | Espaรฑol | Full |
| ๐Ÿ‡ฎ๐Ÿ‡ณ hi | เคนเคฟเคจเฅเคฆเฅ€ | Full |
| ๐Ÿ‡ฎ๐Ÿ‡น it | Italiano | Full |
| ๐Ÿ‡ท๐Ÿ‡บ ru | ะ ัƒััะบะธะน | Full |
| ๐Ÿ‡ท๐Ÿ‡ธ sr | ะกั€ะฟัะบะธ | Full |
| ๐Ÿ‡จ๐Ÿ‡ณ zh | ไธญๆ–‡ | Full |

## ๐Ÿ“‹ Prerequisites

- Home Assistant 2024.11 or later
- Active API key from:
- OpenAI ([Get key](https://platform.openai.com/account/api-keys))
- Anthropic ([Get key](https://console.anthropic.com/))
- DeepSeek ๐Ÿ†• ([Get key](https://platform.deepseek.com/api_keys))
- OpenRouter ([Get key](https://openrouter.ai/keys))
- Any OpenAI-compatible API provider
- Python 3.9 or newer
- Stable internet connection

## Configuration Options

### ๐Ÿ”ง **Core Configuration Settings**
- ๐ŸŒ **API Provider**: OpenAI/Anthropic/DeepSeek
- ๐Ÿ”‘ **API Key**: Provider-specific authentication
- ๐Ÿค– **Model Selection**: Flexible, provider-specific models
- ๐ŸŒก๏ธ **Temperature**: Creativity control (0.0-2.0)
- ๐Ÿ“ **Max Tokens**: Response length limit (passed directly to the LLM API to control the maximum length of the response)
- โฑ๏ธ **Request Interval**: API call throttling
- ๐Ÿ’พ **History Size**: Number of messages to retain
- ๐ŸŒ **Custom API Endpoint**: Optional advanced configuration

๐ŸŒ Potentially Compatible Providers

#### Flexible Provider Ecosystem
The integration is designed to be flexible and may work with other providers offering OpenAI-compatible APIs:
- Groq
- Together AI
- Perplexity AI
- Mistral AI
- Google AI
- Local AI servers (like Ollama)
- Custom OpenAI-compatible endpoints

#### ๐Ÿšจ Compatibility Notes
- Not all providers guarantee full compatibility
- Performance may vary between providers
- Check individual provider's documentation
- Ensure your API key has sufficient credits/quota

#### ๐Ÿ” Provider Compatibility Requirements
To be compatible, a provider should support:
- OpenAI-like REST API structure
- JSON request/response format
- Standard authentication method
- Similar model parameter handling

## โšก Installation

### HACS Installation (Recommended)

1. Open HACS in Home Assistant
2. Click on "Integrations"
3. Click "..." in top right corner
4. Select "Custom repositories"
5. Add repository URL: `https://github.com/smkrv/ha-text-ai`
6. Choose "Integration" as category
7. Click "Download"
8. Restart Home Assistant

Note: Also Integration has been submitted to HACS store and is currently pending review in [pull request #2896](https://github.com/hacs/default/pull/2896).

### Manual Installation
1. Download the latest release
2. Extract and copy `custom_components/ha_text_ai` to your `custom_components` directory
3. Restart Home Assistant
4. Add configuration via UI or YAML

## โš™๏ธ Configuration

### Via UI (Recommended)
1. Go to Settings โ†’ Devices & Services
2. Click "Add Integration"
3. Search for "HA Text AI"
4. Follow the configuration steps

๐Ÿ“ฆ Via YAML (Advanced)

### Platform Configuration (Global Settings)

```yaml
ha_text_ai:
api_provider: openai # Required
api_key: !secret ai_api_key # Required
model: gpt-4o-mini # Strongly recommended
temperature: 0.7 # Optional
max_tokens: 1000 # Optional
request_interval: 1.0 # Optional
api_endpoint: https://api.openai.com/v1 # Required
system_prompt: | # Optional
You are a home automation expert assistant.
Focus on practical and efficient solutions.
```

### Sensor Configuration

```yaml
sensor:
- platform: ha_text_ai
name: "My AI Assistant" # Required, unique identifier
api_provider: openai # Optional (inherits from platform)
model: "gpt-4o-mini" # Optional
temperature: 0.7 # Optional
max_tokens: 1000 # Optional
```

### ๐Ÿ“‹ Configuration Parameters

#### Platform Configuration

| Parameter | Type | Required | Default | Description |
|-----------|------|----------|---------|-------------|
| `api_provider` | String | โœ… | - | AI service provider (openai, anthropic) |
| `api_key` | String | โœ… | - | Authentication key for AI service |
| `model` | String | โš ๏ธ | Provider default | Strongly recommended: Specific AI model to use. If not specified, the provider's default model will be used |
| `temperature` | Float | โŒ | 0.7 | Response creativity level (0.0-2.0) |
| `max_tokens` | Integer | โŒ | 1000 | Maximum response length |
| `request_interval` | Float | โŒ | 1.0 | Delay between API requests |
| `api_endpoint` | URL | โš ๏ธ | Provider default | Custom API endpoint |
| `system_prompt` | String | โŒ | - | Default context for AI interactions |
| `max_history_size` | Integer | โŒ | 100 | Maximum number of conversation entries to store |
| `history_file_size` | Integer | โš ๏ธ | 1 | Maximum history file size in MB |

#### Sensor Configuration

| Parameter | Type | Required | Default | Description |
|-----------|------|----------|---------|-------------|
| `platform` | String | โœ… | - | Must be `ha_text_ai` |
| `name` | String | โœ… | - | Unique sensor identifier |
| `api_provider` | String | โŒ | Platform setting | Override global provider |
| `model` | String | โš ๏ธ | Platform setting | Recommended: Override global model. If not specified, uses platform or provider default |
| `temperature` | Float | โŒ | Platform setting | Override global temperature |
| `max_tokens` | Integer | โŒ | Platform setting | Override global max tokens |

## ๐Ÿ› ๏ธ Available Services

### ask_question
```yaml
service: ha_text_ai.ask_question
data:
question: "What's the optimal temperature for sleeping?"
model: "claude-3-sonnet" # optional
temperature: 0.5 # optional
max_tokens: 500 # optional
context_messages: 10 #optional, number of previous messages to include in context, default: 5
system_prompt: "You are a sleep optimization expert" # optional
instance: sensor.ha_text_ai_gpt
```

### set_system_prompt
```yaml
service: ha_text_ai.set_system_prompt
data:
instance: sensor.ha_text_ai_gpt
prompt: |
You are a home automation expert focused on:
1. Energy efficiency
2. Comfort optimization
3. Security considerations
Provide practical, actionable advice.
```

### clear_history
```yaml
service: ha_text_ai.clear_history
data:
instance: sensor.ha_text_ai_gpt
```

### get_history
```yaml
service: ha_text_ai.get_history
data:
limit: 5 # optional
filter_model: "gpt-4o" # optional
instance: sensor.ha_text_ai_gpt
```

### ๐Ÿท๏ธ HA Text AI Sensor Naming Convention

#### Character Restrictions
- Only lowercase letters (a-z)
- Numbers (0-9)
- Underscore (_)
- Maximum length: 50 characters (including `ha_text_ai_`)

#### Sensor Name Structure
```yaml
# Always starts with 'sensor.ha_text_ai_'
# You define only the part after the underscore
sensor.ha_text_ai_YOUR_UNIQUE_SUFFIX

# Examples:
sensor.ha_text_ai_gpt # GPT-based sensor
sensor.ha_text_ai_claude # Claude-based sensor
sensor.ha_text_ai_abc # Custom suffix
```

#### Response Retrieval
```yaml
# Use your specific sensor name
{{ state_attr('sensor.ha_text_ai_gpt', 'response') }}
```

#### Practical Usage
```yaml
automation:
- alias: "AI Response with Custom Sensor"
action:
- service: ha_text_ai.ask_question
data:
question: "Home automation advice"
instance: sensor.ha_text_ai_gpt
- service: notify.mobile
data:
message: >
AI Tip:
{{ state_attr('sensor.ha_text_ai_gpt', 'response') }}
```

### ๐Ÿ’ก Naming Rules
- Prefix is always `sensor.ha_text_ai_`
- Add your unique identifier after the underscore
- Use lowercase
- No spaces allowed
- Keep it descriptive but concise

### ๐Ÿ” HA Text AI Sensor Attributes

- ๐Ÿค– **Model and Provider Information**: Tracking current AI model and service provider
- ๐Ÿšฆ **System Status**: Real-time API and processing readiness
- ๐Ÿ“Š **Performance Metrics**: Request success rates and response times
- ๐Ÿ’ฌ **Conversation Tracking**: Token usage and interaction history are estimated using a heuristic method based on word count and specific word characteristics, which may differ from actual token usage.
- ๐Ÿ•’ **Last Interaction Details**: Recent query and response tracking
- โค๏ธ **System Health**: Error monitoring and service uptime

๐Ÿ“ฆ Detailed Sensor Attributes

#### Model and Provider Information
```yaml
# Name of the AI model currently in use (e.g., latest version of GPT)
{{ state_attr('sensor.ha_text_ai_gpt', 'Model') }} # gpt-4o

# Service provider for the AI model (determines API endpoint and authentication)
{{ state_attr('sensor.ha_text_ai_gpt', 'Api provider') }} # openai

# Previous or alternative model configuration
{{ state_attr('sensor.ha_text_ai_gpt', 'Last model') }} # gpt-4o
```

#### System Status
```yaml
# Current operational readiness of the AI service API
{{ state_attr('sensor.ha_text_ai_gpt', 'Api status') }} # ready

# Indicates if a request is currently being processed
{{ state_attr('sensor.ha_text_ai_gpt', 'Is processing') }} # false

# Shows if the API has hit its request rate limit
{{ state_attr('sensor.ha_text_ai_gpt', 'Is rate limited') }} # false

# Status of the specific API endpoint being used
{{ state_attr('sensor.ha_text_ai_gpt', 'Endpoint status') }} # ready
```

#### Performance Metrics
```yaml
# Total number of successfully completed API requests
{{ state_attr('sensor.ha_text_ai_gpt', 'Successful requests') }} # 0

# Number of API requests that encountered errors
{{ state_attr('sensor.ha_text_ai_gpt', 'Failed requests') }} # 0

# Mean time taken to receive a response from the AI service
{{ state_attr('sensor.ha_text_ai_gpt', 'Average latency') }} # 0

# Maximum time taken for a single request-response cycle
{{ state_attr('sensor.ha_text_ai_gpt', 'Max latency') }} # 0
```

#### Conversation and Token Usage
```yaml
# Number of previous interactions stored in conversation context
{{ state_attr('sensor.ha_text_ai_gpt', 'History size') }} # 0

# Total number of tokens used across all interactions
{{ state_attr('sensor.ha_text_ai_gpt', 'Total tokens') }} # 0

# Tokens used in the input prompts
{{ state_attr('sensor.ha_text_ai_gpt', 'Prompt tokens') }} # 0

# Tokens used in the AI's generated responses
{{ state_attr('sensor.ha_text_ai_gpt', 'Completion tokens') }} # 0

# Number of entries in current history file
{{ state_attr('sensor.ha_text_ai_gpt', 'History size') }} # 0

# Last few conversation entries (limited to 1 for performance)
{{ state_attr('sensor.ha_text_ai_gpt', 'conversation_history') }} # [...]
```

#### Last Interaction Details
```yaml
# Most recent complete response generated by the AI service
{{ state_attr('sensor.ha_text_ai_gpt', 'Response') }} # Last AI response

# The most recently processed user query or prompt
{{ state_attr('sensor.ha_text_ai_gpt', 'Question') }} # Last asked question

# Precise moment when the last interaction occurred (useful for tracking and logging)
{{ state_attr('sensor.ha_text_ai_gpt', 'Last timestamp') }} # Timestamp
```

#### System Health
```yaml
# Cumulative count of all errors encountered during AI service interactions
{{ state_attr('sensor.ha_text_ai_gpt', 'Total errors') }} # 0

# Indicates if the AI service is currently undergoing scheduled or emergency maintenance
{{ state_attr('sensor.ha_text_ai_gpt', 'Is maintenance') }} # false

# Total continuous operational time of the AI service (in hours or days)
{{ state_attr('sensor.ha_text_ai_gpt', 'Uptime') }} # 547,58
```

### History Storage
Conversation history stored in `.storage/ha_text_ai_history/` directory:
- Each instance has its own history file (JSON)
- Files are automatically rotated when size limit is reached
- Archived history files are timestamped
- Default maximum file size: 1MB

### ๐Ÿ’ก Pro Tips
- Always check attribute existence
- Use these attributes for monitoring and automation
- Some values might be 0 or empty initially

## ๐Ÿ“˜ FAQ

**Q: Which AI providers are supported?**
A: Currently OpenAI (GPT models) and Anthropic (Claude models) are supported, with more providers planned.

**Q: How can I reduce API costs?**
A: Use GPT-3.5-Turbo or Claude-3-Sonnet for most queries, implement caching, and optimize token usage.

**Q: Are there limitations on the number of requests?**
A: Depends on your API provider's plan. We recommend monitoring usage and implementing request throttling via `request_interval` configuration.

**Q: Can I use custom models?**
A: Yes, you can configure custom endpoints and use any compatible model by specifying it in the configuration.

**Q: How do I switch between different AI providers?**
A: Simply change the model parameter in your configuration or service calls to use the desired provider's model.

**Q: How can I reduce API costs?**
A: Use GPT-3.5-Turbo for most queries, implement caching, and optimize token usage.

**Q: Is my data secure?**
A: Yes, your data is secure. The system operates entirely on your local machine, keeping your data under your control. API keys are stored securely and all external communications use encrypted connections.

**Q: How do context messages work?**
A: Context messages allow the AI to remember and reference previous conversation history. By default, 5 previous messages are included, but you can customize this from 1 to 20 messages to control the conversation depth and token usage.

**Q: Where is conversation history stored?**
A: History is stored in files under the `.storage/ha_text_ai_history/` directory, with automatic rotation and size management.

**Q: Can I access old conversation history?**
A: Yes, archived history files are stored with timestamps and can be accessed manually if needed.

**Q: How much history is kept?**
A: By default, up to 100 conversations are stored, but this can be configured. Files are automatically rotated when they reach 1MB.

## ๐Ÿค Contributing

Contributions welcome! Please read our [Contributing Guide](CONTRIBUTING.md).

1. Fork the repository
2. Create feature branch (`git checkout -b feature/Enhancement`)
3. Commit changes (`git commit -m 'Add Enhancement'`)
4. Push branch (`git push origin feature/Enhancement`)
5. Open Pull Request

## Legal Disclaimer and Limitation of Liability

### Software Disclaimer

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
PARTICULAR PURPOSE AND NONINFRINGEMENT.

IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
DEALINGS IN THE SOFTWARE.

## ๐Ÿ“ License

Author: SMKRV
[CC BY-NC-SA 4.0](https://creativecommons.org/licenses/by-nc-sa/4.0/) - see [LICENSE](LICENSE) for details.

## ๐Ÿ’ก Support the Project

The best support is:
- Sharing feedback
- Contributing ideas
- Recommending to friends
- Reporting issues
- Star the repository

If you want to say thanks financially, you can send a small token of appreciation in USDT:

**USDT Wallet (TRC10/TRC20):**
`TXC9zYHYPfWUGi4Sv4R1ctTBGScXXQk5HZ`

*Open-source is built by community passion!* ๐Ÿš€

---

HA Text AI

Made with โค๏ธ for the Home Assistant Community,
utilizing Claude 3.5 Sonnet, Gemini Pro 1.5, and Qwen 2.5 Coder 32B Instruct.

[Report Bug](https://github.com/smkrv/ha-text-ai/issues) ยท [Request Feature](https://github.com/smkrv/ha-text-ai/issues)