-
Notifications
You must be signed in to change notification settings - Fork 3
Configuration
Nicolas Himmelmann edited this page Jul 30, 2018
·
10 revisions
This section explains the layout of the JSON for a matching rule in detail.
{
"uuid" : "<string>",
"name" : "<string>",
"dateCreation" : <integer>,
"mimetypes" : ["<string>", "<string>", ...],
"sharingDomain" : <integer>,
"weekdays" : "<string>,
"timeStart" : "<integer>:<integer>",
"timeEnd" : "<integer>:<integer>",
"context" :
{
"location" :
{
"lat" : <double>,
"lng" : <double>
},
"radius" : <integer>,
"placetypes" : ["<string>", ...],
"activity" : "<string>",
"network" :
{
"wifi" :
{
"isWifiConnected" : <boolean>,
"wifiSsid" : "<string>",
"timestamp" : <integer>
},
"mobile" :
{
"isMobileConnected" : <boolean>,
"isMobileNetworkFast" : <boolean>,
"mobileNetworkType" : "<string>",
"timestamp" : <integer>
},
"timestamp" : <integer>
},
"noise" :
{
"sound_db_thresh" : <integer>,
"sound_rms_thresh" : <integer>
}
},
"filesize" : <integer>,
"decisions" :
[
{
"isSpecific": <boolean>,
"specificNodeId" : "<string>>,
"selectedType" : "<string>",
"minRadius" : <float>,
"maxRadius" : <float>,
"minBwUp" : <integer>,
"minBwDown" : <integer>
},
...
],
"isGlobal" : <integer>,
"storeMultiple" : <boolean>,
"replicationFactor" : <integer>
"delete": <boolean>
}
- uuid : This should be a globally unique identifier, e.g. a UUID
- name : A name for the rule which you can choose freely. Is displayed to the user in the demo app.
- dateCreation: Unix timestamp in seconds
- mimetypes: An array of mimetypes (e.g. "image/jpeg"), for which the rule should be applicable.
- sharingDomain: The sharing domain, under which the rule should be applicable. <1>=private or <0>=public or <-1>=both
- weekdays: Comma-separated list of weekdays at which the rule is valid. 1=monday, ..., 7=sunday" (e.g. "1,2,3,4,5")
- timeStart: The starting time, from which the rule is valid (format hh:mm, for example 09:00).
- timeEnd: The end time, until which the rule is valid (format hh:mm, for example 18:00).
-
context: The definitions of context for the rule. A rule is only valid, if a file is uploaded in these given context conditions. All of the following context type definitions are optional. This means, it is totally fine to only specify a location, or only certain place types.
-
location: Physical location context, based on latitude and longitude values.
- lat: The latitude of the location point
- lng: The longitude of the location point
- radius: The radius in meters around the location, in which the rule is valid.
-
placetypes: A list of place types/categories, in which the rule is valid. Supported types can be found in the PlaceType enumeration
vstore.framework.context.types.place.PlaceType
. -
activity: The user activity which must be given so that the rule is valid. Supported types can be found in the ActivityType enumeration
vstore.framework.context.types.activity
. -
network: Network context which must be given so that the rule is valid. Only one of the following context types should be set. If both are set, WiFi will be preferred.
-
wifi: A wifi network context
-
isWifiConnected:
true
, if WiFi is currently connected.false
, if not. - wifiSsid: The SSID of the wireless network the device is currently connected to.
- timestamp: The unix timestamp of the acquisition of this wifi context in milliseconds.
-
isWifiConnected:
-
mobile: A mobile network context
-
isMobileConnected:
true
, if the device is currently connected to a cellular network. -
isMobileNetworkFast:
true
, if the cellular network is fast (e.g. > 2G). - mobileNetworkType: The type of the cellular network the device is currently connected to (e.g. 2G, 3G, 3.5G, 4G)
- timestamp: The unix timestamp of the acquisition of this cellular context in milliseconds.
-
isMobileConnected:
- timestamp: The unix timestamp of the acquisition of this network context in milliseconds.
-
wifi: A wifi network context
-
noise: Definition of a noise context which must be given so that the rule is applicable.
- sound_db_thresh: The dB threshold for a noise measurement
- sound_rms_thresh: The RMS threshold for a noise measurement
- filesize: The minimum size in bytes a file must have so that the rule can be applied to it.
-
decisions: An array of decision layers, which are evaluated once a rule is executed.
-
isSpecific:
true
, if a file should be placed on a specific node when this decision layer is evaluated. -
specificNodeId: Only relevant, if
isSpecific
is set totrue
. In this case, it specifies the identifier of the specific storage node. -
selectedType: The type of the target storage node of this decision layer (for supported types, see the NodeType enumeration in
vstore.framework.node.NodeType
). - minRadius: The minimum radius, inside which a target node must be located (around the location of the context) that was given at the time the file was stored.
- maxRadius: The maximum radius, inside which a target node is allowed to be located (around the location of the context) that was given at the time the file was stored.
- minBwUp: The minimum upstream bandwidth of the target node in MBit/s.
- minBwDown: The minimum downstream bandwidth of the target node in MBit/s.
-
isSpecific:
-
isGlobal:
true
, if the rule is a globally system-defined rule (not user-editable).false
, if the rule should be editable by the user. -
storeMultiple:
true
, if the framework should store a file, which was matched using this rule, on multiple storage nodes based on the decision layers.false
, if only one node should be used. - replicationFactor: The maximum number of replication for a file placed using this rule and its decision layers.
-
delete:
true
, if this rule should be deleted from a device once it reads the JSON configuration.false
, if not.
-
location: Physical location context, based on latitude and longitude values.
[
{
"uuid" : "string"
"url" : "string",
"port" : integer,
"type" : "string",
"location" : [double, double],
"bandwidthDown" : integer,
"bandwidthUp" : integer
},
...
]