mirror of
https://codeberg.org/Mercury-IM/Smack
synced 2025-01-14 15:16:23 +01:00
236ea71cee
This is initial impementation of XEP-0332 (SMACK-552) - HTTP over XMPP transport. Created extensions, providers and unit tests. Two features are missing: jingle and sipub.
156 lines
6.1 KiB
HTML
156 lines
6.1 KiB
HTML
<html>
|
|
<head>
|
|
<title>HTTP over XMPP transport</title>
|
|
<link rel="stylesheet" type="text/css" href="style.css" />
|
|
</head>
|
|
|
|
<body>
|
|
|
|
<div class="header">HTTP over XMPP transport</div><p>
|
|
|
|
Allows to transport HTTP communication over XMPP peer-to-peer networks.<p>
|
|
|
|
<ul>
|
|
<li><a href="#disco">Discover HOXT support</a></li>
|
|
<li><a href="#iqexchange">IQ exchange</a></li>
|
|
</ul>
|
|
|
|
<hr>
|
|
|
|
<div class="subheader"><a name="disco">Discover HOXT support</a></div><p>
|
|
|
|
<b>Description</b><p>
|
|
|
|
Before using this extension you must ensure that your counterpart supports it also.</p>
|
|
|
|
<b>Usage</b><p>
|
|
|
|
<p>Once you have your <i><b>ServiceDiscoveryManager</b></i> you will be able to discover information associated with
|
|
an XMPP entity. To discover the information of a given XMPP entity send <b>discoverInfo(entityID)</b>
|
|
to your <i><b>ServiceDiscoveryManager</b></i> where entityID is the ID of the entity. The message
|
|
<b>discoverInfo(entityID)</b> will answer an instance of <i><b>DiscoverInfo</b></i> that contains
|
|
the discovered information.</p>
|
|
|
|
<b>Examples</b><p>
|
|
|
|
In this example we can see how to check if the counterpart supports HOXT: <br>
|
|
<blockquote>
|
|
<pre> <font color="#3f7f5f">// Obtain the ServiceDiscoveryManager associated with my XMPPConnection</font>
|
|
ServiceDiscoveryManager discoManager = ServiceDiscoveryManager.getInstanceFor(connection);
|
|
|
|
<font color="#3f7f5f">// Get the information of a given XMPP entity</font>
|
|
DiscoverInfo discoInfo = discoManager.discoverInfo("juliet@capulet.com");
|
|
|
|
<font color="#3f7f5f">// Check if room is HOXT is supported</font>
|
|
discoInfo.containsFeature("urn:xmpp:http");
|
|
</pre>
|
|
</blockquote>
|
|
|
|
<hr>
|
|
|
|
<div class="subheader"><a name="iqexchange">IQ exchange</a></div><p>
|
|
|
|
<b>Description</b><p>
|
|
|
|
You can use IQ's to perform HTTP requests and responses.
|
|
This is applicable to relatively short requests and responses (due to limitation of XMPP message size).</p>
|
|
|
|
<b>Usage</b><p>
|
|
|
|
<p>First you need to register a <i><b>PacketListener</b></i> to be able to handle intended IQs.<p>
|
|
For the HTTP client you:
|
|
<ul>
|
|
<li>You create and send <i><b>HttpOverXmppReq</b></i> request.</li>
|
|
<li>Then you handle the <i><b>HttpOverXmppResp</b></i> response in your <i><b>PacketListener</b></i>.</li>
|
|
</ul>
|
|
|
|
For the HTTP server you:
|
|
<ul>
|
|
<li>You handle the <i><b>HttpOverXmppReq</b></i> requests in your <i><b>PacketListener</b></i>.</li>
|
|
<li>And create and send <i><b>HttpOverXmppResp</b></i> responses.</li>
|
|
</ul>
|
|
|
|
</p>
|
|
|
|
<b>Examples</b><p>
|
|
|
|
In this example we are HTTP client, so we send request (POST) and handle the response: <br>
|
|
<blockquote>
|
|
<pre> <font color="#3f7f5f">// register listener for IQ packets</font>
|
|
connection.addPacketListener(new IqPacketListener(), new PacketTypeFilter(IQ.class));
|
|
|
|
<font color="#3f7f5f">// create a request body</font>
|
|
String urlEncodedMessage = "I_love_you";
|
|
|
|
<font color="#3f7f5f">// create request</font>
|
|
HttpOverXmppReq.Req req = new HttpOverXmppReq.Req(HttpMethod.POST, "/mailbox");
|
|
req.setVersion("1.1");
|
|
|
|
<font color="#3f7f5f">// prepare headers</font>
|
|
Set<Header> set = new HashSet<Header>();
|
|
set.add(new Header("Host", "juliet.capulet.com"));
|
|
set.add(new Header("Content-Type", "application/x-www-form-urlencoded"));
|
|
set.add(new Header("Content-Length", Integer.toString(urlEncodedMessage.length())));
|
|
req.setHeaders(new HeadersExtension(set));
|
|
|
|
<font color="#3f7f5f">// provide body or request (not mandatory, - empty body is used for GET)</font>
|
|
AbstractHttpOverXmpp.Text child = new AbstractHttpOverXmpp.Text(urlEncodedMessage);
|
|
AbstractHttpOverXmpp.Data data = new AbstractHttpOverXmpp.Data(child);
|
|
req.setData(data);
|
|
|
|
<font color="#3f7f5f">// create IQ packet</font>
|
|
HttpOverXmppReq packet = new HttpOverXmppReq();
|
|
packet.setReq(req);
|
|
packet.setTo("juliet@capulet.com/balcony");
|
|
packet.setType(IQ.Type.SET);
|
|
packet.setPacketID("42");
|
|
|
|
<font color="#3f7f5f">// send it</font>
|
|
connection.sendPacket(packet);
|
|
|
|
|
|
<font color="#3f7f5f">// then in your PacketListener</font>
|
|
private class IqPacketListener implements PacketListener {
|
|
|
|
@Override
|
|
public void processPacket(Packet packet) {
|
|
IQ iq = (IQ) packet;
|
|
|
|
<font color="#3f7f5f">// verify from and packed ID</font>
|
|
if (iq.getFrom().equals("juliet@capulet.com/balcony") && (iq.getPacketID().equals("42"))) {
|
|
|
|
<font color="#3f7f5f">// ensure it's not ERROR</font>
|
|
if (iq.getType().equals(IQ.Type.RESULT)) {
|
|
|
|
<font color="#3f7f5f">// check if correct IQ implementation arrived</font>
|
|
if (iq instanceof HttpOverXmppResp) {
|
|
HttpOverXmppResp resp = (HttpOverXmppResp) iq;
|
|
|
|
<font color="#3f7f5f">// check HTTP response code</font>
|
|
if (resp.getResp().getStatusCode() == 200) {
|
|
|
|
<font color="#3f7f5f">// get content of the response</font>
|
|
AbstractHttpOverXmpp.DataChild child = resp.getResp().getData().getChild();
|
|
|
|
<font color="#3f7f5f">// check which type of content of the response arrived</font>
|
|
if (child instanceof AbstractHttpOverXmpp.Xml) {
|
|
|
|
<font color="#3f7f5f">// print the message and anxiously read if from console ;)</font>
|
|
System.out.println(((AbstractHttpOverXmpp.Xml) child).getText());
|
|
} else {
|
|
<font color="#3f7f5f">// process other AbstractHttpOverXmpp.DataChild subtypes</font>
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
</pre>
|
|
</blockquote>
|
|
|
|
<hr>
|
|
|
|
</body>
|
|
|
|
</html>
|