1 Introduction

1.1 Introduction

SAFR Email Sender provides a solution to send customized rich text email notifications triggered from SAFR Events. Email templates are highly customizable, and conditions can be specified to generate event notifications for different conditions such as id class (threat, concern, stranger), person type or many other event attributes.

This guide describes how to install and configure SAFR Email Sender. For SAFR documentation please visit http://docs.real.com.

1.2 Downloads

Download the following files required by SAFR – Genetec API Integration.

1.3 Requirements

Email sender requires a single factor authentication email account using username and password authentication. Many email services require specific configuration to allow this mode. This guide provides guidance for how to enable single factor authentication for some email services.

This guide assumes you have SAFR Software installed and configured and you are familiar with how to generate watchlist alarms through SAFR Actions. For more information about SAFR and SAFR Actions, see http://docs.real.com.

1.4 Overview

SAFR Email Sender is triggered by SAFR Actions. Email is created using a template defined in the configuration file. Pre-defined templates are available, or a custom template can be created. The template defines the layout and content of the email message. Tokens inside the template allow for dynamic content that is passed from the SAFR event. Dynamic information can include recognized person name, picture or other data such as location and person properties.

Notifications can be customized based on the type of event. For example, stranger alerts can go to one group and threat alerts can be sent to a different group. The content of the email can be varied for each, containing different information or layout.

2 Email Templates

2.1 Email Templates

Email templates allow the message layout and content to be specified. The following pre-made templates are available or custom templates can be created.

Notification

Visitor

A screenshot of a computer

AI-generated content may be incorrect.

A screenshot of a person wearing a mask

AI-generated content may be incorrect.

2.2 Creating Custom Email Templates

The two included email templates can be used without making any customizations. This section descrxibes how to create your own email templates if desired.

Email templates are generated using JinJa templating engine. This section will describe how to create the most common email elements. More advanced template syntax rules can be found in the following link.

2.2.1 Including event attributes

To include an event attribute in the email, include one of the known attribute names into double curly braces as in following example:

Person Name: {{ personName }}

Leading or trailing spaces are ignored. So {{personName}} is the same as {{ personName }}. The end result will have the persons full name "John Doe" inserted into the email at the desired location. The token may be inserted at any place within the email template.

2.2.2 Conditional elements

You can include or omit a portion of the email depending on the value of one of the event attributes. For example, the following will include a row in the output for person name, only if event includes such a field.

{% if personName %}
<li>Name : {{personName}}</li>
{% endif %}

The first line checks if the event has a personName attribute and if that attribute has a value. If so, then the next line is included in the output, where {{personName}} is replaced with the actual name as described in previous section. Everything between the {% if %} and {% endif %} is inserted into the email if the condition is true. But the 1st and last lines are not themselves included in the output.

2.2.3 Inserting Images

One of three possible images can be inserted into the email for each event.

  • reference_image - Face image for enrolled person
  • detected_image - Event face image (just the face cropped from the video frame)
  • scene_image - Event scene image (full frame of video)
  • logo - Image specified in email_logo_file of configuration file

Each of the images are attached to the email and then can be inserted into the body of the email as shown below:

<img src="cid:reference_image" width="240" style="display:block;width:100%;max-width:240px">

The image is identified with the following:

cid:NAME

where NAME is either reference_image, detected_image or scene_image.

3 SAFR Configuration

3.1 Install Files

  1. Place following files in C:\Program Files\RealNetworks\SAFR\scripts
  • email_sender.exe
  • email_sender.config
  • templates (unpack templates.zip and ensure folder is named 'templates' with the html files in this folder)

Your unpacked structure should look like this:

A screenshot of a computer

AI-generated content may be incorrect.

  1. Edit email_sender.config. Set the SAFR Account credentials and any other properties you wish the customize. See comments in configuration file for instructions.

3.2 SAFR Actions

SAFR Actions should be set as following for the script best performance.

A screenshot of a computer

AI-generated content may be incorrect.

Here is the SAFR Actions action command

scripts\email_sender.exe -i "#I" -s "#S" -e "#v" -t "#s" -p "#D" -S "#l" -T "#t" -pfn "#" -pln "#U" -pn "#N" -pa "#A" -pg "#G" -ps "#M" -id "#a" -pt "#T" -at "#C" -aid "#c" -pp "#p" -pe "#e" -hl "#H" -pm "#m" -po "#O" -g "#g" -r "recipient_email_addresses" -et "email_template"

Only the last 2 options can be customized. Remaining options can be used in template. The table below describes the all options and provides the token that can be added to the template in order to insert its value.

Command Option

Value

Template Token

Description

-i

#I

site

Site value assigned to the SAFR feed where detection occurred.

-s

#S

source

Source value assigned to the SAFR feed where detection occurred.

-e

#v

eventId

SAFR Event ID

-t

#s

eventTime

SAFR Event start time

-p

#D

personId

SAFR Person ID

-S

#l

similarityScore

SAFR Similarity Score

-T

#t

tags

Person Tags for the recognized person

-pfn

#F

personFirstName

Person First Name

-pln

#U

personLastName

Person Last Name

-pn

#N

personName

Person Name

-pa

#A

age

age (###)

-pg

#G

gender

gender

-ps

#M

sentiment

sentiment avgSentiment (#.##)

-id

#a

idClass

idClass Values of Threat, Concern, No-Concern

-pt

#T

personType

person type

-at

#C

actionType

action type

-aid

#c

actionId

action id

-pp

#p

phone

Person phone

-pe

#e

email

Person email

-hl

#H

homeLocation

home location

-pm

#m

moniker

moniker

-po

#O

organization

Organization

-g

#g

groups

groups (comma separate list of groups)

N/A

N/A

emailTitle

Value of email_title from configuration file. Maybe be augmented with name, ID class and Person type if email_title_attribute is True.

N/A

N/A

personNotes

Notes from person record. (this may be up to 1000 characters).

N/A

N/A

personAddDate

Date person record was created.

N/A

N/A

personAddSite

Site (camera or workstation) where person was added.

N/A

N/A

personAddSource

Source (camera or workstation) where person was added.

N/A

N/A

siteUrl

Value of email_site_url from configuration file.

N/A

NA

footerText

Value of email_footer_text from configuration file

-re

See note

Comma separated list of email addresses. This will override the default email recipients specified in the configuration file. If excluded or "recipient_email_addresses", email addresses from configuration file will be used.

-et

See note

Email template. This will override the default email template specified in the configuration file. If excluded or "email_template", template from configuration file will be used.

Available templates are:

  • notification-template.html
  • visitor-template.html

Custom templates can be created as described above. Custom templates should be placed in the 'templates' folder in same directory as application.

4 Application Behavior

Application will create following two directories in the same directory where the executable is located:

  • logs - stores log files. Logs are rolled daily. No automatic log removal is performed. Customer should take this action though logs are typically very small and should not take significant disk space.
  • people - stores cache of recent persons to allow suppression of repeat emails within configurable time. This directory should be cleaned up occasionally (automated or manually). Anything older than the suppression duration can be deleted safely.

5 Testing

Test the script using a sample command line. You will need a valid event and person Id. You can get these from an existing event (Right click and chose "copy event details" and paste this into a text file.

python scripts\EmailSender2.py -i "My Site" -s "My Camera Name" -e "EVENT_ID" -t "1741568807413" -p "PERSON_ID" -S "1.1831" -T "tag1, tag2" -pfn "John" -pln "Doe" -pn "John Doe" -pa "34" -pg "male" -ps "0.16" -id "concern" -pt "shoplifter" -at "" -aid "" -pp "" -pe "" -hl "Barton Store" -pm "" -po "" -g "region2,region3" -r "manager@acme.com" -et "notification-template.html"

  • Get EVENT_ID and PERSON_ID from SAFR Actions log file located in C:\ProgramData\RealNetworks\SAFR\ares\logs\ares.log.They will be 32 character strings with hypens like this: 9049ff81-1f3d-46f5-a5e6-2a87bfe52793.

6 Troubleshooting

See Troubleshooting section in "Running a Script with SAFR Actions" in Common > Actions under http://docs.real.com

1