Difference between revisions of "Rifidi App API"

From RifidiWiki

Jump to: navigation, search
(get application properties command example)
(get application properties command example)
Line 142: Line 142:
 
==get application properties command example==
 
==get application properties command example==
  
*getAppProperties - returns a list of properties for an application
+
*getAppProperties/{appID} - returns a list of properties for an application
  
 
Request (via HTTP Post/Get) "getAppProperties" command like this:
 
Request (via HTTP Post/Get) "getAppProperties" command like this:
  
http://localhost:8111/getAppProperties/7
+
Response success:
  
Response:
+
http://localhost:8111/getAppProperties/10
  
 
<pre>
 
<pre>
 
<?xml version="1.0" encoding="UTF-8"?>
 
<?xml version="1.0" encoding="UTF-8"?>
 
<response>
 
<response>
   <apps>
+
   <attributes>
       <app>
+
       <entry>
         <id>AppService:ReadZones</id>
+
         <key>RecentTagTimeout</key>
        <number>0</number>
+
         <value>1 min</value>
        <status>STARTED</status>
+
       </entry>
      </app>
+
       <entry>
      <app>
+
         <key>LazyStart</key>
        <id>AppService:SensorStatus</id>
+
         <value>false</value>
         <number>1</number>
+
       </entry>
        <status>STARTED</status>
+
  </attributes>
       </app>
+
</response>
       <app>
+
</pre>
         <id>RifidiManagement:RifidiManagementApp</id>
+
 
         <number>2</number>
+
Response fail (if there is no properties file in file system):
        <status>STARTED</status>
+
 
       </app>
+
http://localhost:8111/getAppProperties/3
      <app>
+
 
        <id>AppService:UniqueTagInterval</id>
+
<pre>
        <number>3</number>
+
<?xml version="1.0" encoding="UTF-8"?>
        <status>STARTED</status>
+
<response>
      </app>
+
  <message>Fail</message>
      <app>
+
  <description>Application properties file not found for groupName: AppService and appName: StableSet</description>
        <id>AppService:StableSet</id>
+
        <number>4</number>
+
        <status>STARTED</status>
+
      </app>
+
      <app>
+
        <id>AppService:LimitStableSet</id>
+
        <number>5</number>
+
        <status>STARTED</status>
+
      </app>
+
      <app>
+
        <id>AppService:UniqueTagBatchInterval</id>
+
        <number>6</number>
+
        <status>STARTED</status>
+
      </app>
+
      <app>
+
        <id>AppService:RSSI</id>
+
        <number>7</number>
+
        <status>STARTED</status>
+
      </app>
+
      <app>
+
        <id>Diagnostic:GPIO</id>
+
        <number>8</number>
+
        <status>STOPPED</status>
+
      </app>
+
      <app>
+
        <id>Diagnostic:Serial</id>
+
        <number>9</number>
+
        <status>STOPPED</status>
+
      </app>
+
      <app>
+
        <id>Diagnostic:Tags</id>
+
        <number>10</number>
+
        <status>STARTED</status>
+
      </app>
+
      <app>
+
        <id>Diagnostic:TagGenerator</id>
+
        <number>11</number>
+
        <status>STARTED</status>
+
      </app>
+
      <app>
+
        <id>Monitoring:ReadZones</id>
+
        <number>12</number>
+
        <status>STARTED</status>
+
      </app>
+
      <app>
+
        <id>Monitoring:Tags</id>
+
        <number>13</number>
+
        <status>STARTED</status>
+
      </app>
+
      <app>
+
        <id>Monitoring:SensorStatus</id>
+
        <number>14</number>
+
        <status>STARTED</status>
+
      </app>
+
  </apps>
+
 
</response>
 
</response>
 
</pre>
 
</pre>

Revision as of 20:05, 5 November 2014

Introduction

Starting in Rifidi 3.1, Rifidi Apps can now be manged via rest

Note: In order for the properties to take effect the associated Rifidi App will need to be stopped and started. This allows for more fine grain control of when properties should take effect (as opposed to having the apps restart dynamically as properties change while a app is running)

The operations available are:

  • Get/Stop/Start App
  • Get/Set Application and Group Properties
  • Get/Add Delete Readzones
  • Get/Set Readzone Properties

Command Example

Note: localhost can be substituted with IP address/Host name of Rifidi Edge Server. Port can be changed in Rifidi configuration

apps command example

  • apps - returns a list of available applications

Request (via HTTP Post/Get) "apps" command like this:

http://localhost:8111/apps

Response:

<?xml version="1.0" encoding="UTF-8"?>
<response>
   <apps>
      <app>
         <id>AppService:ReadZones</id>
         <number>0</number>
         <status>STARTED</status>
      </app>
      <app>
         <id>AppService:SensorStatus</id>
         <number>1</number>
         <status>STARTED</status>
      </app>
      <app>
         <id>RifidiManagement:RifidiManagementApp</id>
         <number>2</number>
         <status>STARTED</status>
      </app>
      <app>
         <id>AppService:UniqueTagInterval</id>
         <number>3</number>
         <status>STARTED</status>
      </app>
      <app>
         <id>AppService:StableSet</id>
         <number>4</number>
         <status>STARTED</status>
      </app>
      <app>
         <id>AppService:LimitStableSet</id>
         <number>5</number>
         <status>STARTED</status>
      </app>
      <app>
         <id>AppService:UniqueTagBatchInterval</id>
         <number>6</number>
         <status>STARTED</status>
      </app>
      <app>
         <id>AppService:RSSI</id>
         <number>7</number>
         <status>STARTED</status>
      </app>
      <app>
         <id>Diagnostic:GPIO</id>
         <number>8</number>
         <status>STOPPED</status>
      </app>
      <app>
         <id>Diagnostic:Serial</id>
         <number>9</number>
         <status>STOPPED</status>
      </app>
      <app>
         <id>Diagnostic:Tags</id>
         <number>10</number>
         <status>STARTED</status>
      </app>
      <app>
         <id>Diagnostic:TagGenerator</id>
         <number>11</number>
         <status>STARTED</status>
      </app>
      <app>
         <id>Monitoring:ReadZones</id>
         <number>12</number>
         <status>STARTED</status>
      </app>
      <app>
         <id>Monitoring:Tags</id>
         <number>13</number>
         <status>STARTED</status>
      </app>
      <app>
         <id>Monitoring:SensorStatus</id>
         <number>14</number>
         <status>STARTED</status>
      </app>
   </apps>
</response>

stopapp command example

  • stopapp/{appID} - stops a Rifidi Application

Request (via HTTP Post/Get) "stopapp" command like this:

http://localhost:8111/stopapp/2

Response:

<?xml version="1.0" encoding="UTF-8"?>
<response>
   <message>Success</message>
</response>

startapp command example

  • startapp/{appID} - starts a Rifidi Application

Request (via HTTP Post/Get) "startapp" command like this:

http://localhost:8111/startapp/2

Response:

<?xml version="1.0" encoding="UTF-8"?>
<response>
   <message>Success</message>
</response>

get application properties command example

  • getAppProperties/{appID} - returns a list of properties for an application

Request (via HTTP Post/Get) "getAppProperties" command like this:

Response success:

http://localhost:8111/getAppProperties/10

<?xml version="1.0" encoding="UTF-8"?>
<response>
   <attributes>
      <entry>
         <key>RecentTagTimeout</key>
         <value>1 min</value>
      </entry>
      <entry>
         <key>LazyStart</key>
         <value>false</value>
      </entry>
   </attributes>
</response>

Response fail (if there is no properties file in file system):

http://localhost:8111/getAppProperties/3

<?xml version="1.0" encoding="UTF-8"?>
<response>
   <message>Fail</message>
   <description>Application properties file not found for groupName: AppService and appName: StableSet</description>
</response>