Python API for UniFi Video
Project description
unifi-video-api
Python API for interfacing with UniFi Video.
Supported UniFi Video versions: v3.9.12 to v3.10.6
Supported Ubiquiti camera models: UVC, UVC G3, UVC G3 Dome, UVC Dome, UVC Pro, UVC G3 Pro, UVC G3 Flex, UVC Micro, UVC G3 Micro, airCam, airCam Dome, and airCam Mini.
Features
For a single UniFi Video server:
- Support both username/password and API key auths
- Provide GET, POST, PUT, and DELETE methods
- Handle session tracking and login when necessary
- Provide iterable collections for cameras and recordings that the UniFi Video server is aware of
Per camera:
- Set or show picture settings: brightness, contrast, saturation, hue, denoise, sharpness, dynamic range
- Set or show IR led state
- Set or show on-display text
- Set or show timestamp state
- Set or show watermark/logo state
- Set recording mode to fulltime, motion, or disabled
- Set recording pre/post padding
- Take and download pictures (snapshots)
- Download camera footage between arbitrary start and end times
Per recording:
- Delete
- Download
- Snapshot (thumbnail) download
Installation
Either grab it from PyPI
pip install unifi-video
or download a release and manually place unifi_video in your project
directory, or any path in $PYTHONPATH
.
You shouldn't need any external libraries, unless you want to run the tests or build the docs (see requirements_dev.txt). unifi-video-api does use the six library but will fallback to using the included six should it fail to import six from system level packages.
Both python 2.7+ and python3 are supported.
Usage
See the docs for an API reference.
from unifi_video import UnifiVideoAPI
# Default kwargs: addr = 'localhost', port = 7080, schema = http
uva = UnifiVideoAPI(username='username', password='password', addr='10.3.2.1')
# Use API key (can be set per user in Unifi NVR user settings)
uva = UnifiVideoAPI(api_key='xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx', addr='10.3.2.1')
# Skip version checking
uva = UnifiVideoAPI(api_key='xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx', addr='10.3.2.1',
check_ufv_version=False)
# Use HTTPS and skip cert verification
uva = UnifiVideoAPI(api_key='xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx', addr='10.3.2.1',
port=7443, schema='https', verify_cert=False)
# Save snapshot from camera whose id, name or onscreen display text
# is "Garage"
uva.get_camera('Garage').snapshot('some/path/snapshot.jpg')
# Save snapshot from all cameras to ./snapshot_camera id_timestamp.jpg
for camera in uva.cameras:
camera.snapshot()
# Get footage from camera "Garage" for specific timespan.
# (The resulting file will be 0 bytes when no footage is found.)
uva.get_camera('Garage').recording_between('2018-12-01 00:00:00',
'2018-12-01 00:05:00')
# Specify filename
uva.get_camera('Garage').recording_between('2018-12-01 00:00:00',
'2018-12-01 00:05:00', 'first_mins_of_dec.mp4')
# Change onscreen display text
uva.get_camera('Garage').set_onscreen_text('Home garage')
# Set IR leds to auto mode
uva.get_camera('Garage').ir_leds('auto')
# Turn off IR leds (manual mode implied)
uva.get_camera('Garage').ir_leds('off')
# Turn on IR leds (manual mode implied)
uva.get_camera('Garage').ir_leds('on')
# Set camera to record at all times and to pre capture 5 secs
uva.get_camera('Garage').set_recording_settings('fulltime',
pre_padding_secs=5)
# Set camera to record motion events only
uva.get_camera('Garage').set_recording_settings('motion')
# Disable recording altogether
uva.get_camera('Garage').set_recording_settings('disable')
# List recordings
for rec in uva.recordings:
print(rec)
# Download recording, write to local file recording01.mp4
uva.recordings['xxxxxxxxxxxxxxxxxxxx'].download('recording01.mp4')
Warning
This software has been tested against a limited set of API versions and hardware. While unlikely, should any of the POST payloads result in software or hardware failure, the maintainer of this package is not liable.
Proceed at your own risk.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file unifi-video-0.1.2.tar.gz
.
File metadata
- Download URL: unifi-video-0.1.2.tar.gz
- Upload date:
- Size: 21.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.7.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 71b683d1c03de1999f84ea91963319b7e997c3f9927e5a05f8aa497073d6d1a8 |
|
MD5 | e7d5c88b289b0f55f365c706141ce4df |
|
BLAKE2b-256 | 5e53fb1988935fb1270c2617c87211628b8d649972c776f76c96a14f48eadaff |