Skip to main content

Shinobi Video Surveillance

Furano, Japan

Shinobi is Open Source, written in Node.js, and real easy to use. It is the future of CCTV and NVR for developers and end-users alike. It is catered to by professionals and most importantly by the one who created it.

Shinobi CCTV

Shinobi Installation

Amendment:

Please note that Node.js 8 or 9 must be present on your system before installation.

If Node.js 8/9 is missing, it will be installed by the installation script, but the installation of FFMPEG will fail and the program will not start at the end.

If this happens to you, you can reinstall FFMPEG via npm. Go to the installation directory of Shinobi cd /home/Shinobi and start the installation via npm install ffmpeg. After that you should be able to start Shinobi via PM2 pm2 restart all, pm2 list.

The easiest way to install, directly on metal, is through git. The following operating systems are supported:

  • Ubuntu 17.10.1
  • CentOS 7
  • MacOS 10.7(+)

Become root to use the installer and run Shinobi. Use one of the following to do so.

Ubuntu 17.10.1:

sudo su

CentOS 7:

su

MacOS 10.7(+):

su

Download and run the installer:

bash <(curl -s https://gitlab.com/Shinobi-Systems/Shinobi-Installer/raw/master/shinobi-install.sh)

Shinobi CCTV

Changing the WebUI Port:

By default the Shinobi WebUI uses the port 8080. Due to a port conflict we were forced to change that port to 8888. The following tutorial will keep referring to the default port - but all screenshots will show the changed port.

OPTIONAL: In case you need to change the port as well, this can be done in the software installation directory (default: /home/Shinobi) by editing both the conf.json and conf.sample.json file:

Shinobi CCTV

Shinobi Configuration

Create a Shinobi user by accessing http://<IP Address>:8080/super and login with:

user: admin@shinobi.video
password: admin

Shinobi CCTV

Click on Add User and create a default user for your Shinobi installation:

Shinobi CCTV

You can now switch to http://<IP Address>:8080/ and login with the default user you just created:

Shinobi CCTV

Adding an INSTAR Full HD Camera

Shinobi CCTV

We can start using Shinobi by clicking on the + Symbol in the top left and adding an ID and a readable Name for the camera we want to add in the Identity section. It is important to choose the Watch Only mode if you want to use the integrated Motion Detection:

Shinobi CCTV

For the Connection part we need to choose h.264 and the Video (RTSP) Path for our camera model (Note: that we are choosing the 11 path that represents the full resolution for INSTAR cameras. If you are experiencing issues - like a stuttering video stream or high CPU loads - you can switch to 12 or 13 instead to set a lower resolution):

rtsp://<Camera IP Address>/11

Shinobi CCTV

Now close the configuration menu to save your settings. Open the side menu by clicking on the hamburger icon in the top left and click on the camera you just added. The video stream should show up in a floating viewport on the right (might take a few seconds - if it takes too long, consider using a smaller RTSP stream as stated above):

Shinobi CCTV

Setting up Motion Detection for your INSTAR IP Camera

Now click on the Wrench Button to get back to the configuration menu and switch the menu to Advanced Mode at the bottom of the floating window:

Shinobi CCTV

The menu will now offer a couple of additional configuration option - a couple of the relate to alarm features:

Shinobi CCTV

  • Global Detector Settings: It is best to leave everything at it's default values - you can come back to it later to add some performance fine tuning here.
  • No Motion Detector: An interesting feature is the inverted motion detection - do you want to make sure that your machine is working at all time? Set up Shinobi to notify you when it stopped.
  • Audio Detector: Our RTSP stream contains both the video as well as the audio stream from our camera. Use the audio to trigger a recording in Shinobi.
  • Object Detection: This function requires the additional installation of OpenCV and is out of the scope of this tutorial.

And last but not least, we have the classic Motion Detection:

Shinobi CCTV

Correction: the screenshot above set's the Recording Timeout to 5min - it is much more sensible to choose a value of 0.2, resulting in 12s alarm videos.

Here, again, we will leave most at the default settings and move on the Region Editor that allows us to define Motion Detection Areas that will be used to limit the area that will be watched by the detection algorithm:

Shinobi CCTV

Klick on the green + Button to add an area - the new area will be displayed in the top left corner of the camera video image. You can drag&drop each of the white anchor points to reposition them. Or click on the red line to add a new anchor (a right-click deletes a point). Klick on Close to save your settings.

When you scroll further down the config menu you will reach the rest of the motion detection settings - again, we will leave most of them at their default settings for now (to be further fine-tuned later on):

Shinobi CCTV

Close the configuration menu now and walk in front of your camera to trigger a few alarm recordings. The Shinobi offers a couple of ways to view our alarm videos:

  • Event Log
  • Video Grid
  • Video List
  • Time Lapse Recordings
  • Power Viewer

We are going to show you the Power Viewer as seen in the screenshots below. Click on the button marked with the red arrow:

Shinobi CCTV

The Power Viewer will show you a timeline of all alarm recording events - the higher the red bars, the more motion was detected inside the video. Clicking on a bar in the timeline opens the recorded video.

Shinobi CCTV

Default Motion Detection Settings

Global Detector Settings Primary Engine : Pixel Array


Detector SettingsRecommended OptionDescription
EnabledYesEnable to reveal and use the other options.
Send FramesYesPush frames to the connected plugin to be analyzed.
Allow Next Trigger2000The amount of milliseconds that needs to pass before allowing the next event registration.
Save Events to SQLYesSave Motion Events in SQL. This will allow display of events over video during the time events occurred in the Power Video Viewer.
Detector Rate2How many frames per second to send to the motion detector.
Feed-In Image Width640Width of the image being detected. Smaller sizes take less CPU.
Feed-In Image Height480Height of the image being detected. Smaller sizes take less CPU.
How to RecordTraditionalThere are multiple methods to record. Read below on why that is.
Trigger RecordYesWhen enabled it will give the command to start the recording process.
Recording FPS Change on StartLeave blank for no change - when you are using a low frame rate in your live video, use this option to increase the frame rate everytime when an alarm recording is running.
Recording Timeout0.2The amount of time, in minutes, that the video will record for.


Motion Detection Primary Engine : Pixel Array


Motion Detection SettingsRecommended OptionDescription
Use Built-InYesUse Kevin Godell's Motion Detector. This is built into Shinobi and requires no other configuration to activate.
Indifference1When using Kevin's Detector Indifference means "minimum percentage changed in region". This option varies based on camera, start with 1 and work your way up.
Max Indifference (leave blank until comfortable with minimum first)As the name suggests it is a max value for Indifference.
Trigger Threshold1Minimum number of detections to fire a motion event. Detections. Default is 1. Don't adjust it until tuning begins.
Color Threshold9The amount of difference allowed in a pixel before it is considered motion. Default is 9.
Full Frame DetectionNoEnabling Full Frame Detection will create a region that covers the entire frame. Only enable this if you aren't using regions made in the Region Editor.
Noise FilterNoRemove false detections due to "noisy backgrounds"
Noise Filter Range6


Traditional Recording


Traditional Recording SettingsRecommended OptionDescription
Video EncoderAutoThe video writer. Shinobi will try to choose the best option for you when selecting Auto. For Manual Selection :  RTSP cameras will generally take copy. MJPEG cameras will take libx264.
Audio EncoderNo AudioRTSP cameras will generally use aac. MJPEG cameras must be set to No Audio. 
Segment Length2Set this to 2 for a buffer of ~5 seconds.