Transform your smart home experience with powerful AI assistance powered by multiple AI providers including OpenAI GPT and Anthropic Claude models. Get intelligent responses, automate complex scenarios, and enhance your home automation with advanced natural language processing.
- 🧠 Multi-Provider AI Integration: Support for OpenAI GPT 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
- Support for OpenAI GPT models
- Anthropic Claude integration
- Custom API endpoints
- Flexible model selection
- Context-aware responses
- Multi-turn conversations
- Custom system instructions
- Natural conversation flow
- File-based conversation history storage
- Automatic history rotation
- Configurable history size limits
- Secure storage in Home Assistant
- Efficient token usage
- Smart rate limiting
- Response caching
- Request interval control
- Per-request model selection
- Adjustable parameters
- Custom system prompts
- Temperature control
- Secure API key storage
- Rate limiting protection
- Error handling
- Usage monitoring
- Intuitive configuration UI
- Detailed sensor attributes
- Rich service interface
- Model selection UI
- Event-driven responses
- Conditional logic support
- Template compatibility
- Model-specific automation
Code | Language | Status |
---|---|---|
🇩🇪 de | Deutsch | Full |
🇬🇧 en | English | Primary |
🇪🇸 es | Español | Full |
🇮🇳 hi | हिन्दी | Full |
🇮🇹 it | Italiano | Full |
🇷🇺 ru | Русский | Full |
🇷🇸 sr | Српски | Full |
🇨🇳 zh | 中文 | Full |
- Home Assistant 2024.11 or later
- Active API key from:
- Python 3.9 or newer
- Stable internet connection
- 🌐 API Provider: OpenAI/Anthropic
- 🔑 API Key: Provider-specific authentication
- 🤖 Model Selection: Flexible, provider-specific models
- 🌡️ Temperature: Creativity control (0.0-2.0)
- 📏 Max Tokens: Response length limit (token usage is estimated using a heuristic method based on word count and specific word characteristics, which may differ from actual token usage)
- ⏱️ Request Interval: API call throttling
- 💾 History Size: Number of messages to retain
- 🌍 Custom API Endpoint: Optional advanced configuration
🌐 Potentially Compatible Providers
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
- Not all providers guarantee full compatibility
- Performance may vary between providers
- Check individual provider's documentation
- Ensure your API key has sufficient credits/quota
To be compatible, a provider should support:
- OpenAI-like REST API structure
- JSON request/response format
- Standard authentication method
- Similar model parameter handling
- Open HACS in Home Assistant
- Click on "Integrations"
- Click "..." in top right corner
- Select "Custom repositories"
- Add repository URL:
https://github.com/smkrv/ha-text-ai
- Choose "Integration" as category
- Click "Download"
- Restart Home Assistant
Note: Also Integration has been submitted to HACS store and is currently pending review in pull request #2896.
- Download the latest release
- Extract and copy
custom_components/ha_text_ai
to yourcustom_components
directory - Restart Home Assistant
- Add configuration via UI or YAML
- Go to Settings → Devices & Services
- Click "Add Integration"
- Search for "HA Text AI"
- Follow the configuration steps
📦 Via YAML (Advanced)
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:
- 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
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 |
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 |
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
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.
service: ha_text_ai.clear_history
data:
instance: sensor.ha_text_ai_gpt
service: ha_text_ai.get_history
data:
limit: 5 # optional
filter_model: "gpt-4o" # optional
instance: sensor.ha_text_ai_gpt
- Only lowercase letters (a-z)
- Numbers (0-9)
- Underscore (_)
- Maximum length: 50 characters (including
ha_text_ai_
)
# 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
# Use your specific sensor name
{{ state_attr('sensor.ha_text_ai_gpt', 'response') }}
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') }}
- Prefix is always
sensor.ha_text_ai_
- Add your unique identifier after the underscore
- Use lowercase
- No spaces allowed
- Keep it descriptive but concise
- 🤖 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
# 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
# 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
# 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
# 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') }} # [...]
# 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
# 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
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
- Always check attribute existence
- Use these attributes for monitoring and automation
- Some values might be 0 or empty initially
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.
Contributions welcome! Please read our Contributing Guide.
- Fork the repository
- Create feature branch (
git checkout -b feature/Enhancement
) - Commit changes (
git commit -m 'Add Enhancement'
) - Push branch (
git push origin feature/Enhancement
) - Open Pull Request
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.
Author: SMKRV CC BY-NC-SA 4.0 - see LICENSE for details.
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! 🚀
Made with ❤️ for the Home Assistant Community,
utilizing Claude 3.5 Sonnet, Gemini Pro 1.5, and Qwen 2.5 Coder 32B Instruct.