-
Notifications
You must be signed in to change notification settings - Fork 89
The Library
sprsquish edited this page Aug 12, 2010
·
1 revision
Running in this way will give the bare-metal library.
This is useful if you want to build a library with the ability to handle XMPP connections.
You’ll need to start either a Blather::Stream::Client
or Blather::Stream::Component
stream passing in the client to handle incoming stanzas, jid, password, host, and port. Host and port are optional and will default to the JID’s domain and 5222 respectively.
The stream object expects the handling client to provide a few methods:
-
post_init
will be called when the stream negotiation has finished and the connection is ready -
unbind
will be called when the stream is shutdown (via normal shutdown or stream error) -
receive_data
is sent all incoming stanzas or errors (the stream object will never raise an error. it simply passes an error into the handling client). -
jid=
is used withBlather::Stream::Client
to set the JID after resource binding
Here’s a very basic example:
require 'blather'
class HandlingClient
attr_accessor :jid
def post_init
#stream started
end
def unbind
#stream closed
end
def receive_data(stanza_or_error)
#handle incoming stanza or error
end
end
handler = HandlingClient.new
stream = Blather::Stream::Client.start handler, 'echo@jabber.local', 'echo'