All checks were successful
ci/woodpecker/tag/build/5 Pipeline was successful
ci/woodpecker/tag/build/6 Pipeline was successful
ci/woodpecker/tag/build/4 Pipeline was successful
ci/woodpecker/tag/namespace Pipeline was successful
ci/woodpecker/tag/build/1 Pipeline was successful
ci/woodpecker/tag/config Pipeline was successful
ci/woodpecker/tag/build/7 Pipeline was successful
ci/woodpecker/tag/build/3 Pipeline was successful
ci/woodpecker/tag/build/2 Pipeline was successful
ci/woodpecker/tag/deploy/5 Pipeline was successful
ci/woodpecker/tag/deploy/3 Pipeline was successful
ci/woodpecker/tag/deploy/4 Pipeline was successful
ci/woodpecker/tag/deploy/2 Pipeline was successful
ci/woodpecker/tag/deploy/6 Pipeline was successful
ci/woodpecker/tag/deploy/1 Pipeline was successful
ci/woodpecker/tag/ingress Pipeline was successful
39 lines
890 B
Python
39 lines
890 B
Python
"""Shelly vendor transformations."""
|
|
|
|
import logging
|
|
from typing import Any
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
|
def transform_relay_to_vendor(payload: dict[str, Any]) -> str:
|
|
"""Transform abstract relay payload to Shelly format.
|
|
|
|
Shelly expects plain text 'on' or 'off' (not JSON).
|
|
|
|
Example:
|
|
- Abstract: {'power': 'on'}
|
|
- Shelly: 'on'
|
|
"""
|
|
power = payload.get("power", "off")
|
|
return power
|
|
|
|
|
|
def transform_relay_to_abstract(payload: str) -> dict[str, Any]:
|
|
"""Transform Shelly relay payload to abstract format.
|
|
|
|
Shelly sends plain text 'on' or 'off'.
|
|
|
|
Example:
|
|
- Shelly: 'on'
|
|
- Abstract: {'power': 'on'}
|
|
"""
|
|
return {"power": payload.strip()}
|
|
|
|
|
|
# Registry of handlers for this vendor
|
|
HANDLERS = {
|
|
("relay", "to_vendor"): transform_relay_to_vendor,
|
|
("relay", "to_abstract"): transform_relay_to_abstract,
|
|
}
|