Async Python Client for ONVIF Camera
Project description
ONVIF Client Implementation in Python 3
Dependencies
zeep[async] >= 4.1.0, < 5.0.0 httpx >= 0.19.0, < 1.0.0
Install python-onvif-zeep-async
From Source
You should clone this repository and run setup.py:
cd python-onvif-zeep-async && python setup.py install
Alternatively, you can run:
pip install --upgrade onvif-zeep-async
Getting Started
Initialize an ONVIFCamera instance
from onvif import ONVIFCamera
mycam = ONVIFCamera('192.168.0.2', 80, 'user', 'passwd', '/etc/onvif/wsdl/')
await mycam.update_xaddrs()
Now, an ONVIFCamera instance is available. By default, a devicemgmt service is also available if everything is OK.
So, all operations defined in the WSDL document:
/etc/onvif/wsdl/devicemgmt.wsdl
are available.
Get information from your camera
# Get Hostname resp = await mycam.devicemgmt.GetHostname() print 'My camera`s hostname: ' + str(resp.Name) # Get system date and time dt = await mycam.devicemgmt.GetSystemDateAndTime() tz = dt.TimeZone year = dt.UTCDateTime.Date.Year hour = dt.UTCDateTime.Time.Hour
Configure (Control) your camera
To configure your camera, there are two ways to pass parameters to service methods.
Dict
This is the simpler way:
params = {'Name': 'NewHostName'}
await device_service.SetHostname(params)
Type Instance
This is the recommended way. Type instance will raise an exception if you set an invalid (or non-existent) parameter.
params = mycam.devicemgmt.create_type('SetHostname')
params.Hostname = 'NewHostName'
await mycam.devicemgmt.SetHostname(params)
time_params = mycam.devicemgmt.create_type('SetSystemDateAndTime')
time_params.DateTimeType = 'Manual'
time_params.DaylightSavings = True
time_params.TimeZone.TZ = 'CST-8:00:00'
time_params.UTCDateTime.Date.Year = 2014
time_params.UTCDateTime.Date.Month = 12
time_params.UTCDateTime.Date.Day = 3
time_params.UTCDateTime.Time.Hour = 9
time_params.UTCDateTime.Time.Minute = 36
time_params.UTCDateTime.Time.Second = 11
await mycam.devicemgmt.SetSystemDateAndTime(time_params)
Use other services
ONVIF protocol has defined many services. You can find all the services and operations here. ONVIFCamera has support methods to create new services:
# Create ptz service ptz_service = mycam.create_ptz_service() # Get ptz configuration await mycam.ptz.GetConfiguration() # Another way # await ptz_service.GetConfiguration()
Or create an unofficial service:
xaddr = 'http://192.168.0.3:8888/onvif/yourservice'
yourservice = mycam.create_onvif_service('service.wsdl', xaddr, 'yourservice')
await yourservice.SomeOperation()
# Another way
# await mycam.yourservice.SomeOperation()
References
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file onvif_zeep_async-4.0.4.tar.gz.
File metadata
- Download URL: onvif_zeep_async-4.0.4.tar.gz
- Upload date:
- Size: 190.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cf948368f26ce68ef34da29a1dddeb95ac1baeffcc7cc832b13af3e1bb9c7893
|
|
| MD5 |
0c9fba561d80c09e3cdac08bf6b4dc05
|
|
| BLAKE2b-256 |
14ec416da8e22abb7ca9454be918c1a0f32084ec0ede082224ba66f0cfbd8541
|
Provenance
The following attestation bundles were made for onvif_zeep_async-4.0.4.tar.gz:
Publisher:
python-publish.yml on openvideolibs/python-onvif-zeep-async
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
onvif_zeep_async-4.0.4.tar.gz -
Subject digest:
cf948368f26ce68ef34da29a1dddeb95ac1baeffcc7cc832b13af3e1bb9c7893 - Sigstore transparency entry: 414584692
- Sigstore integration time:
-
Permalink:
openvideolibs/python-onvif-zeep-async@7c92736fbc8c881ee4c07c92bf29be573cf72590 -
Branch / Tag:
refs/tags/v4.0.4 - Owner: https://github.com/openvideolibs
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@7c92736fbc8c881ee4c07c92bf29be573cf72590 -
Trigger Event:
release
-
Statement type:
File details
Details for the file onvif_zeep_async-4.0.4-py3-none-any.whl.
File metadata
- Download URL: onvif_zeep_async-4.0.4-py3-none-any.whl
- Upload date:
- Size: 202.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e0b662a935008cca225b0ec377bc0dfdc5e0988d2166ea3efe4c45505f5b7b63
|
|
| MD5 |
07ccba98ff08e4a9dfd962334e3cf0af
|
|
| BLAKE2b-256 |
05142faeef207f138c5e97c187bb275449a4695f576a6f65071f9fd1301c82a4
|
Provenance
The following attestation bundles were made for onvif_zeep_async-4.0.4-py3-none-any.whl:
Publisher:
python-publish.yml on openvideolibs/python-onvif-zeep-async
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
onvif_zeep_async-4.0.4-py3-none-any.whl -
Subject digest:
e0b662a935008cca225b0ec377bc0dfdc5e0988d2166ea3efe4c45505f5b7b63 - Sigstore transparency entry: 414584697
- Sigstore integration time:
-
Permalink:
openvideolibs/python-onvif-zeep-async@7c92736fbc8c881ee4c07c92bf29be573cf72590 -
Branch / Tag:
refs/tags/v4.0.4 - Owner: https://github.com/openvideolibs
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@7c92736fbc8c881ee4c07c92bf29be573cf72590 -
Trigger Event:
release
-
Statement type: