Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Table of Contents
maxLevel1

About This Guide

This guide describes how to configure and use the FREEDOM PRIMIS API software.

Topics in this guide are intended for security system integrators and security administrators responsible for setting up IP-based physical access security control systems.

Additional Documentation

To find documentation available for all products, go to https://www.identiv.com/viscount/.  

Getting Started

Introduction

The Freedom Primis API provides the RESTful Web Services for the Freedom Primis Access Control System. The Freedom Primis API calls described in this document required HTTP BASIC authentication. The same login credentials that can access the Freedom Primis software are used for API authentication. You can add/remove logins by navigating to the “Admin Users” section of the Freedom Primis software. The default user that comes with the system is: 

Username: freedom primis 

Password: viscountidentiv

The Freedom Primis API Web Services can be configured to support https. Please contact support for additional details.

Users

This chapter describes how to create/retrieve/update/delete Users through the FREEDOM PRIMIS API software.

user elements:

Element Name

Type

Description

Comments

id

string max 200 characters

Unique identifier for a User

Optional; On POST, server generates an ID

first_name

string max 50 characters

First name of the User

Optional

last_name

string max 50 characters

Last name of the User

Required

access_start_date

date(yyyymmdd)

Date for when the User will be active (enabled)

Optional; Uses the API server’s current date if empty

access_end_date

date(yyyymmdd)

Date for when the User will be inactive (disabled)

Optional

pin

integer

The User’s PIN

Optional; This PIN is used with Wiegand Keypads and should not be confused with a PIV card’s PIN.

email

string max 100 characters

Email address of the User

Optional

phone

string max 50 characters

Phone number of the User

Optional

created_at

datetime

Create timestamp

This element is searchable by using query parameter created_since. for example: created_since=20170615130130 will return all users created after 2017-06-15 13:01:30

updated_at

datetime

Update timestamp

This element is searchable by using query parameter updated_since. for example: updated_since=20170615130130 will return all users updated after 2017-06-15 13:01:30

disabled

boolean(true/false)

Indicates whether a User is disabled

Optional; User is enabled if empty (false).

credential

child element

Credential of the User

Optional; only supported in POST and GET method. Refer to

 

 

section 0 CHAPTER 3  Credentials for details.

cards

child element

The Card(s) belong to the User

Optional; only supported in POST and GET method

 

card_number

string max 100 characters

Unique identifier for a Card

Required

access_group

child element

The Access Group(s) that the User belongs to

Optional; only supported in POST and GET method

 

id

string maximum 36 characters

Unique identifier for an Access Group

Required

name

string max 200 characters

The name of the Access Group

Required

site_id

string maximum 36 characters

The ID of the Site that the Access Group belongs to

Optional; on POST, default to 1 if it is not set

custom_field_items

child element

 

Not used; Only supported in GET

method

image

child element

The image(s) of the User

Optional; Only supported in GET method

 

id

string maximum 36 characters

Unique identifier for the Image

 

filename

string max 255 characters

The filename the image

 

url

string

The url for the image

 

category

integer

The category of the image

 

content_type

string

The content type of the image

 

created_at

datetime

The created date of the image record

 

Add a new user

POST    /api/users

http://<ip address>:<api listening port>/api/users

...

Code Block
languagexml
<user>
  <id />
  <first_name>Test E. Cardholder IV - PIV</first_name>
  <last_name>Test</last_name>
  <access_start_date />
  <access_end_date>20301231</access_end_date>
  <pin type="integer" />
  <email />
  <phone />
  <disabled type="boolean" />
  <access_groups>
    <access_group>
      <id>82</id>
      <name>Engineering 1b</name>
    </access_group>
    <access_group>
      <id>84</id>
      <name>Manager</name>
    </access_group>
    <access_group>
      <id>83</id>
      <name>Production 1</name>
    </access_group>
    </access_groups>
  <credential>
    <type>PIV-II</type>
    <fascn_hex>D650185B3CCE6D9C9053CDA16CDA10AA09C4378486501843EB</fascn_hex>
    <expiration_date>20301231</expiration_date>
    <card_auth_key />
    <guid>00000000000000000000000000000000</guid>
  </credential>
</user>

List all users

GET     /api/users 

http://<ip address>:<api listening port>/api/users

...

Code Block
languagexml
<users>
   <user>
      <id>252</id>
      <first_name>Test E. Cardholder IV - PIV</first_name>
      <last_name>Test</last_name>
      <access_start_date />
      <access_end_date>20301231</access_end_date>
      <pin type="integer" />
      <email />
      <phone />
      <created_at>2013-08-22T10:06:52.000-07:00</created_at>
      <updated_at>2013-08-22T10:06:52.000-07:00</updated_at>
      <disabled type="boolean">false</disabled>
      <credential>
         <id>253</id>
         <fascn_hex>D650185B3CCE6D9C9053CDA16CDA10AA09C4378486501843EB</fascn_hex>
         <type>PIV-II</type>
         <status />
         <expiration_date>20301231</expiration_date>
         <guid>00000000000000000000000000000000</guid>
         <card_auth_key />
      </credential>
      <cards>
         <card_number>32013733334893131152472674132011</card_number>
         <card_number>3201373333489320301231</card_number>
      </cards>
      <access_groups>
         <access_group>
            <id>82</id>
            <name>Engineering 1b</name>
         </access_group>
         <access_group>
            <id>84</id>
            <name>Manager</name>
         </access_group>
         <access_group>
            <id>83</id>
            <name>Production 1</name>
         </access_group>
      </access_groups>
      <custom_field_items />
      <images>
         <image>
            <id type="integer">260</id>
            <filename>252_0.jpg</filename>
            <url>http://192.168.123.101:9000/api/images/view/252_0.jpg</url>
            <category type="integer">0</category>
            <content_type>image/jpeg</content_type>
            <created_at>2013-08-22T11:15:36.000-07:00</created_at>
         </image>
      </images>
   </user>
   <user>
      <id>257</id>
      <first_name>Test Cardholder XIV - PIV</first_name>
      <last_name>Test</last_name>
      <access_start_date />
      <access_end_date>20301231</access_end_date>
      <pin type="integer" />
      <email />
      <phone />
      <created_at>2013-08-22T11:06:39.000-07:00</created_at>
      <updated_at>2013-08-22T11:06:38.000-07:00</updated_at>
      <disabled type="boolean">false</disabled>
      <credential>
         <id>258</id>
         <fascn_hex>D6501858999CED9992049DA16AD9A19C279A844486501843F5</fascn_hex>
         <type>PIV-II</type>
         <status />
         <expiration_date>20301231</expiration_date>
         <guid>00000000000000000000000000000000</guid>
         <card_auth_key />
      </credential>
      <cards>
         <card_number>23100241</card_number>
         <card_number>32014399394149156091935084132011</card_number>
         <card_number>3201439939414920301231</card_number>
         <card_number>834299</card_number>
      </cards>
      <access_groups>
         <access_group>
            <id>82</id>
            <name>Engineering 1b</name>
         </access_group>
      </access_groups>
      <custom_field_items />
      <images />
   </user>
</users>

Search users with filtering criteria

GET     /api/users/search

...

Code Block
languagexml
<users_search>
   <criteria>first_name=Test E. Cardholder IV - PIV,</criteria>
   <users results="1">
      <user>
         <id>252</id>
         <first_name>Test E. Cardholder IV - PIV</first_name>
         <last_name>Test</last_name>
         <access_start_date />
         <access_end_date>20301231</access_end_date>
         <pin type="integer" />
         <email />
         <phone />
         <created_at>2013-08-22T10:06:52.000-07:00</created_at>
         <updated_at>2013-08-22T10:06:52.000-07:00</updated_at>
         <disabled type="boolean">false</disabled>
         <credential>
            <id>253</id>
            <fascn_hex>D650185B3CCE6D9C9053CDA16CDA10AA09C4378486501843EB</fascn_hex>
            <type>PIV-II</type>
            <status />
            <expiration_date>20301231</expiration_date>
            <guid>00000000000000000000000000000000</guid>
            <card_auth_key />
         </credential>
         <cards>
            <card_number>32013733334893131152472674132011</card_number>
            <card_number>3201373333489320301231</card_number>
         </cards>
         <access_groups>
            <access_group>
               <id>82</id>
               <name>Engineering 1b</name>
            </access_group>
            <access_group>
               <id>84</id>
               <name>Manager</name>
            </access_group>
            <access_group>
               <id>83</id>
               <name>Production 1</name>
            </access_group>
         </access_groups>
         <custom_field_items />
         <images>
            <image>
               <id type="integer">260</id>
               <filename>252_0.jpg</filename>
               <url>http://192.168.123.101:9000/api/images/view/252_0.jpg</url>
               <category type="integer">0</category>
               <content_type>image/jpeg</content_type>
               <created_at>2013-08-22T11:15:36.000-07:00</created_at>
            </image>
         </images>
      </user>
   </users>
</users_search>

Get a user record by user id

GET     /api/users/<user id>                   

...

Code Block
languagexml
<user>
   <id>252</id>
   <first_name>Test E. Cardholder IV - PIV</first_name>
   <last_name>Test</last_name>
   <access_start_date />
   <access_end_date>20301231</access_end_date>
   <pin type="integer" />
   <email />
   <phone />
   <created_at>2013-08-22T10:06:52.000-07:00</created_at>
   <updated_at>2013-08-22T10:06:52.000-07:00</updated_at>
   <disabled type="boolean">false</disabled>
   <credential>
      <id>253</id>
      <fascn_hex>D650185B3CCE6D9C9053CDA16CDA10AA09C4378486501843EB</fascn_hex>
      <type>PIV-II</type>
      <status />
      <expiration_date>20301231</expiration_date>
      <guid>00000000000000000000000000000000</guid>
      <card_auth_key />
   </credential>
   <cards>
      <card_number>32013733334893131152472674132011</card_number>
      <card_number>3201373333489320301231</card_number>
   </cards>
   <access_groups>
      <access_group>
         <id>82</id>
         <name>Engineering 1b</name>
      </access_group>
      <access_group>
         <id>84</id>
         <name>Manager</name>
      </access_group>
      <access_group>
         <id>83</id>
         <name>Production 1</name>
      </access_group>
   </access_groups>
   <custom_field_items />
   <images>
      <image>
         <id type="integer">260</id>
         <filename>252_0.jpg</filename>
         <url>http://192.168.123.101:9000/api/images/view/252_0.jpg</url>
         <category type="integer">0</category>
         <content_type>image/jpeg</content_type>
         <created_at>2013-08-22T11:15:36.000-07:00</created_at>
      </image>
   </images>
</user>

Update a user record by user id

PUT     /api/users/<user id> 

...

Code Block
<user>
   <first_name>Patrick</first_name>
   <last_name>Li</last_name>
   <access_start_date />
   <access_end_date>20301231</access_end_date>
   <pin type="integer" />
   <email />
   <phone />
   <disabled type="boolean" />
</user>

Delete a user record by user id

DELETE  /api/users/<user id>       

...

Response code 204 if successfully deleted or if the user does not exist

...

Credentials

This chapter describes how to retrieve or delete Credentials through the FREEDOM PRIMIS API software.

credential element:

Element Name

Type

Description

Comments

id

string maximum 36 characters

Unique identifier for a Credential

Optional; On POST, server generates an ID

fascn_hex

string maximum 50 characters

FASCN of the PIV Card represented as a hex string

Required

type

Either ‘PIV-I’ or ‘PIV- II’

The type of Credential

Optional

status

-

-

UNUSED

expiration_date

date(yyyymmdd)

Expiration date of the CHUID

Required

guid

string maximum 255 characters

The GUID located within the CHUID

Optional

card_auth_key

-

-

UNUSED

List all credentials

GET     /api/credentials                  

...

Code Block
languagexml
<credentials>
   <credential>
      <id>253</id>
      <fascn_hex>D650185B3CCE6D9C9053CDA16CDA10AA09C4378486501843EB</fascn_hex>
      <type>PIV-II</type>
      <status />
      <expiration_date>20301231</expiration_date>
      <guid>00000000000000000000000000000000</guid>
      <card_auth_key />
   </credential>
   <credential>
      <id>161</id>
      <fascn_hex>D6501858289D6DC4649C25A1685A6D81208E711C86501857EE</fascn_hex>
      <type>PIV-II</type>
      <status />
      <expiration_date>20301231</expiration_date>
      <guid>00000000000000000000000000000000</guid>
      <card_auth_key />
   </credential>
</credentials>

Get a credential record by credential id

GET     /api/credentials/<credential id>              

...

Code Block
languagexml
<credential>
   <id>253</id>
   <fascn_hex>D650185B3CCE6D9C9053CDA16CDA10AA09C4378486501843EB</fascn_hex>
   <type>PIV-II</type>
   <status />
   <expiration_date>20301231</expiration_date>
   <guid>00000000000000000000000000000000</guid>
   <card_auth_key />
</credential>

Get a credential record by the FASC-N

GET     /api/credentials/fascn/<fascn>    

...

Code Block
<credential>
   <id>253</id>
   <fascn_hex>D650185B3CCE6D9C9053CDA16CDA10AA09C4378486501843EB</fascn_hex>
   <type>PIV-II</type>
   <status />
   <expiration_date>20301231</expiration_date>
   <guid>00000000000000000000000000000000</guid>
   <card_auth_key />
</credential>

Delete a credential by credential id

DELETE  /api/credentials/<credential id>

...

Result: 
Response code 204 if successfully deleted or if the credential does not exist.

List all certificates under a credential id

GET     /api/credentials/<credential id>/certificates 

http://<ip address>:<api listening port>/api/credentials/253/certificates

Result:

Code Block
<certificate> 
   <credential_id>253</credential_id> 
   <type>0</type> 
   <not_before>2010-10-01T01:30:00.0000000-07:00</not_before> 
   <not_after>2030-10-01T01:30:00.0000000-07:00</not_after> 
   <validated_at>2013-08-22T00:00:00.0000000-07:00</validated_at> 
   <status>1</status>

<content>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</content>
</certificate>

Certificates

This chapter describes how to create/retrieve/update/delete Certificates through the FREEDOM PRIMIS API software.

certificate element:

Element Name

Type

Description

Comments

id

string maximum 36 characters

Unique identifier for a Certificate

Optional; On POST, server generates an ID

credential_id

string maximum 36 characters

The ID of the Credential that the Certificate belongs to

Required

type

0, 1, 2, 3, or 4

The type of Certificate

Required
0 - CHUID Signer Cert
1 - PIV Auth. Cert
2 - Digital Sig. Cert
3 - Key Mgmt. Cert
4 - Card Auth. Cert

not_before

datetime

The start date and time that the Certificate will be valid

Required

not_after

datetime

The end date and time that the Certificate will be valid

Required

validated_at

datetime

The date and time when the Certificate was validated

Optional

status

0 or 1

Indicates the validity of the Certificate

Required
0 - Invalid
1 - Valid

content

string

The content of the Certificate

Required

serial_number

string, maximum 300 characters

The serial number of the Certificate

 

issuer_name

string, maximum 300 characters

The issuer name of the Certificate

Required

List all Certificates

GET     /api/certificates                  

http://<ip address>:<api listening port>/api/certificates

Result: 

Code Block
<certificates>
   <certificate>
      <id>10</id>
      <credential_id>253</credential_id>
      <type>0</type>
      <not_before>2010-10-01T01:30:00.0000000-07:00</not_before>
      <not_after>2030-10-01T01:30:00.0000000-07:00</not_after>
      <validated_at>2013-08-22T00:00:00.0000000-07:00</validated_at>
      <status>1</status>

<content>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</content>

Code Block
   </certificate> 
   <certificate> 
      <id>17</id> 
      <credential_id>301</credential_id> 
      <type>0</type> 
      <not_before>2010-10-01T01:30:00.0000000-07:00</not_before> 
      <not_after>2030-10-01T01:30:00.0000000-07:00</not_after> 
      <validated_at>2013-08-22T00:00:00.0000000-07:00</validated_at> 
      <status>1</status>

<content>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</content>
</certificate>
</certificates>

Add a new certificate

POST    /api/certificates                  

...

Content-Type: text/xml

Post Data:

Code Block
<certificate>
   <id>10</id>
   <credential_id>253</credential_id>
   <type>0</type>
   <not_before>2010-10-01T01:30:00.0000000-07:00</not_before>
   <not_after>2030-10-01T01:30:00.0000000-07:00</not_after>
   <validated_at>2013-08-22T00:00:00.0000000-07:00</validated_at>
   <status>1</status>

<content>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</content>
</certificate>

Get a certificate by certificate id 

GET     /api/certificates/<certificate id>              

http://<ip address>:<api listening port>/api/certificates/10

Result: 

Code Block
<certificate>
   <id>10</id>
   <credential_id>253</credential_id>
   <type>0</type>
   <not_before>2010-10-01T01:30:00.0000000-07:00</not_before>
   <not_after>2030-10-01T01:30:00.0000000-07:00</not_after>
   <validated_at>2013-08-22T00:00:00.0000000-07:00</validated_at>
   <status>1</status>

<content>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</content>
</certificate>

Update a certificate by certificate id

PUT     /api/certificates/<certificate id>               

http://<ip address>:<api listening port>/api/certificates/10

PUT Data: 

Code Block
<certificate>
   <credential_id>255</credential_id>
   <type>1</type>
   <not_before>2010-10-01T01:30:00.0000000-07:00</not_before>
   <not_after>2030-10-01T01:30:00.0000000-07:00</not_after>
   <validated_at>2013-08-22T00:00:00.0000000-07:00</validated_at>
   <status>0</status>

<content>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</content>
</certificate>

Delete a certificate by the certificate id

DELETE  /api/certificates/<certificate id>              

...

Result: 
Response code 204 if successfully deleted or if the certificate does not exist.

Images 

This chapter describes how to create/retrieve/delete Images through the FREEDOM PRIMIS API software.

Image element:

Element Name

Type

Description

Comments

id

string maximum 36 characters

Unique identifier for an Image

On POST, server generates an ID

user_id

string max 200 characters

The identifier of the user

Required

filename

string max 255 characters

The filename the image

Required

url

string

The url for the image

Supported in GET method.

category

integer

The category of the image

On POST, default to 0

content_type

string, maximum 255 characters

The content type of the image

Required

created_at

datetime

The created date of the image record

 

List all images 

GET /api/images 

http://<ip address>:<api listening port>/api/images 

...

Code Block
languagexml
<images>
    <image>
        <id type="integer">172</id>
        <user_id>170</user_id>
        <filename>170_0.jpg</filename>
        <url>http://192.168.123.101:9000/api/images/view/170_0.jpg</url>
        <category type="integer">0</category>
        <content_type>image/jpeg</content_type>
        <created_at>2014-10-17T13:46:33.143-07:00</created_at>
    </image>
    <image>
        <id type="integer">85</id>
        <user_id>83</user_id>
        <filename>83_0.jpg</filename>
        <url>http://192.168.123.101:9000/api/images/view/83_0.jpg</url>
        <category type="integer">0</category>
        <content_type>image/jpeg</content_type>
        <created_at>2014-10-03T17:15:17.879-07:00</created_at>
    </image>
    <image>
        <id type="integer">94</id>
        <user_id>92</user_id>
        <filename>92_0.jpg</filename>
        <url>http://192.168.123.101:9000/api/images/view/92_0.jpg</url>
        <category type="integer">0</category>
        <content_type>image/jpeg</content_type>
        <created_at>2014-10-03T17:32:30.678-07:00</created_at>
    </image>
</images>

Add image to User 

POST /api/images/user/<user id> 

...

Content-Type: image/jpeg 

Delete an image 

DELETE /api/images/<image id> 

...

Result: 
Response code 204 if successfully deleted or if the image does not exist.

...

Access Groups

This chapter describes how to create/retrieve/update/delete Access Groups through the FREEDOM PRIMIS API software.

access_group element:

Element Name

Type

Description

Comments

id

string maximum 100 characters

Unique identifier for an Access Group

Optional; On POST, server generates an ID

name

string max 200 characters

The name of the Access Group

Required

description

string max 100 characters

The description of the Access Group

Optional

site_id

string maximum 36 characters

The ID of the Site that the Access Group belongs to

Optional; on POST, default to 1 if it is not set. site_id 0 means the access group is a global access group and it can be used in all sites.
site_id cannot be changed after the access group is created.

access_right

child element

The Access Right granted to the Access Group

access_right is only supported in GET method

 

zone_id

string max 200 characters

The ID of the Controlled Area that the Access Right has access to

Required

schedule_id

string max 50 characters

The ID of the Schedule that the Access Right is following

Required

activation_time

integer

The activation time of the output devices (i.e. how long the door will be opened for)

Required

List all access groups 

GET /api/access_group 

http://<ip address>:<api listening port>/api/access_groups 

...

Code Block
<access_groups>
    <access_group>
        <id>213</id>
        <name>Security</name>
        <description>security guards</description>
        <site_id>1</site_id>
        <access_rights>
            <access_right>
                <zone_id>1110000000003</zone_id>
                <schedule_id>23</schedule_id>
                <activation_time>5</activation_time>
            </access_right>
            <access_right>
                <zone_id>1110000000004</zone_id>
                <schedule_id>23</schedule_id>
                <activation_time>5</activation_time>
            </access_right>
        </access_rights>
    </access_group>
    <access_group>
        <id>211</id>
        <name>Staffs</name>
        <description>staff group</description>
        <site_id>1</site_id>
        <access_rights>
            <access_right>
                <zone_id>1110000000003</zone_id>
                <schedule_id>24</schedule_id>
                <activation_time>5</activation_time>
            </access_right>
            <access_right>
                <zone_id>1110000000004</zone_id>
                <schedule_id>24</schedule_id>
                <activation_time>5</activation_time>
            </access_right>
        </access_rights>
    </access_group>
    <access_group>
        <id>209</id>
        <name>Supervisor</name>
        <description>supervisor group</description>
        <site_id>1</site_id>
        <access_rights>
            <access_right>
                <zone_id>1110000000003</zone_id>
                <schedule_id>24</schedule_id>
                <activation_time>5</activation_time>
            </access_right>
            <access_right>
                <zone_id>1110000000004</zone_id>
                <schedule_id>23</schedule_id>
                <activation_time>5</activation_time>
            </access_right>
        </access_rights>
    </access_group>
</access_groups>

Add access group to user 

POST /api/users/<user id>/access_groups 

...

Code Block
<access_groups>
    <access_group>
        <id>221</id>
        <name>Accounting</name>
        <description/>
    </access_group>
</access_groups>

Delete an access group from user 

DELETE /api/users/<user id>/access_groups 

...

Result: 
Response code 204 if successfully removed from the user or if the access group was not assigned to the user.

Add a new access group

POST /api/access_groups

http://<ip address>:<api listening port>/api/access_groups

...

Code Block
<access_group>
    <name>Supervisor</name>
    <description>supervisor group</description>
    <site_id>1</site_id>
</access_group>

Get an access group record by the access group id

GET /api/access_groups

http://<ip address>:<api listening port>/api/access_groups/213

...

Code Block
<access_group>
    <id>213</id>
    <name>Security</name>
    <description>security guards</description>
    <site_id>1</site_id>
    <access_rights>
        <access_right>
            <zone_id>1110000000003</zone_id>
            <schedule_id>23</schedule_id>
            <activation_time>5</activation_time>
        </access_right>
        <access_right>
            <zone_id>1110000000004</zone_id>
            <schedule_id>23</schedule_id>
            <activation_time>5</activation_time>
        </access_right>
    </access_rights>
</access_group>

Update an access group record by the access group id

PUT /api/access_groups/<access group id>

...

Code Block
<access_group>
    <name>Supervisor</name>
    <description>supervisor group</description>
    <site_id>1</site_id>
</access_group>

Delete an access group record by the access group id

DELETE  /api/access_groups/<access group id>

...

Result: 
Response code 204 if successfully deleted or if the access group does not exist.

...

CA Certificates

This chapter describes how to create/retrieve/update/delete CA Certificates through the FREEDOM PRIMIS API software.

Element Name

Type

Description

Comments

id

string maximum 36 characters

Unique identifier for a CA Certificate

Optional; On POST, server generates an ID

issuer_name

string max 300 characters

The issuer name of the CA Certificate

Required

serial_number

string max 100 characters

The serial number of the CA Certificate

Required

subject_name

string max 300 characters

The subject name of the CA Certificate

Required

issued_to

string max 200 characters

The organization that the CA Certificate is issued to

Required

issued_by

string max 200 characters

The organization that issued the CA Certificate

Required

expiration_date

datetime

Indicates the validity of the CA Certificate

Required

file_name

string max 200 characters

The file name of the CA Certificate

Required

content

string

The content of the CA Certificate

Required

ak_id

string max 255 characters

Authority key identifier of the CA Certificate

Required

sk_id

string max 255 characters

Subject key identifier of the CA Certificate

Required

Add a new CA certificate

POST    /api/ca_certificates                   

...

Content-Type: text/xml

Post Data:

Code Block
<ca_certificate> 
      <issuer_name>CN=Test Trust Anchor for Test PIV Cards, OU=Test CA, O=Test Certificates 2010, C=US</issuer_name>  
      <serial_number>1</serial_number> 
      <subject_name>CN=Test Trust Anchor for Test PIV Cards, OU=Test CA, O=Test Certificates 2010, C=US</subject_name> 
      <issued_to>Test Trust Anchor for Test PIV Cards</issued_to> 
      <issued_by>Test Trust Anchor for Test PIV Cards</issued_by> 
      <expiration_date>2030-10-01T01:30:00.000-07:00</expiration_date> 
      <file_name>Test Trust Anchor for Test PIV Cards (VeriCert Discovered)</file_name>

<content>MIIEujCCA6KgAwIBAgIBATANBgkqhkiG9w0BAQsFADBvMQswCQYDVQQGEwJVUzEfMB0GA1UEChMWVGVzdCBDZXJ0aWZpY2F0ZXMgMjAxMDEQMA4GA1UECxMHVGVzdCBDQTEtMCsGA1UEAxMkVGVzdCBUcnVzdCBBbmNob3IgZm9yIFRlc3QgUElWIENhcmRzMB4XDTEwMTAwMTA4MzAwMFoXDTMwMTAwMTA4MzAwMFowbzELMAkGA1UEBhMCVVMxHzAdBgNVBAoTFlRlc3QgQ2VydGlmaWNhdGVzIDIwMTAxEDAOBgNVBAsTB1Rlc3QgQ0ExLTArBgNVBAMTJFRlc3QgVHJ1c3QgQW5jaG9yIGZvciBUZXN0IFBJViBDYXJkczCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAK6IQGZI1XEqQYT1xiJXra3nOmsBnjk4orCfcswTBC4dKaQNiAFxfsY/vFG9ZLVJRAofzQzSuHA099PNOePrcqND4BjCVySiUfks+ioIfF59GPak4dC91GlHliy0owD8wGO9LNGmMkA4XaO2utdsJsqNAYrWXKcXdp7/e5RpQWkJg4aNHjJZl9Z63bavZPWW7lkeaRf9NcL+ghA2Mvfn1wtbV9PuhHaIb5I9t3mv108SkFdEELERSDnu5PMwDJVTvi4lwbwHf8AIJLSI1shcloRb+m6v7FqQVNtKGTq2xnnAY0SmoF6mQAmlAM8l5sr0IWn2XFXYG5KnZU/SjjyZZwECAwEAAaOCAV8wggFbMIIBFwYIKwYBBQUHAQsEggEJMIIBBTBJBggrBgEFBQcwBYY9aHR0cDovL3NtaW1lMi5uaXN0Lmdvdi9QSVZUZXN0L0NBQ2VydHNJc3N1ZWRCeVRydXN0QW5jaG9yLnA3YzCBtwYIKwYBBQUHMAWGgapsZGFwOi8vc21pbWUyLm5pc3QuZ292L2NuPVRlc3QlMjBUcnVzdCUyMEFuY2hvciUyMGZvciUyMFRlc3QlMjBQSVYlMjBDYXJkcyxvdT1UZXN0JTIwQ0Esbz1UZXN0JTIwQ2VydGlmaWNhdGVzJTIwMjAxMCxjPVVTP2NBQ2VydGlmaWNhdGU7YmluYXJ5LGNyb3NzQ2VydGlmaWNhdGVQYWlyO2JpbmFyeTAdBgNVHQ4EFgQUjt9b4+pbapL+dK83TJHd7CmAsFUwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQELBQADggEBAKFAHXu0/64wTGGB2+9XVRgTj5Eoe1P42jeaA+E8qkc/KpMkvH02Yv0vxGXpwJLVV5bgY5TDVjSvjuBS0DByIcCCRwwdbv+fEB+fx5oeFYWsZj6kQ1O5QCrH4PySNghpEPS2qu8Ms6O6DPTbtCDwHReiofh674lBP4tFyj8UkjxgErvZlH7dfKvYMpOe9iIue2QMhUX4H1DgLAOkgbTZWoWW4sbLrcKlWXcQAq5emJv1f7Mbp55JSthVAPCPvWS9iWWeeZ773Y4J25SO6HjwM0GIHt04LgnIqORvUr0MWnTdAkANwk92Sb2vOQf253lLqaWM83D16RMUYtVK0Y9W59o=</content>

Code Block
        <ak_id/> 
        <sk_id>8EDF5BE3EA5B6A92FE74AF374C91DDEC2980B055</sk_id> 
</ca_certificate>

List all CA certificates

GET     /api/ca_certificates                  

http://<ip address>:<api listening port>/api/ca_certificates

Result: 

Code Block
<ca_certificates> 
  <ca_certificate> 
    <id>163</id> 
    <issuer_name>CN=Test Trust Anchor for Test PIV Cards, OU=Test CA, O=Test Certificates 2010, C=US</issuer_name> 
    <serial_number>1</serial_number> 
    <subject_name>CN=Test Trust Anchor for Test PIV Cards, OU=Test CA, O=Test Certificates 2010, C=US</subject_name> 
    <issued_to>Test Trust Anchor for Test PIV Cards</issued_to> 
    <issued_by>Test Trust Anchor for Test PIV Cards</issued_by> 
    <expiration_date>2030-10-01T01:30:00.000-07:00</expiration_date> 
    <file_name>Test Trust Anchor for Test PIV Cards (VeriCert Discovered)</file_name>

<content>MIIEujCCA6KgAwIBAgIBATANBgkqhkiG9w0BAQsFADBvMQswCQYDVQQGEwJVUzEfMB0GA1UEChMWVGVzdCBDZXJ0aWZpY2F0ZXMgMjAxMDEQMA4GA1UECxMHVGVzdCBDQTEtMCsGA1UEAxMkVGVzdCBUcnVzdCBBbmNob3IgZm9yIFRlc3QgUElWIENhcmRzMB4XDTEwMTAwMTA4MzAwMFoXDTMwMTAwMTA4MzAwMFowbzELMAkGA1UEBhMCVVMxHzAdBgNVBAoTFlRlc3QgQ2VydGlmaWNhdGVzIDIwMTAxEDAOBgNVBAsTB1Rlc3QgQ0ExLTArBgNVBAMTJFRlc3QgVHJ1c3QgQW5jaG9yIGZvciBUZXN0IFBJViBDYXJkczCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAK6IQGZI1XEqQYT1xiJXra3nOmsBnjk4orCfcswTBC4dKaQNiAFxfsY/vFG9ZLVJRAofzQzSuHA099PNOePrcqND4BjCVySiUfks+ioIfF59GPak4dC91GlHliy0owD8wGO9LNGmMkA4XaO2utdsJsqNAYrWXKcXdp7/e5RpQWkJg4aNHjJZl9Z63bavZPWW7lkeaRf9NcL+ghA2Mvfn1wtbV9PuhHaIb5I9t3mv108SkFdEELERSDnu5PMwDJVTvi4lwbwHf8AIJLSI1shcloRb+m6v7FqQVNtKGTq2xnnAY0SmoF6mQAmlAM8l5sr0IWn2XFXYG5KnZU/SjjyZZwECAwEAAaOCAV8wggFbMIIBFwYIKwYBBQUHAQsEggEJMIIBBTBJBggrBgEFBQcwBYY9aHR0cDovL3NtaW1lMi5uaXN0Lmdvdi9QSVZUZXN0L0NBQ2VydHNJc3N1ZWRCeVRydXN0QW5jaG9yLnA3YzCBtwYIKwYBBQUHMAWGgapsZGFwOi8vc21pbWUyLm5pc3QuZ292L2NuPVRlc3QlMjBUcnVzdCUyMEFuY2hvciUyMGZvciUyMFRlc3QlMjBQSVYlMjBDYXJkcyxvdT1UZXN0JTIwQ0Esbz1UZXN0JTIwQ2VydGlmaWNhdGVzJTIwMjAxMCxjPVVTP2NBQ2VydGlmaWNhdGU7YmluYXJ5LGNyb3NzQ2VydGlmaWNhdGVQYWlyO2JpbmFyeTAdBgNVHQ4EFgQUjt9b4+pbapL+dK83TJHd7CmAsFUwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQELBQADggEBAKFAHXu0/64wTGGB2+9XVRgTj5Eoe1P42jeaA+E8qkc/KpMkvH02Yv0vxGXpwJLVV5bgY5TDVjSvjuBS0DByIcCCRwwdbv+fEB+fx5oeFYWsZj6kQ1O5QCrH4PySNghpEPS2qu8Ms6O6DPTbtCDwHReiofh674lBP4tFyj8UkjxgErvZlH7dfKvYMpOe9iIue2QMhUX4H1DgLAOkgbTZWoWW4sbLrcKlWXcQAq5emJv1f7Mbp55JSthVAPCPvWS9iWWeeZ773Y4J25SO6HjwM0GIHt04LgnIqORvUr0MWnTdAkANwk92Sb2vOQf253lLqaWM83D16RMUYtVK0Y9W59o=</content>

Code Block
      <ak_id/> 
      <sk_id>8EDF5BE3EA5B6A92FE74AF374C91DDEC2980B055</sk_id> 
    </ca_certificate> 
</ca_certificates>

Get a CA certificate by the CA certificate id 

GET     /api/ca_certificates/<ca_certificate id>              

http://<ip address>:<api listening port>/api/ca_certificates/163

Result: 

Code Block
<ca_certificate> 
        <id>163</id> 
        <issuer_name>CN=Test Trust Anchor for Test PIV Cards, OU=Test CA, O=Test Certificates 2010, C=US</issuer_name> 
        <serial_number>1</serial_number> 
        <subject_name>CN=Test Trust Anchor for Test PIV Cards, OU=Test CA, O=Test Certificates 2010, C=US</subject_name> 
        <issued_to>Test Trust Anchor for Test PIV Cards</issued_to> 
        <issued_by>Test Trust Anchor for Test PIV Cards</issued_by> 
        <expiration_date>2030-10-01T01:30:00.000-07:00</expiration_date> 
        <file_name>Test Trust Anchor for Test PIV Cards (VeriCert Discovered)</file_name>

<content>MIIEujCCA6KgAwIBAgIBATANBgkqhkiG9w0BAQsFADBvMQswCQYDVQQGEwJVUzEfMB0GA1UEChMWVGVzdCBDZXJ0aWZpY2F0ZXMgMjAxMDEQMA4GA1UECxMHVGVzdCBDQTEtMCsGA1UEAxMkVGVzdCBUcnVzdCBBbmNob3IgZm9yIFRlc3QgUElWIENhcmRzMB4XDTEwMTAwMTA4MzAwMFoXDTMwMTAwMTA4MzAwMFowbzELMAkGA1UEBhMCVVMxHzAdBgNVBAoTFlRlc3QgQ2VydGlmaWNhdGVzIDIwMTAxEDAOBgNVBAsTB1Rlc3QgQ0ExLTArBgNVBAMTJFRlc3QgVHJ1c3QgQW5jaG9yIGZvciBUZXN0IFBJViBDYXJkczCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAK6IQGZI1XEqQYT1xiJXra3nOmsBnjk4orCfcswTBC4dKaQNiAFxfsY/vFG9ZLVJRAofzQzSuHA099PNOePrcqND4BjCVySiUfks+ioIfF59GPak4dC91GlHliy0owD8wGO9LNGmMkA4XaO2utdsJsqNAYrWXKcXdp7/e5RpQWkJg4aNHjJZl9Z63bavZPWW7lkeaRf9NcL+ghA2Mvfn1wtbV9PuhHaIb5I9t3mv108SkFdEELERSDnu5PMwDJVTvi4lwbwHf8AIJLSI1shcloRb+m6v7FqQVNtKGTq2xnnAY0SmoF6mQAmlAM8l5sr0IWn2XFXYG5KnZU/SjjyZZwECAwEAAaOCAV8wggFbMIIBFwYIKwYBBQUHAQsEggEJMIIBBTBJBggrBgEFBQcwBYY9aHR0cDovL3NtaW1lMi5uaXN0Lmdvdi9QSVZUZXN0L0NBQ2VydHNJc3N1ZWRCeVRydXN0QW5jaG9yLnA3YzCBtwYIKwYBBQUHMAWGgapsZGFwOi8vc21pbWUyLm5pc3QuZ292L2NuPVRlc3QlMjBUcnVzdCUyMEFuY2hvciUyMGZvciUyMFRlc3QlMjBQSVYlMjBDYXJkcyxvdT1UZXN0JTIwQ0Esbz1UZXN0JTIwQ2VydGlmaWNhdGVzJTIwMjAxMCxjPVVTP2NBQ2VydGlmaWNhdGU7YmluYXJ5LGNyb3NzQ2VydGlmaWNhdGVQYWlyO2JpbmFyeTAdBgNVHQ4EFgQUjt9b4+pbapL+dK83TJHd7CmAsFUwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQELBQADggEBAKFAHXu0/64wTGGB2+9XVRgTj5Eoe1P42jeaA+E8qkc/KpMkvH02Yv0vxGXpwJLVV5bgY5TDVjSvjuBS0DByIcCCRwwdbv+fEB+fx5oeFYWsZj6kQ1O5QCrH4PySNghpEPS2qu8Ms6O6DPTbtCDwHReiofh674lBP4tFyj8UkjxgErvZlH7dfKvYMpOe9iIue2QMhUX4H1DgLAOkgbTZWoWW4sbLrcKlWXcQAq5emJv1f7Mbp55JSthVAPCPvWS9iWWeeZ773Y4J25SO6HjwM0GIHt04LgnIqORvUr0MWnTdAkANwk92Sb2vOQf253lLqaWM83D16RMUYtVK0Y9W59o=</content>

Code Block
        <ak_id/> 
        <sk_id>8EDF5BE3EA5B6A92FE74AF374C91DDEC2980B055</sk_id> 
</ca_certificate>

Update a CA certificate by the CA certificate id

PUT     /api/ca_certificates/<ca certificate id>              

http://<ip address>:<api listening port>/api/ca_certificates/163

PUT Data: 

Code Block
<ca_certificate> 
        <id>163</id> 
        <issuer_name>CN=Test Trust Anchor for Test PIV Cards, OU=Test CA, O=Test Certificates 2010, C=US</issuer_name> 
        <serial_number>1</serial_number> 
        <subject_name>CN=Test Trust Anchor for Test PIV Cards, OU=Test CA, O=Test Certificates 2010, C=US</subject_name> 
        <issued_to>Test Trust Anchor for Test PIV Cards</issued_to> 
        <issued_by>Test Trust Anchor for Test PIV Cards</issued_by> 
        <expiration_date>2030-10-01T01:30:00.000-07:00</expiration_date> 
        <file_name>Test Trust Anchor for Test PIV Cards (VeriCert Discovered)</file_name>

<content>MIIEujCCA6KgAwIBAgIBATANBgkqhkiG9w0BAQsFADBvMQswCQYDVQQGEwJVUzEfMB0GA1UEChMWVGVzdCBDZXJ0aWZpY2F0ZXMgMjAxMDEQMA4GA1UECxMHVGVzdCBDQTEtMCsGA1UEAxMkVGVzdCBUcnVzdCBBbmNob3IgZm9yIFRlc3QgUElWIENhcmRzMB4XDTEwMTAwMTA4MzAwMFoXDTMwMTAwMTA4MzAwMFowbzELMAkGA1UEBhMCVVMxHzAdBgNVBAoTFlRlc3QgQ2VydGlmaWNhdGVzIDIwMTAxEDAOBgNVBAsTB1Rlc3QgQ0ExLTArBgNVBAMTJFRlc3QgVHJ1c3QgQW5jaG9yIGZvciBUZXN0IFBJViBDYXJkczCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAK6IQGZI1XEqQYT1xiJXra3nOmsBnjk4orCfcswTBC4dKaQNiAFxfsY/vFG9ZLVJRAofzQzSuHA099PNOePrcqND4BjCVySiUfks+ioIfF59GPak4dC91GlHliy0owD8wGO9LNGmMkA4XaO2utdsJsqNAYrWXKcXdp7/e5RpQWkJg4aNHjJZl9Z63bavZPWW7lkeaRf9NcL+ghA2Mvfn1wtbV9PuhHaIb5I9t3mv108SkFdEELERSDnu5PMwDJVTvi4lwbwHf8AIJLSI1shcloRb+m6v7FqQVNtKGTq2xnnAY0SmoF6mQAmlAM8l5sr0IWn2XFXYG5KnZU/SjjyZZwECAwEAAaOCAV8wggFbMIIBFwYIKwYBBQUHAQsEggEJMIIBBTBJBggrBgEFBQcwBYY9aHR0cDovL3NtaW1lMi5uaXN0Lmdvdi9QSVZUZXN0L0NBQ2VydHNJc3N1ZWRCeVRydXN0QW5jaG9yLnA3YzCBtwYIKwYBBQUHMAWGgapsZGFwOi8vc21pbWUyLm5pc3QuZ292L2NuPVRlc3QlMjBUcnVzdCUyMEFuY2hvciUyMGZvciUyMFRlc3QlMjBQSVYlMjBDYXJkcyxvdT1UZXN0JTIwQ0Esbz1UZXN0JTIwQ2VydGlmaWNhdGVzJTIwMjAxMCxjPVVTP2NBQ2VydGlmaWNhdGU7YmluYXJ5LGNyb3NzQ2VydGlmaWNhdGVQYWlyO2JpbmFyeTAdBgNVHQ4EFgQUjt9b4+pbapL+dK83TJHd7CmAsFUwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQELBQADggEBAKFAHXu0/64wTGGB2+9XVRgTj5Eoe1P42jeaA+E8qkc/KpMkvH02Yv0vxGXpwJLVV5bgY5TDVjSvjuBS0DByIcCCRwwdbv+fEB+fx5oeFYWsZj6kQ1O5QCrH4PySNghpEPS2qu8Ms6O6DPTbtCDwHReiofh674lBP4tFyj8UkjxgErvZlH7dfKvYMpOe9iIue2QMhUX4H1DgLAOkgbTZWoWW4sbLrcKlWXcQAq5emJv1f7Mbp55JSthVAPCPvWS9iWWeeZ773Y4J25SO6HjwM0GIHt04LgnIqORvUr0MWnTdAkANwk92Sb2vOQf253lLqaWM83D16RMUYtVK0Y9W59o=</content>

Code Block
        <ak_id/> 
        <sk_id>8EDF5BE3EA5B6A92FE74AF374C91DDEC2980B055</sk_id> 
</ca_certificate>

Delete a CA certificate by the CA certificate id

DELETE  /api/ca_certificates/<ca_certificate id>              

...

Result: 
Response code 204 if successfully deleted or if the CA certificate does not exist.

Cards

This chapter describes how to create/retrieve/update/delete Cards through the FREEDOM PRIMIS API software.

card element:

Element Name

Type

Description

Comments

card_number

string max 100 characters

Unique identifier for a Card

Required

card_type

string, either ‘wg’ or ‘piv’

The type of the card

Required
wg – Wiegand
piv – Personal identity verification card

user_id

string max 200 characters

The ID of the User that the Card belongs to

Required

created_at

datetime

Create timestamp

 

updated_at

datetime

Update timestamp

 

disabled

boolean(true/false)

Enable or disable the Card

Required

Add a new card

POST /api/cards

http://<ip address>:<api listening port>/api/cards

...

Code Block
<card>
    <card_number>048051B4228841FDB8955FE9945E1C63</card_number>
    <card_type>piv</card_type>
    <user_id>170</user_id>
    <disabled type="boolean">false</disabled>
</card>

List all cards

GET /api/cards

http://<ip address>:<api listening port>/api/cards

...

Code Block
<cards>
<card>
    <card_number>048051B4228841FDB8955FE9945E1C63</card_number>
    <card_type>piv</card_type>
    <user_id>170</user_id>
    <created_at>2014-10-17T13:46:33.040-07:00</created_at>
    <updated_at>2014-10-17T13:46:33.040-07:00</updated_at>
    <disabled type="boolean">false</disabled>
</card>
<card>
    <card_number>1234565590</card_number>
    <card_type>wg</card_type>
    <user_id>190000000011</user_id>
    <created_at>2014-10-22T21:52:26.871-07:00</created_at>
    <updated_at>2014-10-22T21:52:26.871-07:00</updated_at>
    <disabled type="boolean">false</disabled>
</card>
</cards

Get a card record by the card id

GET /api/cards/<card id>

http://<ip address>:<api listening port>/api/cards/048051B4228841FDB8955FE9945E1C63

...

Code Block
<card>
    <card_number>048051B4228841FDB8955FE9945E1C63</card_number>
    <card_type>piv</card_type>
    <user_id>170</user_id>
    <created_at>2014-10-17T13:46:33.040-07:00</created_at>
    <updated_at>2014-10-17T13:46:33.040-07:00</updated_at>
    <disabled type="boolean">false</disabled>
</card>

Update a card record by the card id

PUT /api/cards/<card id>

http://<ip address>:<api listening port>/api/cards/048051B4228841FDB8955FE9945E1C63

...

Code Block
<card>
    <card_type>piv</card_type>
    <user_id>170</user_id>
    <disabled type="boolean">false</disabled>
</card>

Delete a card record by the card id

DELETE  /api/cards/<card id>

...

Result: 
Response code 204 if successfully deleted or if the card does not exist.

Sites

This chapter describes how to create/retrieve/update/delete Sites through the FREEDOM PRIMIS API software.

site element:

Element Name

Type

Description

Comments

id

string maximum 36 characters

Unique identifier for a Site

Optional; On POST, server generates an ID

name

string max 200 characters

The name of the Site

Required

description

string max 200 characters

The description of the Site

Optional

timezone_id

string max 200 characters

The timezone where the Site is in. The value must be a valid Java TimeZone ID. The complete list of supported timezones is available from:
http://<ip address>:<api listening port>/api/sites/validtimezoneids

Required

Add a new site

POST /api/sites

http://<ip address>:<api listening port>/api/sites

...

Code Block
<site>
    <name>Vancouver</name>
    <description>Vancouver Office</description>
    <timezone_id>America/Los_Angeles</timezone_id>
</site>

List all sites

GET /api/sites

http://<ip address>:<api listening port>/api/sites

...

Code Block
<sites>
    <site>
        <id>1</id>
        <name>Main</name>
        <description/>
        <timezone_id>America/Los_Angeles</timezone_id>
    </site>
</sites>

Get a site record by the site id

GET /api/sites/<site id>

http://<ip address>:<api listening port>/api/sites/1

...

Code Block
<site>
    <id>1</id>
    <name>Main</name>
    <description/>
    <timezone_id>America/Los_Angeles</timezone_id>
</site>

Update a site record by the site id

PUT /api/sites/<site id>

http://<ip address>:<api listening port>/api/sites/1

...

Code Block
<site>
    <name>Vancouver</name>
    <description>Vancouver Office</description>
    <timezone_id>America/Los_Angeles</timezone_id>
</site>

Delete a site record by the site id

DELETE  /api/sites/<site id>

...

Result: 
Response code 204 if successfully deleted or if the site does not exist.

Controlled Areas

This chapter describes how to create/retrieve/update/delete Controlled Areas through the FREEDOM Primis API software.

controlled_area element:

Element Name

Type

Description

Comments

id

string max 200 characters

Unique identifier for a Controlled Area

Optional; On POST, server generates an ID

name

string max 255 characters

The name of the Controlled Area

Required

description

string max 255 characters

The description of the Controlled Area

Optional

toggle

character

When toggle is set to “T”, the Controlled Area will remain off or on indefinitely when its state is changed. This disables activation times for the Controlled Area and toggles the state of the Controlled Area indefinitely.

Optional
T – toggle

factor

integer

Multi-factor settings for authorization

Optional; On POST, default to 0
0 – not multi factor
2  – two valid cards are presented
3  – three valid cards are presented

authorization_mode

integer

Multi-factor authorization mode

Optional; On POST, default to 0
0 – single user
1 – multi user

authorization_timeout

Integer

Time out in seconds for multi-factor authorization

Optional; On POST, default to 0

guard_group

 

 

Deprecated

state

string

The state of the Controlled Area

Required
open – the relay is opened
close – the relay is closed
enable – the MESH panel is enabled
disable – the MESH panel is disabled
LOCKDOWN – no access is allowed

zone_group_id

string maximum 36 characters

The zone group which the controlled area is assigned to.

Optional:
“” – not assigned to any zone group
Any value – the ID of the zone group

site_id

string maximum 36 characters

The site identifier

On POST, default to 1 if it is not set.
site_id cannot be changed after the controlled area is created.

Add a new controlled area

POST /api/controlled_areas

...

Code Block
<controlled_area>
    <name>Front entrance lobby</name>
    <description>front entrance</description>
    <toggle/>
    <factor>0</factor>
    <authorization_mode>0</authorization_mode>
    <authorization_timeout>0</authorization_timeout>
    <guard_group/>
    <state>close</state>
    <zone_group_id>0</zone_group_id>
    <site_id>1</site_id>
</controlled_area>

List all controlled areas

GET /api/controlled_areas

...

Code Block
<controlled_areas>
    <controlled_area>
        <id>1110000000003</id>
        <name>Front entrance lobby</name>
        <description>front entrance</description>
        <toggle/>
        <factor>0</factor>
        <authorization_mode>0</authorization_mode>
        <authorization_timeout>0</authorization_timeout>
        <guard_group/>
        <state>close</state>
        <zone_group_id>0</zone_group_id>
        <site_id>1</site_id>
    </controlled_area>
    <controlled_area>
        <id>1110000000004</id>
        <name>Second floor office</name>
        <description>office at second floor</description>
        <toggle/>
        <factor>0</factor>
        <authorization_mode>0</authorization_mode>
        <authorization_timeout>0</authorization_timeout>
        <guard_group/>
        <state>close</state>
        <zone_group_id>0</zone_group_id>
        <site_id>1</site_id>
    </controlled_area>
</controlled_areas>

Get a controlled area record by the controlled area id

GET /api/controlled_areas/<controlled area id>

...

Code Block
<controlled_area>
    <id>1110000000003</id>
    <name>Front entrance lobby</name>
    <description>front entrance</description>
    <toggle/>
    <factor>0</factor>
    <authorization_mode>0</authorization_mode>
    <authorization_timeout>0</authorization_timeout>
    <guard_group/>
    <state>close</state>
    <zone_group_id>0</zone_group_id>
    <site_id>1</site_id>
</controlled_area>

Update a controlled area record by the controlled area id

PUT /api/controlled_areas/<controlled area id>

...

Code Block
<controlled_area>
    <id>1110000000003</id>
    <name>Front entrance lobby</name>
    <description>front entrance</description>
    <toggle/>
    <factor>0</factor>
    <authorization_mode>0</authorization_mode>
    <authorization_timeout>0</authorization_timeout>
    <guard_group/>
    <state>close</state>
    <zone_group_id>0</zone_group_id>
    <site_id>1</site_id>
</controlled_area>

Delete a controlled area record by the controlled area id

DELETE  /api/controlled_areas/<controlled area id>

...

Result: 
Response code 204 if successfully deleted or if the controlled area does not exist.

Schedules

This chapter describes how to create/retrieve/update/delete Schedules through the FREEDOM PRIMIS API software.

schedule element:

Element Name

Type

Description

Comments

id

string maximum 50 characters

Unique identifier for a Schedule

Optional; On POST, server generates an ID

name

string max 200 characters

The name of the Schedule

Required

description

string max 80 characters

The description of the Schedule

Optional

site_id

string maximum 36 characters

The site identifier

On POST, default to 1 if it is not set.
site_id cannot be changed after the schedule is created.

period

child element

 

period is only supported in GET method

 

id

string max 36 characters

Unique identifier for a Schedule Period

 

frequency

integer

The frequency of the Schedule Period

This field is a bit mask of the two types - weekly and holiday. When weekly is used, this field has the value of 0x00002 (decimal 2). When holiday type is used, the lower two bytes has the value of 0x00040 (decimal 64), the upper 3 bytes represents the holiday type in used. Each bit in these 3 upper bytes present one holiday type enumerated like the following:

Type 1 - 0x00100
Type 2 - 0x00200
Type 3 - 0x00400
Type 4 - 0x00800
....
Type 12 - 0x80000
so for a frequency value of decimal 320 (0x00140), holiday type 1 is used (0x00100 + 0x00040).

exceptions

integer

The exception holiday types in the Schedule Period

This field is a bit mask that maintains the exception holiday types in the schedule period. The types are enumerated the same way as the types 1 through to 12 in frequency (0x00100, 0x00200.... 0x80000).

days

integer

The days of the week that are active in the Schedule Period

This field is a bit mask that maintains the days of the week that are active in the schedule period.
Day-of-the-week bit masks are enumerated in the follow way:

SUNDAY_MASK = 0x0001; MONDAY_MASK = 0x0002; TUESDAY_MASK = 0x0004; WEDNESDAY_MASK = 0x0008; THURSDAY_MASK = 0x0010;
FRIDAY_MASK = 0x0020; SATURDAY_MASK = 0x0040;
HOLIDAYS_MASK = 0x0080;

on_time

datetime

The effective start date of the Schedule Period

1900-01-01 00:00:00.0 will be returned if no start date is specified

off_time

datetime

The effective expire date of the Schedule Period

1900-01-01 00:00:00.0 will be returned if no expire date is specified

enabled

integer

 

Deprecated

Add a new schedule

POST /api/schedules/<schedule id>

...

Code Block
<schedule>
    <name>24X7</name>
    <description>24 by 7 schedule</description>
    <site_id>1</site_id>
</schedule>

List all schedules

GET /api/schedules

http://<ip address>:<api listening port>/api/schedules

...

Code Block
<schedules>
    <schedule>
        <id>23</id>
        <name>24X7</name>
        <description>24 by 7 schedule</description>
        <site_id>1</site_id>
        <periods>
            <period>
                <id>190000000022</id>
                <frequency type="integer">2</frequency>
                <exceptions type="integer">0</exceptions>
                <days type="integer">127</days>
                <on_time type="datetime">1900-01-01 00:00:00.0</on_time>
                <off_time type="datetime">1900-01-01 00:00:00.0</off_time>
                <enabled type="integer">1</enabled>
            </period>
        </periods>
    </schedule>
    <schedule>
        <id>24</id>
        <name>Weekday</name>
        <description>weekday schedule</description>
        <site_id>1</site_id>
        <periods>
            <period>
                <id>190000000024</id>
                <frequency type="integer">2</frequency>
                <exceptions type="integer">0</exceptions>
                <days type="integer">62</days>
                <on_time type="datetime">1900-01-01 06:00:00.0</on_time>
                <off_time type="datetime">1900-01-01 20:00:00.0</off_time>
                <enabled type="integer">1</enabled>
            </period>
        </periods>
    </schedule>
    <schedule>
        <id>21</id>
        <name>24X7</name>
        <description>24 by 7 schedule</description>
        <site_id>4</site_id>
        <periods>
            <period>
                <id>190000000013</id>
                <frequency type="integer">2</frequency>
                <exceptions type="integer">0</exceptions>
                <days type="integer">127</days>
                <on_time type="datetime">1900-01-01 00:00:00.0</on_time>
                <off_time type="datetime">1900-01-01 00:00:00.0</off_time>
                <enabled type="integer">1</enabled>
            </period>
        </periods>
    </schedule>
    <schedule>
        <id>22</id>
        <name>Weekday</name>
        <description>weekday schedule</description>
        <site_id>4</site_id>
        <periods>
            <period>
                <id>190000000015</id>
                <frequency type="integer">2</frequency>
                <exceptions type="integer">0</exceptions>
                <days type="integer">62</days>
                <on_time type="datetime">1900-01-01 06:00:00.0</on_time>
                <off_time type="datetime">1900-01-01 20:00:00.0</off_time>
                <enabled type="integer">1</enabled>
            </period>
        </periods>
    </schedule>
</schedules>

Get a schedule record by the schedule id

GET /api/schedules/<schedule id>

...

Code Block
<schedule>
    <id>23</id>
    <name>24X7</name>
    <description>24 by 7 schedule</description>
    <site_id>1</site_id>
    <periods>
        <period>
            <id>190000000022</id>
            <frequency type="integer">2</frequency>
            <exceptions type="integer">320</exceptions>
            <days type="integer">0</days>
            <on_time type="datetime">1900-01-01T00:00:00.000-08:00</on_time>
            <off_time type="datetime">1900-01-01T00:00:00.000-08:00</off_time>
            <enabled type="integer">1</enabled>
        </period>
    </periods>
</schedule>

Update a schedule record by the schedule id

PUT /api/schedules/<schedule id>

...

Code Block
<schedule>
      <name>24X7</name>
      <description>24 by 7 schedule</description>
      <site_id>1</site_id>
</schedule>

Delete a schedule record by the schedule id

DELETE  /api/schedules/<schedule id>

...

Result: 
Response code 204 if successfully deleted or if the schedule does not exist.

Access Rights

This chapter describes how to create/retrieve/delete Access Rights through the FREEDOM PRIMIS API software.

access_right element:

Element Name

Type

Description

Comments

zone_id

string max 200 characters

The ID of the Controlled Area that the Access Right has access to

Required

schedule_id

string max 50 characters

The ID of the Schedule that the Access Right is following

Required

activation_time

integer

The activation time of the output devices (i.e. how long the door will be opened for)

Required

Add a new access right to an access group

POST /api/access_groups/<access group id>/controlled_areas

...

Code Block
languagexml
<access_rights>
      <access_right>
            <zone_id>1110000000003</zone_id>
            <schedule_id>23</schedule_id>
            <activation_time>5</activation_time>
      </access_right>
</access_rights>

List all controlled areas accessible by an access group

GET /api/access_groups/<access group id>/controlled_areas

...

Code Block
<access_rights>
    <access_right>
        <zone_id>1110000000003</zone_id>
        <schedule_id>23</schedule_id>
        <activation_time>5</activation_time>
    </access_right>
</access_rights>

List all access groups assigned to an user

GET /api/access_groups/<access group id>/users

...

Code Block
<users>
<user>
    <id>190000000010</id>
    <first_name>John</first_name>
    <last_name>Smith</last_name>
    <access_start_date/>
    <access_end_date/>
    <pin type="integer"/>
    <email/>
    <phone/>
    <created_at>2014-10-22T21:51:28.272-07:00</created_at>
    <updated_at>2014-10-22T21:51:28.272-07:00</updated_at>
    <disabled type="boolean">false</disabled>
    <credential/>
    <cards>
        <card_number>1234567890</card_number>
    </cards>
    <access_groups>
        <access_group>
            <id>213</id>
            <name>Security</name>
            <site_id>1</site_id>
        </access_group>
        <access_group>
            <id>221</id>
            <name>Accounting</name>
            <site_id>1</site_id>
        </access_group>
    </access_groups>
    <custom_field_items/>
    <images/>
</user>
</users>

Delete access right from an access group by the controlled area id

DELETE  /api/access_groups/<access group id>/controlled_areas/<controlled area id>

...

Result: 
Response code 204 if successfully deleted or if the access right does not exist.

Zone Groups

This chapter describes how to create/retrieve/update/delete Zone Groups through the FREEDOM PRIMIS API software.

zone_group element:

Element Name

Type

Description

Comments

id

string maximum 36 characters

Unique identifier for a Site

Optional; On POST, server generates an ID

name

string max 100 characters

The name of the Site

Required

description

string max 200 characters

The description of the Site

Optional

site_id

string maximum 36 characters

The site identifier

On POST, default to 1 if it is not set.
site_id cannot be changed after the zone group is created.

controlled_area

 

 

controlled-area is only supported in GET method

 

id

string max 200 characters

Unique identifier for a Controlled Area

 

name

string max 255 characters

The name of the Controlled Area

 

Add a new zone group

POST /api/zone_groups

http://<ip address>:<api listening port>/api/zone_groups

...

Code Block
<zone_group>
      <id>1</id>
      <name>Floor 1</name>
      <description>1st floor zone group</description>
      <site_id>1</site_id>
</zone_group>

List all zone groups

GET /api/zone_groups

http://<ip address>:<api listening port>/api/zone_groups

...

Code Block
<zone_groups>
  <zone_group>
    <id>21</id>
    <name>1st Floor</name>
    <description>1st Floor zone group</description>
    <site_id>1</site_id>
    <controlled_areas>
      <controlled_area>
        <id>170000000006</id>
        <name>Account office</name>
      </controlled_area>
    </controlled_areas>
  </zone_group>
  <zone_group>
    <id>22</id>
    <name>2nd Floor</name>
    <description>2nd Floor zone group</description>
    <site_id>1</site_id>
    <controlled_areas>
      <controlled_area>
        <id>170000000007</id>
        <name>Sales office</name>
      </controlled_area>
    </controlled_areas>
  </zone_group>
</zone_groups>
13.3 Get a zone group record by the zone group id
GET /api/zone_groups/<zone group id>
http://<ip address>:<api listening port>/api/zone_groups/1
Result:
<zone_group>
  <id>21</id>
  <name>1st Floor</name>
  <description>1st Floor zone group</description>
  <site_id>1</site_id>
  <controlled_areas>
    <controlled_area>
      <id>170000000006</id>
      <name>Account office</name>
    </controlled_area>
  </controlled_areas>
</zone_group>

Get a zone group record by the zone group id

GET /api/zone_groups/<zone group id>

...

Code Block
<zone_group>
    <id>21</id>
    <name>1st Floor</name>
    <description>1st Floor zone group</description>
    <site_id>1</site_id>
    <controlled_areas>
      <controlled_area>
        <id>170000000006</id>
        <name>Account office</name>
      </controlled_area>
    </controlled_areas>
</zone_group>

Update a zone group record by the zone group id

PUT /api/zone_groups/<zone group id>

...

Code Block
<zone_group>
    <name>1st Floor</name>
    <description>1st Floor zone group</description>
    <site_id>1</site_id>
</zone_group>

Delete a zone group record by the zone group id

DELETE  /api/zone groups/<zone group id>

...

Result: 
Response code 204 if successfully deleted or if the zone group does not exist.

Activity Events

This chapter describes how to retrieve Activity events through the FREEDOM PRIMIS API software.

activity_event element:

Element Name

Type

Description

Comments

id

integer

Unique identifier for an activity event

 

hostname

string max 50 characters

Hostname of the server which logged the event

 

event_time

datetime

Timestamp of the event

This element is searchable by using query parameter logged_since. for example: logged_since=20170615130130 will return all events logged after 2017-06-15 13:01:30

site_id

string maximum 36 characters

The identifier of the site

This element is searchable

activity_type

string max 20 characters

Activity type of the event

Supported values are: Unknown, Card Access, Port, Video, Dial Suite, PIN Access, Panel Access, Schedule, Snapshot, Phone Access, Manual. This element is searchable

device_id

string max 100 characters

The identifier of the device

This element is searchable

device_name

string max 100 characters

Name of the device

This element is searchable

device_type

string max 50 characters

Type of the device

This element is searchable

port_name

string max 50 characters

Name of the port

This element is searchable

originator_id

string max 2000 characters

The identifier of the originator

This element is searchable

originator_name

string max 50 characters

Name of the originator

This element is searchable

result

string max 100 characters

Result of the event

Supported values are: Unknown, Granted, Denied, Opened, Closed, Snapshot, Answered, Placed, Wrong number, Restricted, Locked, Unlocked, Set, Reset, Denied - CA Locked Down, Authenticated, Denied - Invalid License, Error Break, Error short, Denied - Anti Passback, Denied - Card Disabled, Denied - User Deactivated, - Denied - User Expired, Denied - Access Expired, Denied - Risk Level, Denied - Start Date Error, Denied - Certificate Revoked, Denied - Certificate Chain Invalid, Denied - Certificate Signature Invalid, Granted - Certificate Chain Error Ignored, Granted - Certificate Signature Error Ignored, Denied - Certificate Timestamp Invalid, Denied -, Card Swipe, Card Swipe 2 Times, Card Swipe 3 Times, Card Swipe 4 Times, Card Swipe 5 Times, Card Swipe 6 Times, Request to Exit, Door Opened, Door Closed

This element is searchable

suite_id

string max 50 characters

The identifier of the suite

This element is searchable

user_id

string max 200 characters

The identifier of the user

This element is searchable

first_name

string max 50 characters

First name of the user

This element is searchable

last_name

string max 50 characters

Last name of the user

This element is searchable

card_number

string max 100 characters

Card number of the user

This element is searchable

snapshot_url

string max 50 characters

URL of the photo snapshot

This element is searchable

io_control

string max 2 characters

 

Obsoleted

sent_to_ams

boolean(true/false)

Flag to indicate if the event has been sent to AMS

 

event_code

integer

Event code of the event

This element is searchable

 List all activity events

GET     /api/activitylog

http://<ip address>:<api listening port>/api/activitylog

...

Code Block
<activity_events>
<activity_event>
       <id>585781<<id>3042304</id>
    <hostname>localhost.localdomain<    <hostname>server</hostname>
       <event_time>2016time>2023-0207-04T1122T11:5930:2541.614938-0807:00</event_time>
       <site_id>1<id>66fc2ba1-5b58-4fe3-a67a-3d5f218db426</site_id>
       <activity_type>Card Access</activity_type>
   type/>
    <device_id>CC720F00059C<id>E45F01334F1D</device_id>
       <device_name>FBname>Dev 1<SB</device_name>
       <device_type>Freedomtype/>
Bridge 1-Rdr/R2 Supv</device_type>     <port_name>Reader 1</port_name>
    <originator_id>Edmonton_ADUser_02, Edmonton_ADUser_02:3070400000467;Group:admin group, Area:Lobby<name/>
    <originator_id>Identiv EG-2 device synchronization for name=Dev SB, id=E45F01334F1D completed with status=ok</originator_id>
       <originator_name>S-1-5-21-3760748383-892082386-3578648945-113886</originator_name>
    <result>Granted</result>
   name/>
    <result/>
    <suite_id/>
       <user_id>S-1-5-21-3760748383-892082386-3578648945-113886</user_id>
    <first_name>Edmonton_ADUser_02</first_name>
    <last_name>Edmonton_ADUser_02</last_name>
    <card_number>3070400000467</card_number>
   id/>
    <first_name/>
    <last_name/>
    <card_number/>
    <snapshot_url/>
       <io_control>1</io_control>
   control/>
    <sent_to_ams>false</sent_to_ams>
       <event_code>10101<code>60004</event_code>
    <controlled_area_id>c4d9a29d-ef0f-4856-b6a5-1804a1dd8f1a</controlled_area_id>
    <controlled_area_name>Door-EG2</controlled_area_name>
</activity_event>
<activity_event>
       <id>585780<<id>3042307</id>
    <hostname>localhost.localdomain<    <hostname>server</hostname>
       <event_time>2016time>2023-0207-04T1122T11:5930:2643.487377-0807:00</event_time>
       <site_id>1</site_id>
       <activity_type>Card Access</activity_type>
   type/>
    <device_id>CC720F00059C<id>all</device_id>
       <device_name>FB 1</device_name>
   name/>
    <device_type/>
       <port_name>Reader 1</port_name>
   name/>
    <originator_id> <id>Identiv EG-2 Device Synchronization Completed</originator_id>
       <originator_name/>
      <result>Card Swipe</result>
   <result/>
    <suite_id/>
       <user_id>S-1-5-21-3760748383-892082386-3578648945-113886</user_id>
    <first_name>Edmonton_ADUser_02</first_name>
    <last_name>Edmonton_ADUser_02</last_name>
    <card_number>3070400000467</card_number>
  id/>
    <first_name/>
    <last_name/>
    <card_number/>
    <snapshot_url/>
       <io_control/>>
       <sent_to_ams>false</sent_to_ams>
       <event_code>10006<code>60002</event_code>
</activity_event>
    <controlled_area_id/>
    <controlled_area_name/>
</activity_events>event>

Retrieve a range of activity events

GET     /api/activitylog?offset=<offset>&n=<limit>

...

http://<ip address>:<api listening port>/api/activitylog?offset=100&n=50

Search activity events with filtering criteria

GET     /api/activitylog/search

...

Code Block
<activity_events_search>
<criteria>
 
</criteria>
<activity_events results="2">
<activity_event>
       <id>585782<<id>3041955</id>
       <hostname>localhost.localdomain<<hostname>server</hostname>
       <event_time>2016time>2023-0207-04T1121T14:5933:2736.064413-0807:00</event_time>
       <site_id>1</site_id>
       <activity_type>Port</activity_type>
       <device_id>CC720F00059C<id>DCA632E2365A</device_id>
       <device_name>FB 1<name>-FACTORY DEFAULT-</device_name>
       <device_type>Freedomtype>Identiv Bridge 1EG-Rdr2</R2 Supv</device_type>
       <port_name>Relay 1<name>Port</port_name>
       <originator_id> id>DCA632E2365A: Controller Mode (Server Online: PRM)</originator_id>
       <originator_name/>
       <result>Set</result>
       <suite_id/>
       <user_id/>
       <first_name/>
       <last_name/>
       <card_number/>
       <snapshot_url/>
       <io_control/>
       <sent_to_ams>false</sent_to_ams>
       <event_code>10301</event_code>
    <controlled_area_id>198b1cad-ab6f-4d21-a1fc-7ddde77c40c3</controlled_area_id>
    <controlled_area_name>test door</controlled_area_name>
</activity_event>
<activity_event>
       <id>585784<<id>3041956</id>
    <hostname>localhost.localdomain<    <hostname>server</hostname>
       <event_time>2016time>2023-0207-04T1121T14:5933:2736.078486-0807:00</event_time>
       <site_id>1</site_id>
       <activity_type>Port</activity_type>
       <device_id>CC720F00059C<id>DCA632E2365A</device_id>
       <device_name>FB 1<name>-FACTORY DEFAULT-</device_name>
       <device_type>Freedomtype>Identiv Bridge 1EG-Rdr2</R2 Supv</device_type>
       <port_name>LED 1<name>Port</port_name>
       <originator_id> id>DCA632E2365A: Controller Mode (Server Online: PRM)</originator_id>
       <originator_name/>
       <result>Set</result>
       <suite_id/>
       <user_id/>
       <first_name/>
       <last_name/>
       <card_number/>
       <snapshot_url/>
       <io_control/>
       <sent_to_ams>false</sent_to_ams>
       <event_code>10301</event_code>
    <controlled_area_id>d04407de-5991-41b4-8437-6d6a34a736f1</controlled_area_id>
    <controlled_area_name>Test door 2</controlled_area_name>
</activity_event>
</activity_events>
</activity_events_search>

Get a activity event record by id

GET     /api/activitylog/<id>                   

http://<ip address>:<api listening port>/api/activitylog/9655633045762

Result: 

Code Block
<activity_event>
       <id>965563<<id>3045762</id>
     <hostname>localhost.localdomain<   <hostname>server</hostname>
       <event_time>2016time>2023-0208-15T1004T16:5519:3122.446475-0807:00</event_time>
       <site_id>1</site_id>
       <activity_type>Card Access</activity_type>
       <device_id>CC720F00059C<id>E45F0153B9B2</device_id>
       <device_name>FB 1<name>EG-2 prod key</device_name>
       <device_type>Freedomtype>Primis Bridge 1-RdrRdr</R2 Supv</device_type>
       <port_name>Reader 1<2</port_name>
       <originator_id>Edmonton_ADUser_02, Edmonton_ADUser_02:3070400000467;Group:admin group, Area:Lobby<id>E45F0153B9B2: Controller Mode (Server Online: PRM);Raw:01CE01D4, BLen:26, CDef:Factory</originator_id>
       <originator_name>S-1-5-21-3760748383-892082386-3578648945-113886</originator_name>
    <result>Granted</result>
   name>Unknown</originator_name>
    <result>Denied - Unknown Card</result>
    <suite_id/>
       <user_id>S-1-5-21-3760748383-892082386-3578648945-113886</user_id>
    <first_name>Edmonton_ADUser_02</first_name>
    <last_name>Edmonton_ADUser_02<id/>
    <first_name/>
    <last_name>Unknown user</last_name>
       <card_number>3070400000467<number>23100234</card_number>
       <snapshot_url/>
       <io_control>1</io_control>
   control/>
    <sent_to_ams>false</sent_to_ams>
       <event_code>10101<code>10218</event_code>
    <controlled_area_id>a825521d-caf1-4460-b617-ded8cf7621cc</controlled_area_id>
    <controlled_area_name>Door-EG</controlled_area_name>
</activity_event>

System Events

This chapter describes how to retrieve System events through the FREEDOM PRIMIS API software.

Element Name

Type

Description

Comments

id

integer

Unique identifier for an system event

 

hostname

string max 50

characters

Hostname of the server which logged the event

 

event_time

datetime

Timestamp of the event

 

site_id

string maximum 36

characters

The identifier of the site

This element is searchable

category

string max 20 characters

Category of the system event

Supported values are: System, Device, Network, Port, User, Floor, Door, Database, Credential, Ldap, Logon/Logoff, Operator Action and Video
This element is searchable

event_code

integer

Event code identifying events

This element is searchable

severity

string max 20 characters

Severity level of the event

Supported values are: Info, Warning, Error, Critical, Alert and Emergency
This element is searchable

activity_type

string max 50 characters

Event type of the event

Supported values are: UNKNOWN, ALARM, MESSAGE, DEBUG and ALARM CLEARED.
This element is searchable

controlled_area

string max 255

characters

Name of the controlled area

This element is searchable

device_id

string max 100 characters

The identifier of the device

This element is searchable

device_name

string max 100 characters

Name of the device

This element is searchable

suite_id

string max 50 characters

The identifier of the suite

This element is searchable

card_number

string max 100 characters

Card number of the user

This element is searchable

snapshot_url

string max 50 characters

URL of the photo snapshot

This element is searchable

result

string max 100 characters

The result of the event

This element is searchable

event_info

string max 2000 characters

The detail information of the event

This element is searchable

instruction_id

integer

The identifier of the instruction

 

acknowledge_required

boolean(true/false)

Flag to indicate if operator acknowledgement is required

 

transaction_id

integer

The transaction id of the event. The same transaction id will be assigned to related system events.

This element is searchable

sent_to_ams

boolean(true/false)

Flag to indicate if the event has been sent to AMS

 

List all system events

GET     /api/systemlog

http://<ip address>:<api listening port>/api/systemlog

...

Code Block
<system_events>
<system_event>
    <id>519809</id>
    <hostname>localhost.localdomain</hostname>
    <event_time>2016-02-04T11:46:08.764-08:00</event_time>
    <site_id>1</site_id>
    <category>Ldap</category>
    <event_code>23020</event_code>
    <severity>Error</severity>
    <activity_type>ALARM</activity_type>
    <controlled_area/>
    <device_id/>
    <device_name/>
    <suite_id/>
    <card_number/>
    <snapshot_url/>
    <result/>
    <event_info>LDAP update user Edmonton_ADUser_8156 Edmonton_ADUser_8156(S-1-5-21-3760748383-892082386-3578648945-122040) error: duplicate carddata: 3070400000000</event_info>
    <instruction_id>0</instruction_id>
    <acknowledge_required>false</acknowledge_required>
    <transaction_id>0</transaction_id>
    <sent_to_ams>false</sent_to_ams>
</system_event>
<system_event>
    <id>519810</id>
    <hostname>localhost.localdomain</hostname>
    <event_time>2016-02-04T11:46:08.767-08:00</event_time>
    <site_id>1</site_id>
    <category>Ldap</category>
    <event_code>23020</event_code>
    <severity>Error</severity>
    <activity_type>ALARM</activity_type>
    <controlled_area/>
    <device_id/>
    <device_name/>
    <suite_id/>
    <card_number/>
    <snapshot_url/>
    <result/>
    <event_info>LDAP update user Edmonton_ADUser_7925 Edmonton_ADUser_7925(S-1-5-21-3760748383-892082386-3578648945-121809) error: duplicate carddata: 3070400000000</event_info>
    <instruction_id>0</instruction_id>
    <acknowledge_required>false</acknowledge_required>
    <transaction_id>0</transaction_id>
    <sent_to_ams>false</sent_to_ams>
</system_event>
</system_events>

Retrieve a range of system events

GET     /api/systemlog?offset=<offset>&n=<limit>

...

http://<ip address>:<api listening port>/api/systemlog?offset=100&n=50

Search system events with filtering criteria

GET     /api/systemlog/search

...

Code Block
<system_events_search>
<criteria>
severity_level=Error,
</criteria>
<system_events results="100">
<system_event>
    <id>519809</id>
    <hostname>localhost.localdomain</hostname>
    <event_time>2016-02-04T11:46:08.764-08:00</event_time>
    <site_id>1</site_id>
    <category>Ldap</category>
    <event_code>23020</event_code>
    <severity>Error</severity>
    <activity_type>ALARM</activity_type>
    <controlled_area/>
    <device_id/>
    <device_name/>
    <suite_id/>
    <card_number/>
    <snapshot_url/>
    <result/>
    <event_info>LDAP update user Edmonton_ADUser_8156 Edmonton_ADUser_8156(S-1-5-21-3760748383-892082386-3578648945-122040) error: duplicate carddata: 3070400000000</event_info>
    <instruction_id>0</instruction_id>
    <acknowledge_required>false</acknowledge_required>
    <transaction_id>0</transaction_id>
    <sent_to_ams>false</sent_to_ams>
</system_event>
<system_event>
    <id>519810</id>
    <hostname>localhost.localdomain</hostname>
    <event_time>2016-02-04T11:46:08.767-08:00</event_time>
    <site_id>1</site_id>
    <category>Ldap</category>
    <event_code>23020</event_code>
    <severity>Error</severity>
    <activity_type>ALARM</activity_type>
    <controlled_area/>
    <device_id/>
    <device_name/>
    <suite_id/>
    <card_number/>
    <snapshot_url/>
    <result/>
    <event_info>LDAP update user Edmonton_ADUser_7925 Edmonton_ADUser_7925(S-1-5-21-3760748383-892082386-3578648945-121809) error: duplicate carddata: 3070400000000</event_info>
    <instruction_id>0</instruction_id>
    <acknowledge_required>false</acknowledge_required>
    <transaction_id>0</transaction_id>
    <sent_to_ams>false</sent_to_ams>
</system_event>
</system_events>

Get a system event record by id

GET     /api/systemlog/<id>                   

...

Code Block
<system_event>
    <id>519810</id>
    <hostname>localhost.localdomain</hostname>
    <event_time>2016-02-04T11:46:08.767-08:00</event_time>
    <site_id>1</site_id>
    <category>Ldap</category>
    <event_code>23020</event_code>
    <severity>Error</severity>
    <activity_type>ALARM</activity_type>
    <controlled_area/>
    <device_id/>
    <device_name/>
    <suite_id/>
    <card_number/>
    <snapshot_url/>
    <result/>
    <event_info>LDAP update user Edmonton_ADUser_7925 Edmonton_ADUser_7925(S-1-5-21-3760748383-892082386-3578648945-121809) error: duplicate carddata: 3070400000000</event_info>
    <instruction_id>0</instruction_id>
    <acknowledge_required>false</acknowledge_required>
    <transaction_id>0</transaction_id>
    <sent_to_ams>false</sent_to_ams>
</system_event>

...

GLOSSARY

TERM

DEFINITION

Access Group

Access Group is the logical grouping of users which you can assign Access Right to.

Access Right

The access right assigned to an Access Group. Access Right defines the access permission to a controlled area under a time schedule.

Administrator

An individual who is responsible for the maintenance and implementation of access control rights involving tasks such as issuing, and closing user accounts; tracking users and their respective access authorizations; and managing these functions.

CA Certificate

The certificate of a Certificate Authority which issues digital certificates.

Card

The access card issued to a user. It can be a Wiegand card or a PIV card.

Certificate

The digital certificate of an entity or User.

Controlled Area

Controlled Area is an area being controlled by one or more input or output devices such as

Freedom

Primis Bridge readers.

Credential

The credential information of the PIV card.

Image

The digital image of a User.

IP Address

An IP address is a unique identifier for a computer or device on an Internet protocol network.
Every computer and mobile device whether it be a laptop, tablet, smart phone, printer, modem, router, server or scanner requires an IP address to connect to the Internet. IP addresses consist of four sets of numbers from 0 to 255, separated by three dots.

PIV Card

A physical identity card, smart card issued to an individual that contains stored identity credentials such as a photograph, cryptographic keys, digitized fingerprint representation to verify the identity of the cardholder by a process or individual.

Schedule

A schedule is a given period of time that is applied to Controlled Areas and Access Groups and used to schedule device activation and alarms.

Site

A geographical grouping of controlled area(s).

User

An individual whose access privilege to controlled areas are managed by

FREEDOM

PRIMIS.

Zone Group

Zone Group is a logical grouping of Controlled Areas.