2016-07-10 20:21:53 +00:00
|
|
|
"""
|
2016-07-12 14:46:29 +00:00
|
|
|
IMAP sensor support.
|
2016-07-10 20:21:53 +00:00
|
|
|
|
2016-07-12 14:46:29 +00:00
|
|
|
For more details about this platform, please refer to the documentation at
|
|
|
|
https://home-assistant.io/components/sensor.imap/
|
2016-07-10 20:21:53 +00:00
|
|
|
"""
|
|
|
|
import logging
|
2016-08-20 22:40:16 +00:00
|
|
|
|
2016-07-10 20:21:53 +00:00
|
|
|
import voluptuous as vol
|
|
|
|
|
|
|
|
from homeassistant.helpers.entity import Entity
|
2016-08-20 22:40:16 +00:00
|
|
|
from homeassistant.components.sensor import PLATFORM_SCHEMA
|
|
|
|
from homeassistant.const import (
|
|
|
|
CONF_NAME, CONF_PORT, CONF_USERNAME, CONF_PASSWORD)
|
2016-07-10 20:21:53 +00:00
|
|
|
import homeassistant.helpers.config_validation as cv
|
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
CONF_SERVER = "server"
|
|
|
|
|
|
|
|
DEFAULT_PORT = 993
|
2016-08-20 22:40:16 +00:00
|
|
|
ICON = 'mdi:email-outline'
|
2016-07-10 20:21:53 +00:00
|
|
|
|
2016-08-20 22:40:16 +00:00
|
|
|
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({
|
2016-07-10 20:21:53 +00:00
|
|
|
vol.Optional(CONF_NAME): cv.string,
|
2016-08-20 22:40:16 +00:00
|
|
|
vol.Required(CONF_USERNAME): cv.string,
|
2016-07-10 20:21:53 +00:00
|
|
|
vol.Required(CONF_PASSWORD): cv.string,
|
|
|
|
vol.Required(CONF_SERVER): cv.string,
|
2016-08-17 03:55:29 +00:00
|
|
|
vol.Optional(CONF_PORT, default=DEFAULT_PORT): cv.port,
|
2016-07-10 20:21:53 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
|
|
|
|
def setup_platform(hass, config, add_devices, discovery_info=None):
|
2017-05-02 16:18:47 +00:00
|
|
|
"""Set up the IMAP platform."""
|
|
|
|
sensor = ImapSensor(
|
|
|
|
config.get(CONF_NAME, None), config.get(CONF_USERNAME),
|
|
|
|
config.get(CONF_PASSWORD), config.get(CONF_SERVER),
|
|
|
|
config.get(CONF_PORT))
|
2016-07-10 20:21:53 +00:00
|
|
|
|
|
|
|
if sensor.connection:
|
|
|
|
add_devices([sensor])
|
|
|
|
else:
|
|
|
|
return False
|
|
|
|
|
|
|
|
|
|
|
|
class ImapSensor(Entity):
|
2016-07-12 14:46:29 +00:00
|
|
|
"""Representation of an IMAP sensor."""
|
2016-07-10 20:21:53 +00:00
|
|
|
|
|
|
|
def __init__(self, name, user, password, server, port):
|
|
|
|
"""Initialize the sensor."""
|
|
|
|
self._name = name or user
|
|
|
|
self._user = user
|
|
|
|
self._password = password
|
|
|
|
self._server = server
|
|
|
|
self._port = port
|
|
|
|
self._unread_count = 0
|
|
|
|
self.connection = self._login()
|
|
|
|
self.update()
|
|
|
|
|
|
|
|
def _login(self):
|
2016-07-12 14:46:29 +00:00
|
|
|
"""Login and return an IMAP connection."""
|
2016-07-10 20:21:53 +00:00
|
|
|
import imaplib
|
|
|
|
try:
|
|
|
|
connection = imaplib.IMAP4_SSL(self._server, self._port)
|
|
|
|
connection.login(self._user, self._password)
|
|
|
|
return connection
|
|
|
|
except imaplib.IMAP4.error:
|
|
|
|
_LOGGER.error("Failed to login to %s.", self._server)
|
|
|
|
return False
|
|
|
|
|
|
|
|
@property
|
|
|
|
def name(self):
|
|
|
|
"""Return the name of the sensor."""
|
|
|
|
return self._name
|
|
|
|
|
|
|
|
@property
|
|
|
|
def state(self):
|
|
|
|
"""Return the number of unread emails."""
|
|
|
|
return self._unread_count
|
|
|
|
|
|
|
|
def update(self):
|
|
|
|
"""Check the number of unread emails."""
|
|
|
|
import imaplib
|
|
|
|
try:
|
|
|
|
self.connection.select()
|
|
|
|
self._unread_count = len(self.connection.search(
|
2017-03-05 16:15:25 +00:00
|
|
|
None, 'UnSeen UnDeleted')[1][0].split())
|
2016-07-17 20:02:14 +00:00
|
|
|
except imaplib.IMAP4.error:
|
2016-07-10 20:21:53 +00:00
|
|
|
_LOGGER.info("Connection to %s lost, attempting to reconnect",
|
|
|
|
self._server)
|
|
|
|
try:
|
2016-07-17 20:02:14 +00:00
|
|
|
self.connection = self._login()
|
2016-07-10 20:21:53 +00:00
|
|
|
except imaplib.IMAP4.error:
|
|
|
|
_LOGGER.error("Failed to reconnect.")
|
|
|
|
|
|
|
|
@property
|
|
|
|
def icon(self):
|
|
|
|
"""Return the icon to use in the frontend."""
|
|
|
|
return ICON
|