Connected Devices/Projects/Project Link/Taxonomy: Difference between revisions

From MozillaWiki
Jump to navigation Jump to search
(→‎Channels: + Mucho documentation)
(Changing TOC.)
Line 1: Line 1:
== Taxonomy Documentation ==
= Taxonomy Documentation =
Github Link: http://fxbox.github.io/taxonomy/doc/foxbox_taxonomy/index.html
Github Link: http://fxbox.github.io/taxonomy/doc/foxbox_taxonomy/index.html


== Current REST API Examples ==
= Current REST API =


=== Account ===
== Account ==
* To create account:
* To create account:
** POST http://localhost:3000/users/setup {"email": "a@b.com","username":"admin","password": "00000000"}
** POST http://localhost:3000/users/setup {"email": "a@b.com","username":"admin","password": "00000000"}
Line 10: Line 10:
** POST http://localhost:3000/users/login (Header contains Authorization: Basic <base64 encode of username:password)
** POST http://localhost:3000/users/login (Header contains Authorization: Basic <base64 encode of username:password)


=== Service List ===
== Service List ==
Services may requested by selector. A service selector is an object with the following fields:
Services may requested by selector. A service selector is an object with the following fields:


Line 35: Line 35:
** GET http://localhost:3000/api/v1/services
** GET http://localhost:3000/api/v1/services


=== Channels ===
== Channels ==


Channels are designed to be used by selector.
Channels are designed to be used by selector.
Line 52: Line 52:




==== Fetching ====
=== Fetching ===


* Fetch values from all channels matching any of the selectors
* Fetch values from all channels matching any of the selectors
Line 62: Line 62:
** PUT http://localhost:3000/api/v1/channels/get [{"tags": "location: entrance", kind: "OpenClosed"}
** PUT http://localhost:3000/api/v1/channels/get [{"tags": "location: entrance", kind: "OpenClosed"}


==== Sending ====
=== Sending ===


* Send one values to all channels matching any of the selectors:
* Send one values to all channels matching any of the selectors:
Line 73: Line 73:
See http://fxbox.github.io/taxonomy/doc/foxbox_taxonomy/values/enum.Value.html for the full documentation on values.
See http://fxbox.github.io/taxonomy/doc/foxbox_taxonomy/values/enum.Value.html for the full documentation on values.


=== Time ===
= Specific services and channels =
== Time ==
* Get the current time
* Get the current time
** PUT http://localhost:3000/api/v1/channels/get {"id":"getter:timeofday.clock@link.mozilla.org"}
** PUT http://localhost:3000/api/v1/channels/get {"id":"getter:timeofday.clock@link.mozilla.org"}
Line 87: Line 88:
** POST http://localhost:3000/api/v1/services {"setters":[{"kind":{"adapter":"Adapter","kind":"snapshot","type": "Json", "vendor":"DLink"} }]}
** POST http://localhost:3000/api/v1/services {"setters":[{"kind":{"adapter":"Adapter","kind":"snapshot","type": "Json", "vendor":"DLink"} }]}


=== Tags ===
== Tags ==
* Assign Tags to a service
* Assign Tags to a service
** POST http://localhost:3000/api/v1/services/tags {"services":[{"id":"thinkerbell-root-service"}],"tags":["Living Room"] }
** POST http://localhost:3000/api/v1/services/tags {"services":[{"id":"thinkerbell-root-service"}],"tags":["Living Room"] }
Line 96: Line 97:
* Query all devices matching the tag
* Query all devices matching the tag
** POST http://localhost:3000/api/v1/services {"tags":["Living"]}
** POST http://localhost:3000/api/v1/services {"tags":["Living"]}
=== Recipe ===
== Recipe ==
* Send Recipe
* Send Recipe
* List available Recipes
* List available Recipes


=== WebPush ===
== WebPush ==
* Add push subscription
* Add push subscription
** PUT http://localhost:3000/api/v1/channels/set {"select": {"id": "setter:subscribe.webpush@link.mozilla.org"}, "value": {"Json": {“subscriptions”:[{“push_uri”:”http://push.service/t54wtresfesfd”,”public_key”:”base64_encoded_key”}]}}}
** PUT http://localhost:3000/api/v1/channels/set {"select": {"id": "setter:subscribe.webpush@link.mozilla.org"}, "value": {"Json": {“subscriptions”:[{“push_uri”:”http://push.service/t54wtresfesfd”,”public_key”:”base64_encoded_key”}]}}}

Revision as of 17:02, 1 April 2016

Taxonomy Documentation

Github Link: http://fxbox.github.io/taxonomy/doc/foxbox_taxonomy/index.html

Current REST API

Account

Service List

Services may requested by selector. A service selector is an object with the following fields:

  • (optional) string `id`: accept only a service with a given id;
  • (optional) string array of string `tags`: accept only services with all the tags in the array;
  • (optional) object or array of objects `getters` (see GetterSelector): accept only services with channels matching all the selectors in this array;
  • (optional) object or array of objects `setters` (see SetterSelector): accept only services with channels matching all the selectors in this array.

The GET accepts 0, 1 or an array of service selectors and will return all the services that match any of the selectors.

Example with 1 selector:

  • Get services with tag "location: kitchen" and channel kind "OvenTemperature"

Example with 2 selectors:

As a shortcut, providing no argument will locate all services:

Channels

Channels are designed to be used by selector.

A selector is an object with the following fields:

  • (optional) string id: accept only a channel with a given id;
  • (optional) string `service`: accept only channels of a service with a given id;
  • (optional) string|array of string `tags`: accept only channels with all the tags in the array;
  • (optional) string|array of string `service_tags`: accept only channels of a service with all the tags in the array;
  • (optional) string|object `kind` (see ChannelKind): accept only channels of a given kind.

While each field is optional, at least one field must be provided.

Generally, using an id is considered a bad idea, as this ties the application to a specific device, and this will fail if the device is replaced (consider that this is equivalent to using an IP address instead of a domain name).


Fetching


Example:

Sending

or

See http://fxbox.github.io/taxonomy/doc/foxbox_taxonomy/values/enum.Value.html for the full documentation on values.

Specific services and channels

Time

Camera

Tags

Recipe

  • Send Recipe
  • List available Recipes

WebPush