mirror of
https://github.com/home-assistant/core.git
synced 2025-06-05 13:47:06 +00:00

* Use intent responses from home_assistant_intents * Use error responses from home_assistant_intents * Remove speech checks for intent tests (set by conversation now) * Bump hassil and home-assistant-intents versions * Use Home Assistant JSON reader when loading intents * Remove speech checks for light tests (done in agent) * Add more tests for code coverage * Add test for reloading on new component * Add test for non-default response
58 lines
1.4 KiB
Python
58 lines
1.4 KiB
Python
"""Agent foundation for conversation integration."""
|
|
from __future__ import annotations
|
|
|
|
from abc import ABC, abstractmethod
|
|
from dataclasses import dataclass
|
|
from typing import Any
|
|
|
|
from homeassistant.core import Context
|
|
from homeassistant.helpers import intent
|
|
|
|
|
|
@dataclass
|
|
class ConversationResult:
|
|
"""Result of async_process."""
|
|
|
|
response: intent.IntentResponse
|
|
conversation_id: str | None = None
|
|
|
|
def as_dict(self) -> dict[str, Any]:
|
|
"""Return result as a dict."""
|
|
return {
|
|
"response": self.response.as_dict(),
|
|
"conversation_id": self.conversation_id,
|
|
}
|
|
|
|
|
|
class AbstractConversationAgent(ABC):
|
|
"""Abstract conversation agent."""
|
|
|
|
@property
|
|
def attribution(self):
|
|
"""Return the attribution."""
|
|
return None
|
|
|
|
async def async_get_onboarding(self):
|
|
"""Get onboard data."""
|
|
return None
|
|
|
|
async def async_set_onboarding(self, shown):
|
|
"""Set onboard data."""
|
|
return True
|
|
|
|
@abstractmethod
|
|
async def async_process(
|
|
self,
|
|
text: str,
|
|
context: Context,
|
|
conversation_id: str | None = None,
|
|
language: str | None = None,
|
|
) -> ConversationResult:
|
|
"""Process a sentence."""
|
|
|
|
async def async_reload(self, language: str | None = None):
|
|
"""Clear cached intents for a language."""
|
|
|
|
async def async_prepare(self, language: str | None = None):
|
|
"""Load intents for a language."""
|