File

doc/example_component.lua @ 286:04b6c060ff01

plugins.carbons: Get and parse timestamp from carbon into a number.
author Kim Alvefur <zash@zash.se>
date Sat, 17 Mar 2012 15:59:43 +0100
parent 260:7f6df45a3d1f
line wrap: on
line source

local jid, password = "echo.localhost", "hellohello";

--os.execute("squish --minify-level=none verse");

require "verse".init("component");

c = verse.new(verse.logger())
c:add_plugin("version");
c:add_plugin("ping");

-- Add some hooks for debugging
c:hook("opened", function () print("Stream opened!") end);
c:hook("closed", function () print("Stream closed!") end);
c:hook("stanza", function (stanza) print("Stanza:", stanza) end);

-- This one prints all received data
c:hook("incoming-raw", print, 1000);

-- Print a message after authentication
c:hook("authentication-success", function () print("Logged in!"); end);
c:hook("authentication-failure", function (err) print("Failed to log in! Error: "..tostring(err.condition)); end);

-- Print a message and exit when disconnected
c:hook("disconnected", function () print("Disconnected!"); os.exit(); end);

-- Now, actually start the connection:
c.connect_host = "127.0.0.1"
c:connect_component(jid, password);

-- Catch binding-success which is (currently) how you know when a stream is ready
c:hook("ready", function ()
	print("Stream ready!");
	c.version:set{ name = "verse example component" };
end);

-- Echo, echo, echo, echo...
c:hook("stanza", function (stanza)
	stanza.attr.from, stanza.attr.to = stanza.attr.to, stanza.attr.from;
	c:send(stanza);
end)

print("Starting loop...")
verse.loop()