/usr/share/perl5/AnyEvent/XMPP/Ext.pm is in libanyevent-xmpp-perl 0.55-4.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 | package AnyEvent::XMPP::Ext;
no warnings;
use strict;
use AnyEvent::XMPP::Namespaces qw/xmpp_ns/;
use base qw/Object::Event/;
=head1 NAME
AnyEvent::XMPP::Ext - Extension baseclass and documentation
=head1 DESCRIPTION
This module also has documentation about the supported extensions
and also is a base class for all extensions that can be added
via the C<add_extension> method of the classes that derive from
L<AnyEvent::XMPP::Extendable>. (That are: L<AnyEvent::XMPP::Client>,
L<AnyEvent::XMPP::Connection> and L<AnyEvent::XMPP::IM::Connection>)
=head1 Methods
=over 4
=item B<disco_feature>
This method can be overwritten by the extension and should return
a list of namespace URIs of the features that the extension enables.
=cut
sub disco_feature {
}
sub disco_feature_standard {
(
xmpp_ns ('data_form'),
)
}
=back
=head1 Supportet extensions
This is the list of supported XMPP extensions:
=over 4
=item XEP-0004 - Data Forms (Version 2.8)
This extension handles data forms as described in XEP-0004.
L<AnyEvent::XMPP::Ext::DataForm> allows you to construct, receive and
answer data forms. This is neccessary for all sorts of things in XMPP.
For example XEP-0055 (Jabber Search) or also In-band registration.
=item XEP-0030 - Service Discovery (Version 2.3)
This extension allows you to send service discovery requests and
define a set of discoverable information. See also L<AnyEvent::XMPP::Ext::Disco>.
=item XEP-0054 - vcard-temp (Version 1.1)
This extension allows the retrieval and storage of XMPP vcards
as defined in XEP-0054. It is implemented by L<AnyEvent::XMPP::Ext::VCard>.
=item XEP-0066 - Out of Band Data (Version 1.5)
This extension allows to receive and send out of band data URLs
and provides helper functions to handle jabber:x:oob data.
See also L<AnyEvent::XMPP::Ext::OOB>.
=item XEP-0077 - In-Band Registration (Version 2.2)
This extension lets you register new accounts "in-band".
For details please take a look at L<AnyEvent::XMPP::Ext::Registration>.
=item XEP-0078 - Non-SASL Authentication (Version 2.3)
After lots of sweat and curses I implemented finally iq auth.
Unfortunately the XEP-0078 specifies things that are not implemented,
in fact the only server that worked was openfire and psyced.org.
So I de-analyzed the iq auth and now it just barfs the IQ set out
on the stream with the username and the password.
If you insist on XEP-0078 behaviour enable the C<anal_iq_auth> option
when creating the stream.
You can also completely disable iq auth, well, just see the documentation
of L<AnyEvent::XMPP::Connection>
=item XEP-0082 - XMPP Date and Time Profiles (Version 1.0)
Implemented some functions to deal with XMPP timestamps, see L<AnyEvent::XMPP::Util>
C<to_xmpp_time>, C<to_xmpp_datetime>, C<from_xmpp_datetime>.
They are meant as simple formatters for you, you will still need to handle timezone
stuff and such yourself.
=item XEP-0086 - Error Condition Mappings (Version 1.0)
"A mapping to enable legacy entities to correctly handle errors from XMPP-aware entities."
This extension will enable sending of the old error codes when generating a stanza
error with for example the C<write_error_tag> method of L<AnyEvent::XMPP::Writer>.
Also if only the old numeric codes are supplied the L<AnyEvent::XMPP::Error::Stanza>
class tries to map the numeric codes to the new error conditions if possible.
=item XEP-0091 - Delayed Delivery (Version 1.3)
See also XEP-0203 below.
=item XEP-0092 - Software Version (Version 1.1)
The ability to answer to software version, name and operating system requests
and being able to send such requests is implemented in L<AnyEvent::XMPP::Ext::Version>.
=item XEP-0114 - Jabber Component Protocol (Version 1.5)
This extension allows you to connect to a server as a component
and makes it possible to implement services like pubsub, muc, or
whatever you can imagine (even gateways).
See documentation of L<AnyEvent::XMPP::Component> and the example
C<samples/simple_component>.
=item XEP-0153 - vCard-Based Avatars (Version 1.0)
This extension allows to store and retrive avatars from vcards.
On top of that it will also signal others that you support avatars and
that they might have changed. See L<AnyEvent::XMPP::Ext::VCard>.
=item XEP-0199 - XMPP Ping (Version 1.0)
You can send ping requests to other entities and also are
able to reply to them. On top of that the L<AnyEvent::XMPP::Ext::Ping>
extension implements a connection timeout mechanism based on this.
=item XEP-0203 - Delayed Delivery (Version 1.0)
Both delayed delivery XEPs are supported and are implemented by
L<AnyEvent::XMPP::IM::Delayed> which is a super class of L<AnyEvent::XMPP::IM::Message>
and L<AnyEvent::XMPP::IM::Presence>.
If you need to fetch delay from stanzas you caught yourself in an event you
can use a L<AnyEvent::XMPP::IM::Delayed> object to parse/fetch the delay out of the
L<AnyEvent::XMPP::Node>.
Use the functions described above in the XEP-0082 item to decode the timestamps
of delays.
=back
=head1 AUTHOR
Robin Redeker, C<< <elmex at ta-sa.org> >>, JID: C<< <elmex at jabber.org> >>
=head1 COPYRIGHT & LICENSE
Copyright 2007, 2008 Robin Redeker, all rights reserved.
This program is free software; you can redistribute it and/or modify it
under the same terms as Perl itself.
=cut
1; # End of AnyEvent::XMPP
|