view mod_json_streams.wiki @ 175:01fb5e97f22b

mod_json_streams: Added section for strophe.js plugin.
author Waqas Hussain <waqas20@gmail.com>
date Sat, 02 Apr 2011 05:13:54 +0500
parents c87bea8ab41a
children 8426db59abf0
line wrap: on
line source

#summary JSON Encodings for XMPP
#labels Stage-Beta

= Introduction =

This plugin encodes XMPP as JSON. This is an implementation of [http://xmpp.org/extensions/xep-0295.html XEP-0295: JSON Encodings for XMPP].

Simply loading this modules makes Prosody accept JSON for C2S streams (legacy XML clients are still supported).

For BOSH, it requires mod_bosh be loaded, and JSON should be directed to the `/jsonstreams` HTTP path.

JSON for S2S isn't supported due to the lack of a discovery mechanism, so we have left that disabled to stay compatible with legacy XML servers.

= Configuration =
Just add `"json_streams"` in your config's global `modules_enabled` list, for example:

{{{
modules_enabled = {
	...
	"json_streams";
}
}}}

= Strophe.js plugin =
We also developed a [http://prosody-modules.googlecode.com/hg/mod_json_streams/strophe.jsonstreams.js JSON streams plugin] for popular [http://code.stanziq.com/strophe strophe.js] library.

Just include it like this after including the strophe library, and your strophe-based client will be speaking JSON:
{{{
<script type="text/javascript" src="strophe.jsonstreams.js"></script>
}}}
Be sure to set the HTTP path to `/jsonstreams`. No other changes are required.

= Compatibility =
||0.8||Works||
||trunk||Works||

= Quirks =
 * This plugin does not currently work with Prosody's [http://prosody.im/doc/port_multiplexing port multiplexing] feature.