| 1 |
NAME |
| 2 |
Net::XMPP2 - An implementation of the XMPP Protocol |
| 3 |
|
| 4 |
VERSION |
| 5 |
Version 0.01 |
| 6 |
|
| 7 |
SYNOPSIS |
| 8 |
use Net::XMPP2::Connection; |
| 9 |
|
| 10 |
or: |
| 11 |
|
| 12 |
use Net::XMPP2::IM::Connection; |
| 13 |
|
| 14 |
or: |
| 15 |
|
| 16 |
use Net::XMPP2::Client; |
| 17 |
|
| 18 |
DESCRIPTION |
| 19 |
This is the head module of the Net::XMPP2 XMPP client protocol (as |
| 20 |
described in RFC 3920 and RFC 3921) framework. |
| 21 |
|
| 22 |
Net::XMPP2::Connection is a RFC 3920 conformant "XML" stream |
| 23 |
implementation for clients, which handles tcp connect up to the resource |
| 24 |
binding. And provides low-level access to the XML nodes on the XML |
| 25 |
stream along with some high level methods to send the predefined XML |
| 26 |
stanzas. |
| 27 |
|
| 28 |
Net::XMPP2::IM::Connection is a more highlevel module, which is derived |
| 29 |
from Net::XMPP2::Connection. It handles all the instant messaging client |
| 30 |
functionality described in RFC 3921. |
| 31 |
|
| 32 |
Net::XMPP2::Client is a multi account client class. It manages |
| 33 |
connections to multiple XMPP accounts and tries to offer a nice |
| 34 |
highlevel interface to XMPP communication. |
| 35 |
|
| 36 |
For a list of "Supportet extensions" see below. |
| 37 |
|
| 38 |
There are also other modules in this distribution, for example: |
| 39 |
Net::XMPP2::Util, Net::XMPP2::Writer, Net::XMPP2::Parser and those I |
| 40 |
forgot :-) Those modules might be helpful and/or required if you want to |
| 41 |
use this framework for XMPP. |
| 42 |
|
| 43 |
See also Net::XMPP2::Writer for a discussion about the brokeness of XML |
| 44 |
in the XMPP specification. |
| 45 |
|
| 46 |
If you have any questions or seek for help look below under "SUPPORT". |
| 47 |
|
| 48 |
REQUIREMENTS |
| 49 |
One of the major drawbacks I see for Net::XMPP2 is the long list of |
| 50 |
required modules to make it work. |
| 51 |
|
| 52 |
AnyEvent |
| 53 |
For the I/O events and timers. |
| 54 |
|
| 55 |
XML::Writer |
| 56 |
For writing "XML". |
| 57 |
|
| 58 |
XML::Parser::Expat |
| 59 |
For parsing partial "XML" stuff. |
| 60 |
|
| 61 |
MIME::Base64 |
| 62 |
For SASL authentication |
| 63 |
|
| 64 |
Authen::SASL |
| 65 |
For SASL authentication |
| 66 |
|
| 67 |
Net::LibIDN |
| 68 |
For stringprep profiles to handle JIDs. |
| 69 |
|
| 70 |
Net::SSLeay |
| 71 |
For SSL connections. |
| 72 |
|
| 73 |
Net::DNS |
| 74 |
For SRV RR lookups. |
| 75 |
|
| 76 |
And yes, all these are essential for XMPP communication. Even thought |
| 77 |
'instant messaging' and 'presence' is a quite simple problem XMPP |
| 78 |
somehow was successful at complicating the task enough to keep me busy |
| 79 |
for a long time. But all that time wasn't only for the technology |
| 80 |
required to get it started, mostly it was for all the quirks, hacks and |
| 81 |
badly applied "XML" in the protocol which complicated the matter. |
| 82 |
|
| 83 |
RELEASE NOTES |
| 84 |
Here are some notes to the releases (release of this version is at top): |
| 85 |
|
| 86 |
Version |
| 87 |
* 0.01 |
| 88 |
This release has beta status. The code is already used daily in my |
| 89 |
client and I keep looking out for bugs. If you find undocumented, |
| 90 |
missing or faulty code/methods please drop me a mail! See also |
| 91 |
"BUGS" below. |
| 92 |
|
| 93 |
Potential edges when using this module: sparely documented methods, |
| 94 |
missing functionality and generally bugs bugs and bugs. Even thought |
| 95 |
this module is in daily usage there are still lots of cases I might |
| 96 |
have missed. |
| 97 |
|
| 98 |
For the next release I'm planning to provide more examples in the |
| 99 |
documentation and/or samples/ directory, along with bugfixes and |
| 100 |
enhancements along with some todo items killed from the TODO file. |
| 101 |
|
| 102 |
TODO |
| 103 |
There are still lots of items on the TODO list (see also the TODO file |
| 104 |
in the distribution of Net::XMPP2). |
| 105 |
|
| 106 |
Why (yet) another XMPP module? |
| 107 |
The main outstanding feature of this module in comparsion to the other |
| 108 |
XMPP (aka Jabber) modules out there is the support for AnyEvent. |
| 109 |
AnyEvent permits you to use this module together with other I/O event |
| 110 |
based programs and libraries (ie. Gtk2 or Event). |
| 111 |
|
| 112 |
The other modules could often only be integrated in those applications |
| 113 |
or librarys by using threads. I decided to write this module because I |
| 114 |
think CPAN lacks an event based XMPP module. Threads are unfortunately |
| 115 |
not an alternative in Perl at the moment due the limited threading |
| 116 |
functionality they provide and the global speed hit. I also think that a |
| 117 |
simple event based I/O framework might be a bit easier to handle than |
| 118 |
threads. |
| 119 |
|
| 120 |
Another thing was that I didn't like the APIs of the other modules. In |
| 121 |
Net::XMPP2 I try to provide low level modules for speaking XMPP as |
| 122 |
defined in RFC 3920 and RFC 3921 (see also Net::XMPP2::Connection and |
| 123 |
Net::XMPP2::IM::Connection). But I also try to provide a high level API |
| 124 |
for easier usage for instant messaging tasks and clients (eg. |
| 125 |
Net::XMPP2::Client). |
| 126 |
|
| 127 |
A note about TLS |
| 128 |
This module also supports TLS, as the specification of XMPP requires an |
| 129 |
implementation to support TLS. |
| 130 |
|
| 131 |
There are maybe still some bugs in the handling of TLS in |
| 132 |
Net::XMPP2::Connection. So keep an eye on TLS with this module. If you |
| 133 |
encounter any problems it would be very helpful if you could debug them |
| 134 |
or at least send me a detailed report on how to reproduce the problem. |
| 135 |
|
| 136 |
(As I use this module myself I don't expect TLS to be completly broken, |
| 137 |
but it might break under different circumstances than I have here. Those |
| 138 |
circumstances might be a different load of data pumped through the TLS |
| 139 |
connection.) |
| 140 |
|
| 141 |
I mainly expect problems where aviable data isn't properly read from the |
| 142 |
socket or written to it. You might want to take a look at the |
| 143 |
"debug_send" and "debug_recv" events in Net::XMPP2::Connection. |
| 144 |
|
| 145 |
Supportet extensions |
| 146 |
See Net::XMPP2::Ext for a list. |
| 147 |
|
| 148 |
EXAMPLES |
| 149 |
See "samples/test_client" for a first pointer. More examples will be |
| 150 |
included in later releases, please feel free to ask the "AUTHOR" if you |
| 151 |
have any questions about the API. There is also an IRC channel, see |
| 152 |
"SUPPORT". |
| 153 |
|
| 154 |
AUTHOR |
| 155 |
Robin Redeker, "<elmex at ta-sa.org>", JID: "<elmex at jabber.org>" |
| 156 |
|
| 157 |
BUGS |
| 158 |
Please note that I'm currently (July 2007) the only developer on this |
| 159 |
project and I'm very busy with my studies in Computer Science in Summer |
| 160 |
2007. If you want to ease my workload or want timely releases please |
| 161 |
send me patches instead only bug reports or feature requests. I won't |
| 162 |
forget the reports or requests if you can't or didn't send patches but |
| 163 |
it can take a long time until I get enough time to fix/implement them. |
| 164 |
|
| 165 |
Also try to be as precise as possible with bugreports and best, if you |
| 166 |
can't send a patch, would be if you find out which code doesn't work and |
| 167 |
tell me why. |
| 168 |
|
| 169 |
Please report any bugs or feature requests to "bug-net-xmpp2 at |
| 170 |
rt.cpan.org", or through the web interface at |
| 171 |
<http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Net-XMPP2>. I will be |
| 172 |
notified, and then you'll automatically be notified of progress on your |
| 173 |
bug as I make changes. |
| 174 |
|
| 175 |
SUPPORT |
| 176 |
You can find documentation for this module with the perldoc command. |
| 177 |
|
| 178 |
perldoc Net::XMPP2 |
| 179 |
|
| 180 |
You can also look for information at: |
| 181 |
|
| 182 |
* IRC: Net::XMPP2 IRC Channel |
| 183 |
IRC Network: http://freenode.net/ |
| 184 |
Server : chat.freenode.net |
| 185 |
Channel : #net_xmpp2 |
| 186 |
|
| 187 |
Feel free to join and ask questions! |
| 188 |
|
| 189 |
* Net::XMPP2 Project Site |
| 190 |
<http://www.ta-sa.org/> |
| 191 |
|
| 192 |
* AnnoCPAN: Annotated CPAN documentation |
| 193 |
<http://annocpan.org/dist/Net-XMPP2> |
| 194 |
|
| 195 |
* CPAN Ratings |
| 196 |
<http://cpanratings.perl.org/d/Net-XMPP2> |
| 197 |
|
| 198 |
* RT: CPAN's request tracker |
| 199 |
<http://rt.cpan.org/NoAuth/Bugs.html?Dist=Net-XMPP2> |
| 200 |
|
| 201 |
* Search CPAN |
| 202 |
<http://search.cpan.org/dist/Net-XMPP2> |
| 203 |
|
| 204 |
ACKNOWLEDGEMENTS |
| 205 |
Thanks to the XSF for the development of an open instant messaging |
| 206 |
protocol (even thought it uses "XML"). |
| 207 |
|
| 208 |
And thanks to all people who had to listen to my desperate curses about |
| 209 |
the brokeness/braindeadness of XMPP, without you I would've never |
| 210 |
brought this module to a usable state. |
| 211 |
|
| 212 |
COPYRIGHT & LICENSE |
| 213 |
Copyright 2007 Robin Redeker, all rights reserved. |
| 214 |
|
| 215 |
This program is free software; you can redistribute it and/or modify it |
| 216 |
under the same terms as Perl itself. |
| 217 |
|