Integration
U-Alarm is not only a stand-alone solution, but can be used in an integrated system as well. Each article contains valuable information about the required settings in U-Alarm, as well as in the corresponding third-party software.
General concept
Components
The integration has 3 components:
U-Alarm
Third party application (preferably a VMS)
a Connector
Note: In this document, the Third party application is often referred to as VMS, however it can be any software with similar capabilities.
Topology
U-Alarm
- Receives video streams from cameras.
- Detects incidents.
- Notifies the operator on its user interface.
- Sends Event messages with metadata to an external API via HTTP.
VMS
- Receives good quality video streams from cameras.
- Stores video/Provides user interface for operators including incident management.
- Has an interface to receive real time notifications (alarms/events) from external sources.
Connector
- Dedicated to a specific VMS.
- Usually running on the same machine as the VMS.
- Associates streams registered in U-Alarm with streams registered in the VMS (easier if the VMS provides a unique identifier for each camera).
- Receives Event messages or pulls count data from U-Alarm.
- Converts U-Alarm Events to a message which is readable by the VMS.
Capabilities
Capabilities are determined by both U-Alarm and the VMS. The following information is available in the U-Alarm Event’s metadata:
- the incident’s type (Intrusion and Crowd Detection, Multi Object Detection and Multi Object Counter)
- the timestamp of the incident
- camera identifier(s)
- the detections’ coordinates in the camera frame
- confidence value - events with lower confidence can be filtered in order to decrease false positive alarms
(Learn more about the metadata for your Custom Integration...)
This information is translated by the Connector component. The capabilities of the VMS may limit the forwarded information and the overall end user experience.
Example scenario
Installation
- U-Alarm is installed on an NVidia Jetson NX box.
- The VMS is installed on a Windows server.
- The Connector is installed on the same machine.
- Both machines are on the same local network with fixed IP addresses.
Configuration
VMS
The VMS is configured according to its own documentation with the following requirements:
- Observed Cameras must be registered in both U-Alarm and in the VMS. The VMS may use the primary stream of the cameras with higher resolution and FPS compared to U-Alarm. A unique identifier should be memorized for each registered camera. The identifiers will be used in U-Alarm configuration.
- Access credentials for the connector.
- All other settings in order to receive external events.
Connector
Connector must have the following information:
- Access credentials for the VMS.
- An unused port for its service.
- The (network) location of the VMS interface.
U-Alarm
U-Alarm is configured along its own documentation with the following exceptions:
- Observed Cameras must be registered in both U-Alarm and in the VMS. U-Alarm often uses a secondary stream of the same camera with lower resolution and FPS.
- Cameras’ Technical names must be set. Each technical name should be unique and should match the unique identifier of the same camera in the VMS.
- The network address of the Connector (host, port) must be set in the Alarm configuration.
Workflow
In this example let’s say we configured intrusion detection in U-Alarm.
- The intruder enters an observed area.
- The camera stream is sent to U-Alarm.
- U-Alarm detects the intruder and immediately sends an Event to the Connector.
- The Connector converts the incoming Event and sends it to the VMS.
- The VMS triggers an alarm and notifies the operator.
Implementations
For alarms
Milestone XProtect
Milestone XProtect is one of the most popular Video Management Systems. U-Alarm is able to send Alarms to this system so you can manage incidents in your well known platform.
Alarms via E-mail
U-Alarm can be configured to send alarms via e-mail. This enables you to use U-Alarm in conjunction with e-mail notifications, or omit the use of U-Alarm altogether. The service can be set up to be used by either human beings or automated systems.
Custom Integration
This guide will aid developers in order to receive and process Alarms triggered U-Alarm in their custom solution.
For people and vehicle counting
Counter API
U-Alarm's measurement-based counters are designed to be used with custom third party software. Read on to learn how the data created by the counters can be read from U-Alarm.
Monitoring
SNMP
SNMP settings are available in the Control Panel.
Status via HTTP API
You can progamatically acquire several metrics from the U-Alarm via its HTTP API.
The response contains a JSON object with the available metrics. Integrating applications should accept unkown keys in the response, as new metrics may be added in later versions.
The endpoint is authenticated via API token in the Authorization header, see here.
Standard HTTP response codes are used:
- 200 for successful response
- 401 for authentication failure
- >=500 if the API could not respond due to error
The following example uses curl to test if the U-Alarm API endpoint is reachable.
curl -H 'Authorization: Bearer <API token>' -H 'Accept: application/json' 'http://<address-of-ualarm>/API/system/status'
or if HTTPS is configured
curl -H 'Authorization: Bearer <API token>' -H 'Accept: application/json' 'https://<address-of-ualarm>/API/system/status'
Response body:
{
"sysuptime": 78792, //< system uptime in seconds
"avgcpu": 22, //< average CPU utilization
"avggpu": 0, //< average GPU utilization (used by video analitics)
"ram_available_megabytes": 4900, //< unused RAM
"ram_used_megabytes": 7859, //< RAM usage
"ram_used_pcnt": 38, //< RAM used percentage
"ualarm": {
"systemstatus": 1, //< 1=OK, 2=ERROR
"videostorage_total_bytes": 491182010368, //< storage assigned for Event videos
"videostorage_free_bytes": 401370316800, //< storage free
"videostorage_used_pcnt": 19, //< storage used percentage
"systemstatus_msg": " ", //< if systemstatus is 2, a message describes it.
"cameras_statuses": [
{
"id": "cam5",
"display_name": "display name of cam5",
"technical_name": "technical name of cam5",
"problems": []
},
{
"id": "cam7",
"display_name": "Garage",
"technical_name": "garage cam",
"problems": []
}
]
}
}