mirror of
https://github.com/blakeblackshear/frigate.git
synced 2025-01-07 00:06:57 +01:00
b299652e86
* Update default genai prompt * Update docs * improve wording * clarify wording
67 lines
2.5 KiB
Python
67 lines
2.5 KiB
Python
from enum import Enum
|
|
from typing import Optional, Union
|
|
|
|
from pydantic import BaseModel, Field, field_validator
|
|
|
|
from ..base import FrigateBaseModel
|
|
from ..env import EnvString
|
|
|
|
__all__ = ["GenAIConfig", "GenAICameraConfig", "GenAIProviderEnum"]
|
|
|
|
|
|
class GenAIProviderEnum(str, Enum):
|
|
openai = "openai"
|
|
azure_openai = "azure_openai"
|
|
gemini = "gemini"
|
|
ollama = "ollama"
|
|
|
|
|
|
# uses BaseModel because some global attributes are not available at the camera level
|
|
class GenAICameraConfig(BaseModel):
|
|
enabled: bool = Field(default=False, title="Enable GenAI for camera.")
|
|
use_snapshot: bool = Field(
|
|
default=False, title="Use snapshots for generating descriptions."
|
|
)
|
|
prompt: str = Field(
|
|
default="Analyze the sequence of images containing the {label}. Focus on the likely intent or behavior of the {label} based on its actions and movement, rather than describing its appearance or the surroundings. Consider what the {label} is doing, why, and what it might do next.",
|
|
title="Default caption prompt.",
|
|
)
|
|
object_prompts: dict[str, str] = Field(
|
|
default_factory=dict, title="Object specific prompts."
|
|
)
|
|
|
|
objects: Union[str, list[str]] = Field(
|
|
default_factory=list,
|
|
title="List of objects to run generative AI for.",
|
|
)
|
|
required_zones: Union[str, list[str]] = Field(
|
|
default_factory=list,
|
|
title="List of required zones to be entered in order to run generative AI.",
|
|
)
|
|
|
|
@field_validator("required_zones", mode="before")
|
|
@classmethod
|
|
def validate_required_zones(cls, v):
|
|
if isinstance(v, str) and "," not in v:
|
|
return [v]
|
|
|
|
return v
|
|
|
|
|
|
class GenAIConfig(FrigateBaseModel):
|
|
enabled: bool = Field(default=False, title="Enable GenAI.")
|
|
prompt: str = Field(
|
|
default="Analyze the sequence of images containing the {label}. Focus on the likely intent or behavior of the {label} based on its actions and movement, rather than describing its appearance or the surroundings. Consider what the {label} is doing, why, and what it might do next.",
|
|
title="Default caption prompt.",
|
|
)
|
|
object_prompts: dict[str, str] = Field(
|
|
default_factory=dict, title="Object specific prompts."
|
|
)
|
|
|
|
api_key: Optional[EnvString] = Field(default=None, title="Provider API key.")
|
|
base_url: Optional[str] = Field(default=None, title="Provider base url.")
|
|
model: str = Field(default="gpt-4o", title="GenAI model.")
|
|
provider: GenAIProviderEnum = Field(
|
|
default=GenAIProviderEnum.openai, title="GenAI provider."
|
|
)
|