mirror of
https://github.com/blakeblackshear/frigate.git
synced 2024-11-26 19:06:11 +01:00
cffc431bf0
* POC: Added FastAPI with one endpoint (get /logs/service) * POC: Revert error_log * POC: Converted preview related endpoints to FastAPI * POC: Converted two more endpoints to FastAPI * POC: lint * Convert all media endpoints to FastAPI. Added /media prefix (/media/camera && media/events && /media/preview) * Convert all notifications API endpoints to FastAPI * Convert first review API endpoints to FastAPI * Convert remaining review API endpoints to FastAPI * Convert export endpoints to FastAPI * Fix path parameters * Convert events endpoints to FastAPI * Use body for multiple events endpoints * Use body for multiple events endpoints (create and end event) * Convert app endpoints to FastAPI * Convert app endpoints to FastAPI * Convert auth endpoints to FastAPI * Removed flask app in favour of FastAPI app. Implemented FastAPI middleware to check CSRF, connect and disconnect from DB. Added middleware x-forwared-for headers * Added starlette plugin to expose custom headers * Use slowapi as the limiter * Use query parameters for the frame latest endpoint * Use query parameters for the media snapshot.jpg endpoint * Use query parameters for the media MJPEG feed endpoint * Revert initial nginx.conf change * Added missing even_id for /events/search endpoint * Removed left over comment * Use FastAPI TestClient * severity query parameter should be a string * Use the same pattern for all tests * Fix endpoint * Revert media routers to old names. Order routes to make sure the dynamic ones from media.py are only used whenever there's no match on auth/etc * Reverted paths for media on tsx files * Deleted file * Fix test_http to use TestClient * Formatting * Bind timeline to DB * Fix http tests * Replace filename with pathvalidate * Fix latest.ext handling and disable uvicorn access logs * Add cosntraints to api provided values * Formatting * Remove unused * Remove unused * Get rate limiter working --------- Co-authored-by: Nicolas Mowen <nickmowen213@gmail.com>
53 lines
1.6 KiB
Python
53 lines
1.6 KiB
Python
from typing import Optional
|
|
|
|
from pydantic import BaseModel
|
|
|
|
DEFAULT_TIME_RANGE = "00:00,24:00"
|
|
|
|
|
|
class EventsQueryParams(BaseModel):
|
|
camera: Optional[str] = "all"
|
|
cameras: Optional[str] = "all"
|
|
label: Optional[str] = "all"
|
|
labels: Optional[str] = "all"
|
|
sub_label: Optional[str] = "all"
|
|
sub_labels: Optional[str] = "all"
|
|
zone: Optional[str] = "all"
|
|
zones: Optional[str] = "all"
|
|
limit: Optional[int] = 100
|
|
after: Optional[float] = None
|
|
before: Optional[float] = None
|
|
time_range: Optional[str] = DEFAULT_TIME_RANGE
|
|
has_clip: Optional[int] = None
|
|
has_snapshot: Optional[int] = None
|
|
in_progress: Optional[int] = None
|
|
include_thumbnails: Optional[int] = 1
|
|
favorites: Optional[int] = None
|
|
min_score: Optional[float] = None
|
|
max_score: Optional[float] = None
|
|
is_submitted: Optional[int] = None
|
|
min_length: Optional[float] = None
|
|
max_length: Optional[float] = None
|
|
sort: Optional[str] = None
|
|
timezone: Optional[str] = "utc"
|
|
|
|
|
|
class EventsSearchQueryParams(BaseModel):
|
|
query: Optional[str] = None
|
|
event_id: Optional[str] = None
|
|
search_type: Optional[str] = "thumbnail,description"
|
|
include_thumbnails: Optional[int] = 1
|
|
limit: Optional[int] = 50
|
|
cameras: Optional[str] = "all"
|
|
labels: Optional[str] = "all"
|
|
zones: Optional[str] = "all"
|
|
after: Optional[float] = None
|
|
before: Optional[float] = None
|
|
timezone: Optional[str] = "utc"
|
|
|
|
|
|
class EventsSummaryQueryParams(BaseModel):
|
|
timezone: Optional[str] = "utc"
|
|
has_clip: Optional[int] = None
|
|
has_snapshot: Optional[int] = None
|