We have previously developed such a component for an internal project using the component approach and a database - we used presence bcc to get all presence updates.<br><br>Somethings to keep in mind around freshness of presence information.<br>When the jabber server restarts - all your existing information in the DB is stale. You may want to detect this and purge the presence store. Similar cases arise when there is loss of connectivity between the component cases. User accounts may get deleted on the IM server and you may need to synchronize that on your database also.<br><br>Over time, I have found that such a presence server capability is best built "directly" into the IM server with tight integration with the presence processing and subscriber management modules. This way you benefit from privacy policies that are available in the same place.<br><br>YMMV.<br><br><br><b><i>Peter Saint-Andre <stpeter@jabber.org></i></b> wrote:<blockquote class="replbq"
style="border-left: 2px solid rgb(16, 16, 255); margin-left: 5px; padding-left: 5px;"> -----BEGIN PGP SIGNED MESSAGE-----<br>Hash: SHA1<br><br>+1, that seems like a sensible approach.<br><br>/psa<br><br>Peter Millard wrote:<br>> This is exactly how I would implement this as well.<br>> <br>> 1) Have an external component that uses iq:register protocol with<br>> x-data for picking themes, etc. This component subscribes to the<br>> user's presence during registration (just like a transport does). Now<br>> the component has the users presence.<br>> <br>> 2) External component pushes presence info into a database (mysql, psql, etc).<br>> <br>> 3) Write a quick PHP applet or something which returns an image based<br>> on the JID.<br>> <br>> We could easily deploy something like this on jabber.org provided the<br>> DB is psql, and the component is not in Java or Perl (for scalability<br>> issues). Seems like this would be super easy to write
using the<br>> Twisted Python jabber component stuff.<br>> <br>> This approach would also work with any server implementation since the<br>> component is subscribing to the user's presence.<br>> <br>> pgm.<br>> <br>> On 3/9/06, Richard Dobson <richard@dobson-i.net> wrote:<br>>>> It would be good if we had standardized methods for embedding presence<br>>>> information in web pages. For example, I'd like to be able to point to<br>>>> the following image file and have it show my presence:<br>>>><br>>>> <img src="http://www.jabber.org/users/stpeter.png"><br>>>><br>>>> Granted there are challenges here:<br>>>><br>>>> 1. Needs to be opt-in (no presence leaking)<br>>>><br>>> Have it as a contact on the users roster which represents the presence<br>>> service, if that contact can see the users presence the user is opting in.<br>>>> 2. User needs a way to
choose icon set (if there's a choice)<br>>>><br>>> x:data forms seems like a perfect fit here<br>>>> 3. Jabber server and web server need to share information<br>>>><br>>> Easiest way for this would be for them both to share a database of<br>>> presence information with a jabber component keeping it up to date.<br>>>> 4. Would not be dynamic (that would require an xmpp: URI)<br>>>><br>>>> At the jabber.org domain, #3 is a bit of a pain (the web server and<br>>>> jabber server are on different machines), but the challenge seems to be<br>>>> surmountable.<br>>>><br>>>> Other IM systems have this and it's one of those cool features that end<br>>>> users really like. So what's holding us back? What's needed to make this<br>>>> happen?<br>>>><br>>> Nothings holding us back this has been available for quite some time in<br>>> various forms on
jabber.<br>>><br>>> Richard<br>-----BEGIN PGP SIGNATURE-----<br>Version: GnuPG v1.4.1 (Darwin)<br>Comment: Using GnuPG with Mozilla - http://enigmail.mozdev.org<br><br>iD8DBQFEFbO0NF1RSzyt3NURAlbwAJ9rhSwaD893Ilo0PBqhg3oxgMWhjwCfR1de<br>J3rxkGox7XZ69OjJw4DANcc=<br>=4/tt<br>-----END PGP SIGNATURE-----<br></richard@dobson-i.net></blockquote><br>