1
0
mirror of https://github.com/checktheroads/hyperglass synced 2024-05-11 05:55:08 +00:00
checktheroads bb97b90e26 docs
2020-02-08 00:58:32 -07:00

78 lines
2.4 KiB
Python

"""Validate OpenGraph Configuration Parameters."""
# Standard Library
from typing import Optional
from pathlib import Path
# Third Party
import PIL.Image as PilImage
from pydantic import FilePath, StrictInt, root_validator
# Project
from hyperglass.configuration.models._utils import HyperglassModel
class OpenGraph(HyperglassModel):
"""Validation model for params.opengraph."""
width: Optional[StrictInt]
height: Optional[StrictInt]
image: Optional[FilePath]
@root_validator
def validate_image(cls, values):
"""Set default opengraph image location.
Arguments:
value {FilePath} -- Path to opengraph image file.
Returns:
{Path} -- Opengraph image file path object
"""
supported_extensions = (".jpg", ".jpeg", ".png")
if (
values["image"] is not None
and values["image"].suffix not in supported_extensions
):
raise ValueError(
"OpenGraph image must be one of {e}".format(
e=", ".join(supported_extensions)
)
)
if values["image"] is None:
image = (
Path(__file__).parent.parent.parent
/ "static/images/hyperglass-opengraph.png"
)
values["image"] = "".join(str(image).split("static")[1::])
with PilImage.open(image) as img:
width, height = img.size
if values["width"] is None:
values["width"] = width
if values["height"] is None:
values["height"] = height
return values
class Config:
"""Pydantic model configuration."""
title = "OpenGraph"
description = "OpenGraph configuration parameters"
fields = {
"width": {
"title": "Width",
"description": "Width of OpenGraph image. If unset, the width will be automatically derived by reading the image file.",
},
"height": {
"title": "Height",
"description": "Height of OpenGraph image. If unset, the height will be automatically derived by reading the image file.",
},
"image": {
"title": "Image File",
"description": "Valid path to a JPG or PNG file to use as the OpenGraph image.",
},
}
schema_extra = {"level": 3}