[JDEV] File transfer and Jabber

Jens Alfke jens at mac.com
Mon Apr 23 18:11:14 CDT 2001


On Monday, April 23, 2001, at 09:52 AM, mark at mjwilcox.com wrote:

> I think using Jabber to send files is a waste of bandwith and time.
> Look, email attachments were a bad thing.

Wow, I work on email in my day job and that's an unusual opinion I've 
never heard before, even from people who generally hate MIME.

> Attachments waste bandwith, disk space and you force every user
> who you send the message to, to consume network resources
> *even* if they don't want to.

First off, even with regard to email this is not true. Most mail clients 
nowadays let the recipient choose whether to download large attachments, 
either by limiting the size of a POP download or by using IMAP's more 
sophisticated mechanism to retrieve individual MIME bodies on demand.

Secondly, I definitely agree with you that in-band Jabber file transfer 
should never be driven by the sender. I said this very clearly and 
emphatically yesterday. The receiver should send <iq> queries to 
retrieve chunks of the attachment.

> Instead of sending actual data around
> the jabber network, send URLs to files on a Web server. If I want to
> read your file, I'll download it.

This is simply an accounting trick that wastes someone else's disk space 
and network bandwidth, namely the owner of the Web server. It's 
everything you said you hate about email enclosures except that you 
replace the word "SMTP" with "HTTP" (or "WebDAV"). They have to host the 
file for you, regardless of whether the recipient wants it, and if the 
recipient doesn't request the file immediately, the server has to hang 
onto it for some unknown period of time before getting rid of it, which 
incurs extra administrative overhead (they have to have some kind of 
daemon nuking expired files.)

Then we also have issues of preventing abuse by imposing quotas on 
users, which implies the Web server has to require you to log in to 
upload, which means you have to have Yet Another Damn Account somewhere. 
It also means that if you fill up your quota, you can't send any more 
files to anyone until the recipient of the last one hurries up and 
downloads the file ... and maybe she's watching TV instead, or 
downloading over a 14.4 modem, and you'll just have to wait the full 
half hour or whatever until the server expires the file and restores 
your quota.

It also doubles the time to send a file since the sender has to finish 
uploading it before the receiver can download it.

It also makes Jabber more confusing to set up and use. "I know you 
already have a Jabber account, but you can't send me a file until you 
also get an account on a WebDAV server and go through a preference panel 
in your client to tell Jabber about it..."

Have I rattled off enough reasons why this is a bad idea that doesn't 
actually help anything? Or should I take five minutes to come up with 
some more?

If people really, really insist on using an out-of-band mechanism to 
send files, please at least use one that isn't store-and-forward. As I 
said earlier, the sender and receiver can open a socket to a relay 
server and have the server stream the data across.  This imposes 
virtually no disk or CPU overhead on the relay server, and allows the 
file to be sent immediately without any forwarding delays.

—Jens
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: text/enriched
Size: 3659 bytes
Desc: not available
URL: <https://www.jabber.org/jdev/attachments/20010423/ff5b0786/attachment-0002.bin>


More information about the JDev mailing list