Skip to content
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
21 changes: 11 additions & 10 deletions homeassistant/components/binary_sensor/digital_ocean.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,19 +8,18 @@

import voluptuous as vol

import homeassistant.helpers.config_validation as cv
from homeassistant.components.binary_sensor import (
BinarySensorDevice, PLATFORM_SCHEMA)
from homeassistant.components.digital_ocean import (
CONF_DROPLETS, ATTR_CREATED_AT, ATTR_DROPLET_ID, ATTR_DROPLET_NAME,
ATTR_FEATURES, ATTR_IPV4_ADDRESS, ATTR_IPV6_ADDRESS, ATTR_MEMORY,
ATTR_REGION, ATTR_VCPUS)
from homeassistant.loader import get_component
import homeassistant.helpers.config_validation as cv
ATTR_REGION, ATTR_VCPUS, DATA_DIGITAL_OCEAN)

_LOGGER = logging.getLogger(__name__)

DEFAULT_NAME = 'Droplet'
DEFAULT_SENSOR_CLASS = 'motion'
DEFAULT_SENSOR_CLASS = 'moving'
DEPENDENCIES = ['digital_ocean']

PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({
Expand All @@ -30,19 +29,21 @@

def setup_platform(hass, config, add_devices, discovery_info=None):
"""Set up the Digital Ocean droplet sensor."""
digital_ocean = get_component('digital_ocean')
digital = hass.data.get(DATA_DIGITAL_OCEAN)
if not digital:
return False

droplets = config.get(CONF_DROPLETS)

dev = []
for droplet in droplets:
droplet_id = digital_ocean.DIGITAL_OCEAN.get_droplet_id(droplet)
droplet_id = digital.get_droplet_id(droplet)
if droplet_id is None:
_LOGGER.error("Droplet %s is not available", droplet)
return False
dev.append(DigitalOceanBinarySensor(
digital_ocean.DIGITAL_OCEAN, droplet_id))
dev.append(DigitalOceanBinarySensor(digital, droplet_id))

add_devices(dev)
add_devices(dev, True)


class DigitalOceanBinarySensor(BinarySensorDevice):
Expand All @@ -53,7 +54,7 @@ def __init__(self, do, droplet_id):
self._digital_ocean = do
self._droplet_id = droplet_id
self._state = None
self.update()
self.data = None

@property
def name(self):
Expand Down
9 changes: 5 additions & 4 deletions homeassistant/components/digital_ocean.py
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@

CONF_DROPLETS = 'droplets'

DIGITAL_OCEAN = None
DATA_DIGITAL_OCEAN = 'data_do'
DIGITAL_OCEAN_PLATFORMS = ['switch', 'binary_sensor']
DOMAIN = 'digital_ocean'

Expand All @@ -47,13 +47,14 @@ def setup(hass, config):
conf = config[DOMAIN]
access_token = conf.get(CONF_ACCESS_TOKEN)

global DIGITAL_OCEAN
DIGITAL_OCEAN = DigitalOcean(access_token)
digital = DigitalOcean(access_token)

if not DIGITAL_OCEAN.manager.get_account():
if not digital.manager.get_account():
_LOGGER.error("No Digital Ocean account found for the given API Token")
return False

hass.data[DATA_DIGITAL_OCEAN] = digital

return True


Expand Down
19 changes: 9 additions & 10 deletions homeassistant/components/switch/digital_ocean.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,13 +8,12 @@

import voluptuous as vol

import homeassistant.helpers.config_validation as cv
from homeassistant.components.switch import (SwitchDevice, PLATFORM_SCHEMA)
from homeassistant.components.digital_ocean import (
CONF_DROPLETS, ATTR_CREATED_AT, ATTR_DROPLET_ID, ATTR_DROPLET_NAME,
ATTR_FEATURES, ATTR_IPV4_ADDRESS, ATTR_IPV6_ADDRESS, ATTR_MEMORY,
ATTR_REGION, ATTR_VCPUS)
from homeassistant.loader import get_component
import homeassistant.helpers.config_validation as cv
ATTR_REGION, ATTR_VCPUS, DATA_DIGITAL_OCEAN)

_LOGGER = logging.getLogger(__name__)

Expand All @@ -29,19 +28,21 @@

def setup_platform(hass, config, add_devices, discovery_info=None):
"""Set up the Digital Ocean droplet switch."""
digital_ocean = get_component('digital_ocean')
digital = hass.data.get(DATA_DIGITAL_OCEAN)
if not digital:
return False

droplets = config.get(CONF_DROPLETS)

dev = []
for droplet in droplets:
droplet_id = digital_ocean.DIGITAL_OCEAN.get_droplet_id(droplet)
droplet_id = digital.get_droplet_id(droplet)
if droplet_id is None:
_LOGGER.error("Droplet %s is not available", droplet)
return False
dev.append(DigitalOceanSwitch(
digital_ocean.DIGITAL_OCEAN, droplet_id))
dev.append(DigitalOceanSwitch(digital, droplet_id))

add_devices(dev)
add_devices(dev, True)


class DigitalOceanSwitch(SwitchDevice):
Expand All @@ -54,8 +55,6 @@ def __init__(self, do, droplet_id):
self.data = None
self._state = None

self.update()

@property
def name(self):
"""Return the name of the switch."""
Expand Down