-
Notifications
You must be signed in to change notification settings - Fork 9
Home
This contains introductory documentation on the SicsthSense Engine. Here you can find details on how to install, interact with and modify the code of SicsthSense. The code is all released under the Modified BSD License, so feel free to fork and modify.
Download the code:
git clone https://github.com/sics-iot/sicsthsense.git
In the downloaded sicsthsense
directory, use Maven (allowing automatic dependency management for the 3rd party libraries) to build it:
mvn package
There must be an SQL server running locally, we recommend MySQL, the database initialisation can be easily performed by applying the buildDB.sql file: cat buildDB.sql | mysql -u root -p
.
Run the packaged .jar file:
runJar.sh
or java -jar target/engine-*-SNAPSHOT.jar server 6sense.yml
Now you have the SicsthSense up and running! There should be an HTTP server running on port 8080. Visiting this with a web browser should confirm it. From here you may authenticate using OpenID or a username/password combination.
This Wiki also contains a breakdown of the codebase
The Engine is a Java implementation of a RESTful HTTP server representing the SicsthSense cloud presence.
It uses DropWizard, which is a distribution of popular Java frameworks (Jetty,Jersey, Jackson, JDBI, slf4j, etc.). Other external libraries used include: Atmosphere (for websockets). And a MySQL server for the data storage.
All entities in the SicsthSense system follow a RESTful resource orientated architecture. For example user 1 may be accessed from the URL: http://HOSTNAME:8080/users/1
The engine will then return a JSON representation of the user.
Similarly, that user's resources can be listed via GETing the URL:
http://HOSTNAME:8080/users/1/resources
or individual resources by appending their resource ID:
http://HOSTNAME:8080/users/1/resources/999
A new resource can be added by POSTing a JSON representation of a resource to the URL: http://HOSTNAME:8080/users/1/resources
, whereas they can be deleted by performing an HTTP DELETE request to their relevant URL: http://HOSTNAME:8080/users/1/resources/999
It is possible to modify the representation stored on the server by PUTing a new JSON representation of that resource. Alternatively a new resource may be created by POSTing a JSON representation of the new resource.
Resources contain Parsers that make sense of data and output Streams of data points. The parsers can simply be a JSON field path, allowing a given JSON field to be parsed as a datapoint from the incoming data and then stored in SicsthSense.
Data enters the system via SicsthSense receiving a POST or by it performing a Poll. Poll events can be scheduled by configuring the Resource. Simply specify the fields polling_url and polling_period, SicsthSense will then perform an HTTP GET on that url every period seconds.