Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/use-go/onvif
full and enhanced onvif protocol stack in golang.
https://github.com/use-go/onvif
getcapabilities ip-cameras library onvif onvif-protocol onvif-services ptz
Last synced: 3 months ago
JSON representation
full and enhanced onvif protocol stack in golang.
- Host: GitHub
- URL: https://github.com/use-go/onvif
- Owner: use-go
- License: mit
- Created: 2019-11-07T12:39:54.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2024-03-28T11:16:51.000Z (10 months ago)
- Last Synced: 2024-07-31T20:27:42.136Z (6 months ago)
- Topics: getcapabilities, ip-cameras, library, onvif, onvif-protocol, onvif-services, ptz
- Language: Go
- Homepage:
- Size: 1.57 MB
- Stars: 387
- Watchers: 17
- Forks: 180
- Open Issues: 21
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-ip-camera - onvif - Go client (Generic software / ONVIF)
README
# onvif protocol
Simple management of onvif IP-devices cameras. onvif is an implementation of ONVIF protocol for managing onvif IP devices. The purpose of this library is convenient and easy management of IP cameras and other devices that support ONVIF standard.
## Installation
To install the library, use **go get**:
```go
go get github.com/use-go/onvif```
## Supported services
The following services are implemented:
- Device
- Media
- PTZ
- Imaging
- Event
- Discovery
- Auth(More Options)
- Soap## Using
### General concept
1) Connecting to the device
2) Authentication (if necessary)
3) Defining Data Types
4) Carrying out the required method#### Connecting to the device
If there is a device on the network at the address *192.168.13.42*, and its ONVIF services use the *1234* port, then you can connect to the device in the following way:
```go
dev, err := onvif.NewDevice(onvif.DeviceParams{Xaddr: "192.168.13.42:1234"})
```*The ONVIF port may differ depending on the device , to find out which port to use, you can go to the web interface of the device. **Usually this is 80 port.***
#### Authentication
If any function of the ONVIF services requires authentication, you must use the `Authenticate` method.
```go
device := onvif.NewDevice(onvif.DeviceParams{Xaddr: "192.168.13.42:1234", Username: "username", Password: password})
```#### Defining Data Types
Each ONVIF service in this library has its own package, in which all data types of this service are defined, and the package name is identical to the service name and begins with a capital letter. onvif defines the structures for each function of each ONVIF service supported by this library. Define the data type of the `GetCapabilities` function of the Device service. This is done as follows:
```go
capabilities := device.GetCapabilities{Category:"All"}
```Why does the `GetCapabilities` structure have the Category field and why is the value of this field `All`?
The figure below shows the documentation for the [GetCapabilities](https://www.onvif.org/ver10/device/wsdl/devicemgmt.wsdl). It can be seen that the function takes one Category parameter and its value should be one of the following: 'All', 'Analytics',' Device ',' Events', 'Imaging', 'Media' or 'PTZ'`.
![Device GetCapabilities](docs/img/exmp_GetCapabilities.png)
An example of defining the data type of `GetServiceCapabilities` function in [PTZ](https://www.onvif.org/ver20/ptz/wsdl/ptz.wsdl):
```go
ptzCapabilities := ptz.GetServiceCapabilities{}
```The figure below shows that `GetServiceCapabilities` does not accept any arguments.
![PTZ GetServiceCapabilities](docs/img/GetServiceCapabilities.png)
*Common data types are in the xsd/onvif package. The types of data (structures) that can be shared by all services are defined in the onvif package.*
An example of how to define the data type of the CreateUsers function in [Devicemgmt](https://www.onvif.org/ver10/device/wsdl/devicemgmt.wsdl):
```go
createUsers := device.CreateUsers{User: onvif.User{Username:"admin", Password:"qwerty", UserLevel:"User"}}
```The figure below shows that ,in this example, the `CreateUsers` structure field must be a User whose data type is the User structure containing the Username, Password, UserLevel, and optional Extension fields. The User structure is in the onvif package.
![Device CreateUsers](docs/img/exmp_CreateUsers.png)
#### Carrying out the required method
To perform any function of one of the ONVIF services whose structure has been defined, you must use the `CallMethod` of the device object.
```go
createUsers := device.CreateUsers{User: onvif.User{Username:"admin", Password:"qwerty", UserLevel:"User"}}
device := onvif.NewDevice(onvif.DeviceParams{Xaddr: "192.168.13.42:1234", Username: "username", Password: password})
device.Authenticate("username", "password")
resp, err := dev.CallMethod(createUsers)
```## Great Thanks
Enhanced and Improved from: [goonvif](https://github.com/yakovlevdmv/goonvif)