Skip to content
LiamMcNamara edited this page Oct 22, 2013 · 50 revisions

Welcome to the SicsthSense Wiki!

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.

Quick Start

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

Technology

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.

Interacting with the engine

Resource

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.

Clone this wiki locally