Web Intents is a discovery mechanism and extremely light-weight RPC system between web apps, modeled after the similarly-named system in Android. An Intent is an action to be performed by a provider. Intents provides a declarative syntax that allows providers to list the Intents they handle and a registration system that enumerates available providers. A client requests an Intent be handled, the User Agent allows the user to select which provider to use, and the provider performs the action of the Intent, possibly using data passed as input in the Intent. The provider may return data as output to the client.
To use today
No browsers currently support this API natively. To use this system simple drop the following code in to your site:
When browsers start to implement this natively the Shim will defer all its functionality to the native interface.
To register your service application to be able to handle image sharing simply declare an intent tag.
<intent action="http://webintents.org/share" type="image/*" />
This will register the current page's ability to share images.
To build a client application that can use the share functionality, it is as simple as using the following code:
var intent = new Intent( "http://webintents.org/share", "image/*", "http://upload.wikimedia.org/wikipedia/commons/thumb/f/f8/Three_jolly_kittens.png/800px-Three_jolly_kittens.png" ); window.navigator.startActivity(intent);
When a service is invoked via startActivity, the "intent" object on window will be populated with the data provided by the client.
To send data back to the client that invoked it, it is as simple as calling postResult() on the intent.
This will build and minify both the server and client components.
To run the server locally:
The server will not be set up on port 80 or webintents.org so will need to do the following:
1) Edit /etc/hosts - add the following "127.0.0.1 webintents.org" 2) Start nginx using using the configuration in https://github.com/PaulKinlan/WebIntents/tree/master/conf