Skip to content

The Jarvis Specification

bbaumgar edited this page Sep 22, 2014 · 23 revisions

This serves as a complete specification of the structure, organization, and functionality of Jarvis:

Overall Architecture

The application is separated into the Core and Modules.

-------------------------------------
| Core Application                  |
|                                   |
|  --------------    -------------  |
|  | Module #1  |    | Module #2 |  |
|  --------------    -------------  |
|                                   |
-------------------------------------`

While the Core has direct access to hardware, it is up to the untrusted 3rd-party modules to create useful data for the user. The Core is able to manage the permissions of each of these modules. Modules are able to chain together.

--------------
| Module #1  |
--------------
      |
      | (typed)
      |
      v
--------------
| Module #2  |
--------------

Module Structure

|- Module Directory
|--- Manifest File (package.json)
|--- Main File (index.html)
|--- Supporting JS/CSS Files

package.json example:

{
  "title": "GPS Module",
  "permissions": {
    "sensor": ["gps"]
  },
  "subscribed_events: [],
  "dependencies": [],
  "provided_events": [
    {
      "name": "GPS Data",
      "type_name": "gps",
      "fields": {
        "latitude": "float",
        "longitude": "float"
      }
    }
   ]},
  "description": "Produces GPS Data for other modules to consume.",
}

Events

Events signify the availability of data from a provider module or a notification of a real-world event. They could signal the completion of data processing on a server, the availability of GPS data, or the device's entrance into a geofenced area.

URIs

An event's data is accessible via a URI which describes the type of data and the timestamp at which it was made available. The user is able to select which modules' data are provided by default for each data type. For example, GPS events use the URI format: jarvis://gps/2014-09-22T05:29:33+00:00. If two modules are installed which create GPS events, the user selects his preferred GPS module and all GPS URIs route to the selected module.

Format:

{
 "id": “event-id”, // Unique id corresponding to the event type and name.
 "timestamp": “iso”, // Time at which the data was made available.
 "description": "Human-readable description of the event", 
 "URI": "jarvis://[datatype]/[timestamp]", // URI from which other modules can request data. 
 "type": "data " // Data type registered with the core. Must be in the module's provided types.
} 

Data Communications

All data in Jarvis is considered to be structured and typed. Since we are using JSON as the intermediary language between the Modules and the Core, typing becomes a matter of defining (key, value type) tuples that a module is interested in.

For example, in this snippet of data, a tuple of ("times_eaten", int) would match:

{ "times_eaten": 5 }

Our data type system allows for for data to conform to rules that only match a subset of its features. For example, the following data would match the rules ("latitude", float) ("longitude", float) despite the fact that it contains an extra field (altitude).

{
  "latitude":   64.3,
  "longitude": -37.5,
  "altitude":   -100,
}

If a module requested data matching the rules above, the fields not explicitly requested (altitude) would be stripped out.

Outside of the type system, all module-to-core and inter-module communications is handled by a Javascript API that allows information to flow into (and out of) the sandboxed iFrames that modules live in.

The following is a cursory list of expected API functions:

  • getData
  • publishData

Data Permissions

  • sensor - Access to a specific hardware sensor (possible values: gps, gyro, accelerometer).
  • network - Access to a specific network resources (e.g. https://*.google.com).
  • input_type - Access to a specific type of data as input.
  • output_type - Ability to export a type of data to other modules.

Where input and output type is in the form of a data type. Data types in JSON are specified as:

{
  "name": "GPS Data", // The human readable name shown to users when they want to assign a module to this data type.
  "type_name": "gps", // The unique name given to this type, used internally throughout Jarvis.
  "fields": { // An object of fields where the key is the field name and the value is the type of data stored in the field.
    "latitude": "float",
    "longitude": "float",
  }
}

A field is analogous to the idea of "tuple matching-rules" in the above sections.

Permissions may include other metadata in order to determine the quality of the data accessed.

For example, gps resolution:low frequency:4h can be used to show that the module only needs low resolution GPS data at a frequency of once every 4 hours.

Presentations

Clone this wiki locally