Compare commits
No commits in common. "564bac8ea4919e6d1ccdfd79f48f4ffe8b3d6266" and "83db799b9661fa42d60c3acb4e51a712185a7d2a" have entirely different histories.
564bac8ea4
...
83db799b96
6 changed files with 23 additions and 95 deletions
|
|
@ -18,33 +18,16 @@ from .settings import SETTINGS
|
|||
_logger = getLogger(__name__)
|
||||
|
||||
|
||||
class TickerAPIConfig(BaseModel):
|
||||
"""
|
||||
Section "[ticker.api]" in "config.txt".
|
||||
"""
|
||||
|
||||
file_name: str = "ticker"
|
||||
separator: str = " +++ "
|
||||
comment_marker: str = "#"
|
||||
|
||||
|
||||
class TickerUIConfig(BaseModel):
|
||||
"""
|
||||
Section "[ticker.ui]" in "config.txt".
|
||||
"""
|
||||
|
||||
display: bool = True
|
||||
color: str = "primary"
|
||||
speed: int = 30
|
||||
|
||||
|
||||
class TickerConfig(BaseModel):
|
||||
"""
|
||||
Section "[ticker]" in "config.txt".
|
||||
"""
|
||||
|
||||
api: TickerAPIConfig = TickerAPIConfig()
|
||||
ui: TickerUIConfig = TickerUIConfig()
|
||||
file_name: str = "ticker"
|
||||
separator: str = " +++ "
|
||||
comment_marker: str = "#"
|
||||
color: str = "primary"
|
||||
speed: int = 30
|
||||
|
||||
|
||||
class ImageConfig(BaseModel):
|
||||
|
|
@ -89,7 +72,7 @@ class Config(BaseModel):
|
|||
dav_file = DavFile(SETTINGS.config_path)
|
||||
|
||||
try:
|
||||
cfg = cls.parse_obj(
|
||||
return cls.parse_obj(
|
||||
toml_loads(await dav_file.as_string)
|
||||
)
|
||||
|
||||
|
|
@ -106,4 +89,4 @@ class Config(BaseModel):
|
|||
buffer.seek(0)
|
||||
await dav_file.write(buffer.read())
|
||||
|
||||
return cfg
|
||||
return cfg
|
||||
|
|
|
|||
|
|
@ -7,7 +7,7 @@ This file: Main API router definition.
|
|||
from fastapi import APIRouter
|
||||
|
||||
from ..settings import SETTINGS
|
||||
from . import aggregate, calendar, image, misc, text, ticker
|
||||
from . import aggregate, calendar, image, text, ticker
|
||||
|
||||
main_router = APIRouter(prefix=f"/{SETTINGS.api_v1_prefix}")
|
||||
main_router.include_router(text.router)
|
||||
|
|
@ -15,7 +15,6 @@ main_router.include_router(ticker.router)
|
|||
main_router.include_router(image.router)
|
||||
main_router.include_router(calendar.router)
|
||||
main_router.include_router(aggregate.router)
|
||||
main_router.include_router(misc.router)
|
||||
|
||||
__all__ = [
|
||||
"main_router",
|
||||
|
|
|
|||
|
|
@ -1,45 +0,0 @@
|
|||
"""
|
||||
Router "misc" provides:
|
||||
|
||||
- getting the project version
|
||||
- getting the device IP
|
||||
"""
|
||||
|
||||
from importlib.metadata import version
|
||||
from logging import getLogger
|
||||
from socket import AF_INET, SOCK_DGRAM, socket
|
||||
|
||||
from fastapi import APIRouter
|
||||
|
||||
from ..settings import SETTINGS
|
||||
|
||||
_logger = getLogger(__name__)
|
||||
|
||||
router = APIRouter(prefix="/misc", tags=["misc"])
|
||||
|
||||
|
||||
@router.on_event("startup")
|
||||
async def start_router() -> None:
|
||||
_logger.debug(f"{router.prefix} router starting.")
|
||||
|
||||
|
||||
@router.get("/lanip")
|
||||
async def get_ip() -> str:
|
||||
with socket(
|
||||
family=AF_INET,
|
||||
type=SOCK_DGRAM,
|
||||
) as s:
|
||||
s.settimeout(0)
|
||||
try:
|
||||
s.connect((SETTINGS.ping_address, SETTINGS.ping_port))
|
||||
IP = s.getsockname()[0]
|
||||
|
||||
except Exception:
|
||||
IP = "127.0.0.1"
|
||||
|
||||
return IP
|
||||
|
||||
|
||||
@router.get("/version")
|
||||
async def get_version() -> str:
|
||||
return version("ovdashboard-api")
|
||||
|
|
@ -5,6 +5,8 @@ Router "text" provides:
|
|||
- finding text files by name prefix
|
||||
- getting text file raw content by name prefix
|
||||
- getting text file HTML content by name prefix (using Markdown)
|
||||
- getting the "ticker" raw content
|
||||
- getting the "ticker" HTML content (using Markdown)
|
||||
"""
|
||||
|
||||
import re
|
||||
|
|
|
|||
|
|
@ -1,9 +1,12 @@
|
|||
"""
|
||||
Router "ticker" provides:
|
||||
Router "text" provides:
|
||||
|
||||
- getting the ticker's raw content
|
||||
- getting the ticker's HTML content (using Markdown)
|
||||
- getting the ticker's UI config
|
||||
- listing text files
|
||||
- finding text files by name prefix
|
||||
- getting text file raw content by name prefix
|
||||
- getting text file HTML content by name prefix (using Markdown)
|
||||
- getting the "ticker" raw content
|
||||
- getting the "ticker" HTML content (using Markdown)
|
||||
"""
|
||||
|
||||
from logging import getLogger
|
||||
|
|
@ -12,7 +15,7 @@ from typing import Iterator
|
|||
from fastapi import APIRouter, Depends
|
||||
from markdown import markdown
|
||||
|
||||
from ..config import Config, TickerUIConfig
|
||||
from ..config import Config
|
||||
from ..dav_common import webdav_ensure_path
|
||||
from ..dav_file import DavFile
|
||||
from .text import text_lister, text_unique
|
||||
|
|
@ -31,7 +34,7 @@ async def start_router() -> None:
|
|||
|
||||
async def get_ticker_lines() -> Iterator[str]:
|
||||
cfg = await Config.get()
|
||||
file_name = await text_unique(cfg.ticker.api.file_name)
|
||||
file_name = await text_unique(cfg.ticker.file_name)
|
||||
|
||||
ticker = await DavFile(
|
||||
f"{await text_lister.remote_path}/{file_name}",
|
||||
|
|
@ -52,7 +55,7 @@ async def get_ticker_content_lines(
|
|||
return (
|
||||
line
|
||||
for line in ticker_lines
|
||||
if not line.startswith(cfg.ticker.api.comment_marker)
|
||||
if not line.startswith(cfg.ticker.comment_marker)
|
||||
)
|
||||
|
||||
|
||||
|
|
@ -60,32 +63,22 @@ async def get_ticker_content(
|
|||
ticker_content_lines: Iterator[str] = Depends(get_ticker_content_lines),
|
||||
) -> str:
|
||||
cfg = await Config.get()
|
||||
ticker_content = cfg.ticker.api.separator.join(
|
||||
ticker_content = cfg.ticker.separator.join(
|
||||
["", *ticker_content_lines, ""],
|
||||
)
|
||||
|
||||
return ticker_content.strip()
|
||||
|
||||
|
||||
@ router.get("/html")
|
||||
@ router.get("/get/html")
|
||||
async def get_ticker(
|
||||
ticker_content: str = Depends(get_ticker_content),
|
||||
) -> str:
|
||||
return markdown(ticker_content)
|
||||
|
||||
|
||||
@ router.get("/raw")
|
||||
@ router.get("/get/raw")
|
||||
async def get_raw_ticker(
|
||||
ticker_content: str = Depends(get_ticker_content),
|
||||
) -> str:
|
||||
return ticker_content
|
||||
|
||||
|
||||
@ router.get(
|
||||
"/config",
|
||||
response_model=TickerUIConfig,
|
||||
)
|
||||
async def get_ui_config(
|
||||
cfg: Config = Depends(Config.get),
|
||||
) -> TickerUIConfig:
|
||||
return cfg.ticker.ui
|
||||
|
|
|
|||
|
|
@ -52,10 +52,6 @@ class Settings(BaseSettings):
|
|||
cache_seconds: int = 30
|
||||
cache_size: int = 30
|
||||
|
||||
# doesn't even have to be reachable
|
||||
ping_address: str = "10.0.0.0"
|
||||
ping_port: int = 1
|
||||
|
||||
api_v1_prefix: str = "api/v1"
|
||||
openapi_url: str = "/openapi.json"
|
||||
docs_url: Optional[str] = None if production_mode else "/docs"
|
||||
|
|
|
|||
Loading…
Reference in a new issue