Cluebase VMS Architectural and Engineering Specification
General Description
1. Cluebase video management system (VMS) is an enterprise-level client/server-based smart IP video security solution that provides management of video, audio and other data across an IP network. The video management system is designed to work with various ONVIF compliant 3rd party products. Video from other sites may be viewed from single or numerous workstations simultaneously at any time. 
2. The video management system can be deployed on a single PC for small or medium system applications or on separate interconnected PCs and servers to meet large systems requirements.
3. The server part of VMS compatible with Linux and Windows OS (64-bit). Though recommended OS for server part is Ubuntu 18.04, 20.04 versions.
4. The server part compatible with ARM, Intel and AMD CPUs.
5. The server part fully docker container-based.
6. The client part compatible with Linux, Windows and MacOS operating systems.
7. There is web-based client. Supported browsers are Chrome, Edge, Firefox, Safari.
8. Client part also has desktop Windows, Linux and MacOS applications.
9. The VMS support cameras compliant to ONVIF Profile S. It is possible to scan the network for ONVIF cameras.
10. It is possible to provide basic configuration of ONVIF cameras from within the VMS, such as general camera settings, recording profiles, audio profiles.
11. It is possible to access camera’s web interface from the link in the VMS.
12. It is possible to use the events provided by an ONVIF camera to trigger events and alarms in the Video Management System.
13. It is possible for operator to control PTZ camera using virtual joystick.
14. It is possible to record ONVIF compliant cameras.
15. It is possible to display ONVIF compliant cameras in live view on a monitor connected to a PC.
16. It is possible to connect cameras or other video sources via RTSP stream to VMS.
17. It is possible to live view and record cameras connected via RTSP.
18. The VMS is designed to use a facility’s existing IT infrastructure.
19. The VMS is capable to be deployed in Local Area Networks (LAN) as well as in Wide Area Networks (WAN).
20. The VMS allows an operator to control and view live and playback streams of cameras and receive alarms from a remote site (across WAN).
21. The VMS is capable to be deployed in the cloud environment (containers, VMs).
22. The VMS allows to view transcoded video streams (live and playback).
23. Live video and archive is played via HLS (HTTP Live Streaming) protocol.
24. The VMS shall allow the establishment of user groups that have access rights to specific cameras, layouts, camera settings, storage settings, system settings.
25. The VMS supports export of the video and frame in the avi, mp4 and jpeg formats to a local or network drive.
26. The VMS is designed in such a way that configuration changes to any part of the system will not interrupt operational tasks.
27. The video management system supports enabling an encrypted communication between the server and client workstation.
28. The server part provides management, monitoring, and control of the entire system. The server part maintains stream management, alarm management, central configuration and user management.
29. The client part provides the user interface for system monitoring and operation. The client workstation maintains live monitoring, storage retrieval, and alarm handling.
30. The video management system supports display of alarms in a special alarm panel.
31. The video management system provides the capability to allow alarms to be filtered by type of the alarm, camera and time.
32. The video management system allows to send an e-mail message in response to an alarm.
33. The video management system allows to send messages to Telegram in response to an alarm.
34. The video management system allows to send messages in the alarm panel, to an email address and Telegram in case of camera disconnection.
35. The video management system supports API that allows for fetching live video streams and archive from 3rd party applications.
36. The video management system provides the user of the client workstation with an option to select the video stream offered by a camera. For cameras configured to use two or more different streams for live view and for recording, operator shall be able to manually switch between the higher resolution stream and the lower resolution stream for a particular camera.
37. The video management system provides the user of the client workstation with an option to enable an automatic switching between a high and a low-resolution stream. The video management system automatically switches to a low-resolution stream, if the user of the client workstation opens multiple cameras on a monitor. The video management system automatically switches to a high-resolution stream, when the user maximizes a camera on the monitor.
38. The video management system support PTZ control with a dedicated graphical (virtual) joystick control, supporting Pan, Tilt, Zoom and Focus commands. For PTZ cameras, the cursor shall change to indicate the Pan/Tilt direction when hovering over the corresponding image pane. The Pan/Tilt speed shall increase as the cursor moves farther from the center of the virtual joystick. An additional control command near the Pan/Tilt command of the joystick shall be used for zoom-in/zoom-out control.
39. The video management system shall support digital zoom of any image pane. The mouse wheel shall control digital zoom when the mouse cursor is hovering over a selected image pane.
40. The video management system provides an instant playback function. Instant playback supports pause, play forward, play reverse, single step forward, single step reverse, fast-forward.
41. The video management system shall support a timeline that provides a graphical overview of video stored on the disk for particular camera. The timeline shall display a timescale that can be adjusted.
42. The video management system supports object storage as an option for storing video footage.
Video analytics
43. The video management system provides an integration with a server-based analytics platform.
44. The video analytic processing able to scale seamlessly by adding servers.
45. The system should allow the use of a pool of video analytic algorithm on any camera. It should be easy to change an algorithm from a camera to another.
46. The video analytic processing should be able to run on top of a server or to be virtualized using virtualization technologies.
47.The system can offer the following video analytic:
- Object Detection - identifies people, cars, busses, trucks, motorcycles and animals in a defined area/zone.
- Face recognition – an algorithm for human identification and verification, based on the facial recognition as well as the age and gender estimation. The algorithm creates a database of all faces captured by video cameras and lets you search the database for similar faces.
- License plate recognition - an algorithm for license plate recognition. Video streams can be processed to search for and recognize license plate numbers in the frame. These license plate numbers are saved to a database and associated with the relevant recorded video. The database is searchable. License plate numbers can be compared to lists in real time, with actions performed (or not performed) depending on whether or not a license plate is found in the list. Aside from license plates, system can recognize the make, model, and color of vehicle, as well as the country and direction of movement of the car.
- Traffic Analytics - intended for the calculation of intensity and determination of traffic structure classify the types of vehicles (car, bus, truck, bicycle, motorbike). It also counts people and provides statistical report with graphs and pies by hours, days, weeks, months.
- Crowd Detection - estimates the number of people within a given area in real time and triggers an alarm when a specified number of people (capacity) or a specified percentage of people (occupancy) is reached.
- Hard Hat Detection - detects people not wearing helmets, records video and sends alarms.
- Heat Map - color visual representation of data analysis of customer activity presented by color visual representation of data (warm and cold zones).
- Age & Gender Detection - determines the gender of customers and their approximate age by detecting and analyzing the faces of visitors.
- Motion Detection - captures any movement in the scene. The following rules can be applied: line crossing, loitering, intrusion, abandoned object, disappearance of an object.
- Smoke & Fire Detection - recognizes smoke and fire in the image.
- Smart Tracking System - search people by attributes (color of clothes, bag, hair, hat, gender, and age).
- Body Movement Detection - identifies a person in different positions: sitting, standing, walking, lying, getting up.
- Wagon Identification - detection and recognition of wagon UIC numbers.
- Smart Parking - management of parking lot, detection of license plates of entering vehicles, recognition of model, direction of movement, and payment status of the car.
48.It is possible to setup several “lists” in the database of the analytics platform. A list contains License plates or faces and related data.
49. The analytics platform detects license plates or faces in the live stream provided by the cameras and shall match them against the license plates and faces stored in data-base of the analytics platform
50. When there is a match, an event should be sent by the system to the video management system. Additional data such as the camera and the time of detection should be included in the event provided to the video management system.
51. When the event provided by the analytics platform triggers an alarm in the video management system, the following content shall appear in the alarm panel of the VMS:
- A cropped extract of the original image.
- The corresponding face or license plate taken from the database of the analytics platform to allow the operator to compare the captured image with the reference image from data-base
- Additional data related to the face or license plate stored in the data-base of the analytics platform (e.g. name of person etc.)
52. All events and meta-data are displayed in the archive on a timeline of corresponding camera of the video management system as an icon. If pointing the mouse arrow at this icon, a frame with the image of an object that triggered an alarm should appear.
53. System should support own AI-based embedded human and vehicle motion detection algorithm.
User interface elements
54. Video frame elements:
- Should be able to switch from live video mode to archive mode. If video camera is being recorded switch button should appear as an activate. If not being recorded it should be in inactive status without possibility to click on it.
- Should have button allowing instantly jump back to archive for a predefined number of seconds.
- Should be a possibility to pause live video upon request and restart it by clicking on play button.
- Should have date and time indicator, that allows to access archive at specified date and time.
- Should have object counter element indicating number of detected objects of specific type.
- Should have sound volume bar allowing to control sound from the camera with built-in microphone.
- Should contain video analytics icon allowing to activate embedded AI-based motion detection analytics.
- While clicking on video analytics “ai” icon, settings should be activated allowing to pre-configure embedded AI-based human and vehicle motion detection analytics.
- In the pre-configurable settings, it should be possible to set the following parameters: enable video analytics button, sensitivity option in percentage, view zone button, send to alarm panel button, detections frequency in seconds, delay between detection in seconds, object type selection option.
- If embedded human and vehicle motion detection analytics enabled the “ai” icon should turn green. When disabled it should be of a white color.
- Stream management icon allowing to choose from lower and higher resolution video stream as well as allowing the system to perform automatic stream selection.
- Google maps activation icon. If activated it partially overlays on the live video frame with the option to fully overlay on it indicating camera positioning on the map.
- It should be possible to reload the video stream by clicking on a dedicated icon.
- In the archive mode it should be possible to increase the video playback speed x2, x4, x8.
- Video or frame can be exported by clicking on dedicated icons. Video can be exported in mp4 or avi formats. Frame can be exported in jpeg format.
- It should be possible to expand and narrow down the archive timeline by scrolling the mouse wheel while pointing on a timeline or by clicking on the plus and minus buttons.
55. Upper menu panel:
- All created layouts should appear in the menu panel. Each of them should have unique name.
- All layouts displayed in the menu panel should be editable right from the panel.
- It should be possible to move layouts by holding the mouse cursor and dragging them left and right.
- I should be possible to hide upper menu panel by clicking on dedicated icon in a such way that it appears whenever user point mouse cursor back at the same area.
- There should be an icon on menu panel that allows to work in tutorial mode. Once activated is should be possible to point by mouse cursor at any user interface element and receive short explanation what is this element created for.
- There should be possibility to access expandable main menu from upper menu panel.
- There should be an alarm indicator that changes the color and creates sound whenever alarm is triggered.
56. Alarm panel:
- There should be a possibility to expand alarm panel by clicking on dedicated icon in the upper panel menu.
- Alarm panel should have an option to filter events by: type of event, cameras and time of the event.
- Each video analytics event should contain the following minimum information: frame (picture of the object), type of the analytics, camera, object type, and time and date of triggering.
- If alarm is triggered by face recognition or license plate recognition analytics event may also contain the name of the person from the list.
- There should be “apply” button to filter events and “reset” button to return to default status.
- The latest triggered event should appear in the top of the list.
- Alarm panel should have chat field so different users of the system could communicate through this chat.
57. Layout settings:
- Layout configuration should be accessible from either by editing existing layouts or by accessing expandable main menu.
- Layout settings should consist of: layout name field, layout templates, camera list, groups of cameras and save and cancel buttons.
- System should have the following layout templates: 1 camera, 4 cameras, 9 cameras, 16 cameras, 25 cameras, 36 cameras, all cameras.
- System should allow to add camera by drag and drop method to one of the chosen layouts using mouse cursor.
- System should allow to drag and drop individual camera or the whole group.
- Once layout created it should be possible to change position of live streaming cameras by drag and drop method without accessing layout settings.
Camera settings  
58. Camera settings should consist of the following elements: name of the server, camera groups, individual cameras, manual camera adding option, adding group of cameras option, option to bind two or more servers, automatic camera search option.
59. Individual camera setting should consist of the following elements:
- Unique camera number field.
- Device name field.
- Camera ID.
- Camera group field.
- Recording schedule field.
- Camera type field.
- If camera being added through RTSP then RTSP URL field followed by login and password fields.
- Receive event check box for events from integrated cameras.
- Generate RTSP checkbox to create RTSP link.
- PTZ checkbox for cameras added through ONVIF or native protocols.
- Option to reset settings.
- Frame showing camera live stream.
- Option to set camera location on the google map.
- Coordinates filed allowing to set camera on the google map by entering precise coordinates of the location.
60. Manual camera adding option should consist of the following fields: device name, camera type, IP and port fields if camera being added through ONVIF, RTSP URL if camera being added through RTSP, login and password fields.
61.Adding group of cameras setting should consist of add group field and add button.
62. Bind server setting should consist of the following fields: server name, domain or IP address of the server, port, login and password.
63. It should be possible to bind 2 or more servers in the local network or with public IP.
64. It should be possible to bind 2 or more remotely distributed servers each of which is in their own local network using cloud link feature. It should be possible to manage local storage, access camera’s archive, create layouts and receive alarms from all of those binded local servers by 1 or more remote operators.
65.Automatic camera search setting should consist of the following fields: range of IP addresses field, list of discovered cameras including IP address of the camera, camera name field, login, password and ping information in milliseconds, add all devices and refresh the search buttons.
Storage settings  
66. Storage setting should consist of the following elements: server name and hard drive discs.
67. Hard drive disk should have the following settings and fields:
- On and off buttons that activate storage.
- Individual camera storage settings section.
- Checkbox allowing to select individual camera.
- Camera unique umber.
- Camera name.
- Archive depths in days field.
- Recording quality drop down field.
- Recording logics drop down field allowing to select the following options: full time recording, scheduled recording or recording by triggered alarm.
- Storage bulk configuration section.
- General storage limit for the selected hard drive in Gb.
- Pre-recording and post-recording fields in seconds.
- Storage capacity bar indicating used space and free space on a hard drive.
Analytics settings  
68. Analytics settings should consist of the following elements: server settings, notifications, alarms via emails.
69. Server settings should consist of the following fields:
- Video analytics server URL or IP address.
- Video analytics server authorization API token.
- Option to store metadata in days.
70. Notifications settings should consist of the following fields:
- Send email upon event occurrence with ability to enable and disable this option with the dedicated buttons.
- Send event to Telegram messenger upon event occurrence including fields for Telegram bot API token and Telegram chat ID with ability to enable and disable this option with the dedicated buttons.
- Send notification when camera connection is lost with checkboxes that allow to select where to send. There should be 3 options available: email, Telegram and alarm panel.
71. Alarm via email settings should be available for events from integrated cameras’ edge analytics and should consist of the following fields:
- Buttons to enable or disable receiving alarms form the camera.
- Fields to enter: email address, password, IMAP host and IMAP port.
License settings 
72. License settings should consist of two statuses: before the license has been activated and after activation status.
73. License activation status should consist of the following fields:
- Customer email.
- Customer name.
- Number of required camera licenses.
- Type of license allowing to choose temporary or permanent license.
- Send license request button.
- Buttons allowing to upload activation file and activate licenses.
74. After licenses were activated license setting should contain the following information:
- License type: permanent or temporary.
- Customer email address.
- Customer name.
- Number of activated licenses.
- License status.
Users settings 
75.Users settings menu should consist of created users and roles assigned to the users, option to add new user and option to add new role.
76. By default, there should be admin role and admin user created.
77. For admin user fields to change user name and user role should be disabled. User name should always remain as admin and user role should always remain as Admin.
78. Add new user setting should consist of the following elements:
- Username filed.
- Password field.
- Dropdown menu to select a role.
- Checkboxes showing cameras that are allowed to be controlled by the user.
- Checkboxes showing current permissions set for the user: camera settings, storage settings, system settings, user settings, layout settings, analytics settings, camera archive access, exporting and alarm notifications.
- Buttons that are enabled or disabled depending on set permissions for the user: archive status, access to microphones, access to reports.
79. Add new role setting should consist of the following elements:
- Role name filed.
- Checkboxes allowing to select cameras to be controlled by the user by this specific role.
- Checkboxes setting the following permissions for this specific role: camera settings, storage settings, system settings, user settings, layout settings, analytics settings, camera archive access, exporting and alarm notifications.
- Buttons that should enabled or disabled the following permissions for the user: archive status, access to microphones, access to reports.
General settings  
80. General settings menu should consist of the following settings: video stream, user interface, recording schedules, system information, cloud link, demo mode.
81. Video stream settings should have possibility to set live stream and archive chunk size in seconds.
82. There should be a possibility to enable and disable pulling both camera streams (lower and higher resolution) at the same time.
83. User interface settings should allow to enable and disable automatic page reload after predefined number of seconds.
84. Recording schedules setting should allow to set day of the week and time to schedule the recording of video in the archive. Possibility to create schedule should be easy and intuitive by double clicking on the schedule indicator and dragging the bar from side to side by holding mouse cursor. It also should include list of created scheduled in the drop-down menu.
85. System information setting should include the following parameters: CPU load, RAM load, UI version and server version.
86. Cloud link setting should allow to create tunnel between the server of the user and client machine of the user that connects to the server. By enabling cloud link system should generate URL that should allow the user without any additional VPN or public IP on a server side to connect to the server using his access credentials from any location. Server and client should have internet access.
87.Demo mode setting should allow to enable four video clips that can be used as virtual cameras.
Localization settings
88. Localization setting should contain list of languages with checkboxes. Once user chooses preferred language user interface language should instantly change to the chosen language.