Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

gateway: remove click support for gateway devices #1229

Merged
merged 2 commits into from
Dec 14, 2021
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
15 changes: 0 additions & 15 deletions miio/gateway/alarm.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,77 +2,62 @@

from datetime import datetime

import click

from ..click_common import command, format_output
from .gatewaydevice import GatewayDevice


class Alarm(GatewayDevice):
"""Class representing the Xiaomi Gateway Alarm."""

@command(default_output=format_output("[alarm_status]"))
def status(self) -> str:
"""Return the alarm status from the device."""
# Response: 'on', 'off', 'oning'
return self._gateway.send("get_arming").pop()

@command(default_output=format_output("Turning alarm on"))
def on(self):
"""Turn alarm on."""
return self._gateway.send("set_arming", ["on"])

@command(default_output=format_output("Turning alarm off"))
def off(self):
"""Turn alarm off."""
return self._gateway.send("set_arming", ["off"])

@command()
def arming_time(self) -> int:
"""Return time in seconds the alarm stays 'oning' before transitioning to
'on'."""
# Response: 5, 15, 30, 60
return self._gateway.send("get_arm_wait_time").pop()

@command(click.argument("seconds"))
def set_arming_time(self, seconds):
"""Set time the alarm stays at 'oning' before transitioning to 'on'."""
return self._gateway.send("set_arm_wait_time", [seconds])

@command()
def triggering_time(self) -> int:
"""Return the time in seconds the alarm is going off when triggered."""
# Response: 30, 60, etc.
return self._gateway.get_prop("alarm_time_len").pop()

@command(click.argument("seconds"))
def set_triggering_time(self, seconds):
"""Set the time in seconds the alarm is going off when triggered."""
return self._gateway.set_prop("alarm_time_len", seconds)

@command()
def triggering_light(self) -> int:
"""Return the time the gateway light blinks when the alarm is triggerd."""
# Response: 0=do not blink, 1=always blink, x>1=blink for x seconds
return self._gateway.get_prop("en_alarm_light").pop()

@command(click.argument("seconds"))
def set_triggering_light(self, seconds):
"""Set the time the gateway light blinks when the alarm is triggerd."""
# values: 0=do not blink, 1=always blink, x>1=blink for x seconds
return self._gateway.set_prop("en_alarm_light", seconds)

@command()
def triggering_volume(self) -> int:
"""Return the volume level at which alarms go off [0-100]."""
return self._gateway.send("get_alarming_volume").pop()

@command(click.argument("volume"))
def set_triggering_volume(self, volume):
"""Set the volume level at which alarms go off [0-100]."""
return self._gateway.send("set_alarming_volume", [volume])

@command()
def last_status_change_time(self) -> datetime:
"""Return the last time the alarm changed status."""
return datetime.fromtimestamp(self._gateway.send("get_arming_time").pop())
9 changes: 1 addition & 8 deletions miio/gateway/gatewaydevice.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@
import logging
from typing import TYPE_CHECKING

from ..device import Device
from ..exceptions import DeviceException

_LOGGER = logging.getLogger(__name__)
Expand All @@ -13,17 +12,12 @@
from .gateway import Gateway


class GatewayDevice(Device):
class GatewayDevice:
"""GatewayDevice class Specifies the init method for all gateway device
functionalities."""

def __init__(
self,
ip: str = None,
token: str = None,
start_id: int = 0,
debug: int = 0,
lazy_discover: bool = True,
parent: "Gateway" = None,
) -> None:
if parent is None:
Expand All @@ -32,4 +26,3 @@ def __init__(
)

self._gateway = parent
super().__init__(ip, token, start_id, debug, lazy_discover)
rytilahti marked this conversation as resolved.
Show resolved Hide resolved
25 changes: 0 additions & 25 deletions miio/gateway/light.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,6 @@

from typing import Tuple

import click

from ..click_common import command
from ..utils import brightness_and_color_to_int, int_to_brightness, int_to_rgb
from .gatewaydevice import GatewayDevice

Expand All @@ -31,7 +28,6 @@ class Light(GatewayDevice):
the state of the 'rgb' light.
"""

@command()
def rgb_status(self):
"""Get current status of the light. Always represents the current status of the
light as opposed to 'night_light_status'.
Expand All @@ -47,7 +43,6 @@ def rgb_status(self):

return {"is_on": is_on, "brightness": brightness, "rgb": rgb}

@command()
def night_light_status(self):
"""Get status of the night light. This command only gives the correct status of
the LEDs if the last command was a 'night_light' command and not a 'rgb' light
Expand All @@ -63,27 +58,18 @@ def night_light_status(self):

return {"is_on": is_on, "brightness": brightness, "rgb": rgb}

@command(
click.argument("brightness", type=int),
click.argument("rgb", type=(int, int, int)),
)
def set_rgb(self, brightness: int, rgb: Tuple[int, int, int]):
"""Set gateway light using brightness and rgb tuple."""
brightness_and_color = brightness_and_color_to_int(brightness, rgb)

return self._gateway.send("set_rgb", [brightness_and_color])

@command(
click.argument("brightness", type=int),
click.argument("rgb", type=(int, int, int)),
)
def set_night_light(self, brightness: int, rgb: Tuple[int, int, int]):
"""Set gateway night light using brightness and rgb tuple."""
brightness_and_color = brightness_and_color_to_int(brightness, rgb)

return self._gateway.send("set_night_light_rgb", [brightness_and_color])

@command(click.argument("brightness", type=int))
def set_rgb_brightness(self, brightness: int):
"""Set gateway light brightness (0-100)."""
if 100 < brightness < 0:
Expand All @@ -92,7 +78,6 @@ def set_rgb_brightness(self, brightness: int):

return self.set_rgb(brightness, current_color)

@command(click.argument("brightness", type=int))
def set_night_light_brightness(self, brightness: int):
"""Set night light brightness (0-100)."""
if 100 < brightness < 0:
Expand All @@ -101,7 +86,6 @@ def set_night_light_brightness(self, brightness: int):

return self.set_night_light(brightness, current_color)

@command(click.argument("color_name", type=str))
def set_rgb_color(self, color_name: str):
"""Set gateway light color using color name ('color_map' variable in the source
holds the valid values)."""
Expand All @@ -115,7 +99,6 @@ def set_rgb_color(self, color_name: str):

return self.set_rgb(current_brightness, color_map[color_name])

@command(click.argument("color_name", type=str))
def set_night_light_color(self, color_name: str):
"""Set night light color using color name ('color_map' variable in the source
holds the valid values)."""
Expand All @@ -129,10 +112,6 @@ def set_night_light_color(self, color_name: str):

return self.set_night_light(current_brightness, color_map[color_name])

@command(
click.argument("color_name", type=str),
click.argument("brightness", type=int),
)
def set_rgb_using_name(self, color_name: str, brightness: int):
"""Set gateway light color (using color name, 'color_map' variable in the source
holds the valid values) and brightness (0-100)."""
Expand All @@ -147,10 +126,6 @@ def set_rgb_using_name(self, color_name: str, brightness: int):

return self.set_rgb(brightness, color_map[color_name])

@command(
click.argument("color_name", type=str),
click.argument("brightness", type=int),
)
def set_night_light_using_name(self, color_name: str, brightness: int):
"""Set night light color (using color name, 'color_map' variable in the source
holds the valid values) and brightness (0-100)."""
Expand Down
6 changes: 0 additions & 6 deletions miio/gateway/radio.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,19 +2,16 @@

import click

from ..click_common import command
from .gatewaydevice import GatewayDevice


class Radio(GatewayDevice):
"""Radio controls for the gateway."""

@command()
def get_radio_info(self):
"""Radio play info."""
return self._gateway.send("get_prop_fm")

@command(click.argument("volume"))
def set_radio_volume(self, volume):
"""Set radio volume."""
return self._gateway.send("set_fm_volume", [volume])
Expand Down Expand Up @@ -68,15 +65,13 @@ def get_default_music(self):
raise NotImplementedError()
return self._gateway.send("get_default_music")

@command()
def get_music_info(self):
"""Unknown."""
info = self._gateway.send("get_music_info")
click.echo("info: %s" % info)
free_space = self._gateway.send("get_music_free_space")
click.echo("free space: %s" % free_space)

@command()
def get_mute(self):
"""mute of what?"""
return self._gateway.send("get_mute")
Expand All @@ -102,7 +97,6 @@ def get_download_progress(self):
raise NotImplementedError()
return self._gateway.send("get_download_progress")

@command()
def set_sound_playing(self):
"""stop playing?"""
return self._gateway.send("set_sound_playing", ["off"])
Expand Down
8 changes: 0 additions & 8 deletions miio/gateway/zigbee.py
Original file line number Diff line number Diff line change
@@ -1,30 +1,23 @@
"""Xiaomi Gateway Zigbee control implementation."""

import click

from ..click_common import command
from .gatewaydevice import GatewayDevice


class Zigbee(GatewayDevice):
"""Zigbee controls."""

@command()
def get_zigbee_version(self):
"""timeouts on device."""
return self._gateway.send("get_zigbee_device_version")

@command()
def get_zigbee_channel(self):
"""Return currently used zigbee channel."""
return self._gateway.send("get_zigbee_channel")[0]

@command(click.argument("channel"))
def set_zigbee_channel(self, channel):
"""Set zigbee channel."""
return self._gateway.send("set_zigbee_channel", [channel])

@command(click.argument("timeout", type=int))
def zigbee_pair(self, timeout):
"""Start pairing, use 0 to disable."""
return self._gateway.send("start_zigbee_join", [timeout])
Expand Down Expand Up @@ -52,7 +45,6 @@ def write_zigbee_attribute(self):
raise NotImplementedError()
return self._gateway.send("write_zigbee_attribute")

@command()
def zigbee_unpair_all(self):
"""Unpair all devices."""
return self._gateway.send("remove_all_device")
Expand Down