Changed camera.mjpeg to use Response and Closing; cleaned up a number of code-clarity issues near that

This commit is contained in:
Ryan Turner 2015-11-08 23:41:21 -06:00
parent 8541fdb112
commit dfa81b0117

View file

@ -11,7 +11,8 @@ from requests.auth import HTTPBasicAuth
from homeassistant.helpers import validate_config from homeassistant.helpers import validate_config
from homeassistant.components.camera import DOMAIN from homeassistant.components.camera import DOMAIN
from homeassistant.components.camera import Camera from homeassistant.components.camera import Camera
import urllib.request import requests
from contextlib import closing
_LOGGER = logging.getLogger(__name__) _LOGGER = logging.getLogger(__name__)
@ -41,23 +42,23 @@ class MjpegCamera(Camera):
def camera_image(self): def camera_image(self):
""" Return a still image reponse from the camera. """ """ Return a still image reponse from the camera. """
if self._username and self._password:
password_mgr = urllib.request.HTTPPasswordMgrWithDefaultRealm()
password_mgr.add_password(None, self._mjpeg_url, self._username, self._password)
handler = urllib.request.HTTPBasicAuthHandler(password_mgr)
opener = urllib.request.build_opener(handler)
urllib.request.install_opener(opener)
stream = urllib.request.urlopen(self._mjpeg_url) def process_response(response):
charset = stream.headers.get_param('charset') data = b''
bytes = b'' for chunk in response.iter_content(1024):
while True: data += chunk
bytes += stream.read(1024) jpg_start = data.find(b'\xff\xd8')
a = bytes.find(b'\xff\xd8') jpg_end = data.find(b'\xff\xd9')
b = bytes.find(b'\xff\xd9') if jpg_start != -1 and jpg_end != -1:
if a != -1 and b != -1: jpg = data[jpg_start:jpg_end + 2]
jpg = bytes[a:b+2] return jpg
return jpg
if self._username and self._password:
with closing(requests.get(self._mjpeg_url, auth=HTTPBasicAuth(self._username, self._password), stream=True)) as response:
return process_response(response)
else:
with closing(requests.get(self._mjpeg_url, stream=True)) as response:
return process_response(response)
@property @property
def name(self): def name(self):