OT: perl mail problems
m.seaman at infracaninophile.co.uk
Sat Jan 28 16:13:40 UTC 2012
On 28/01/2012 13:39, Da Rock wrote:
> I know this is not exactly FreeBSD related, but I'm in need of a monk
> that can enlighten me on a sacred incantation to connect perl to an imap
> server using Mail::Box modules :) If it helps people sleep, its all
> running only on FreeBSD systems...
> I have googled and searched, and googled some more, and tested, and then
> went back to the drawing board and googled yet again... there is simply
> no clear answer out there. All the docs are very disjointed from my
> reckoning- with no clear direction that explains how you get from a-b.
> I have enabled a connection (I think - based on my tests and logs), but
> I cannot get further than that. I have a Mail::Box::Manager
> instantiated, and then I have to use Mail::Box::IMAP4 to open a
> connection to the server. From there I need to get a list of the folders
> available- and thats where I get stymied.
> All the docs are pop3 based, or maildir based, or mbox. The imap is very
> sketchy... and what is out there says to basically connect, and then
> there is a jump to folders and messages with no idea of what is involved
> in between. Although I did see one complete example with pop3, but it
> won't work for imap.
This is absolutely typical -- IMAP is frequently treated as
POP-with-extra-bits, which really makes no sense whatsoever. There's a
fundamental difference in behaviour to do with where the mail is
actually stored. Anything that works by connecting to an IMAP server
and downloading all the new messages to hold and read locally really is
missing the point.
> One of the biggest problems is the username confuses any other module
> method than the Mail::Box::IMAP4 - the syntax is user at domain, and so if
> I use Mail::Box::Manager it will compile it into a url form ie
> imap4://user@domain:firstname.lastname@example.org which it obviously barfs on and
> refuses to look beyond user at domain.
Yeah, IMAP4 doesn't do URL-style things itself, so this is a fiction
invented to appease the higher layers of Mail::Box. Unfortunately, '@'
is of syntactic significance to URL schemes, making it difficult to
incorporate usernames containing it.
Hmmm.... can you substitute a hex encoded character string in that
username? %40 should be the encoding for an @ character.
> I really seem to be missing something fundamental here. I'm only trying
> to create some tools which will handle some situations apparently only
> local to my systems, and improve my perl foo before I start creating
> modules of my own and testing mod_perl.
> If someone can help clear this up I'll be happy to communicate off list
> if that is necessary.
Is all the e-mail you have to deal with stored on your IMAP4 server? If
so, then using Mail::IMAPClient directly[*] might serve you better
rather than through the Mail::Box and Mail::Transport classes. However,
that's a much lower level interface and you'll need to be fairly au-fait
with RFC 3501. (That's not as bad as it sounds: all it boils down to is
finding what the command is called in the IMAP protocol when you want to
achieve a particular effect.)
One thing that I notice on a cursory reading of Mail::Box::IMAP4 is that
it seems to assume things about the behaviour of the IMAP message store
which aren't necessarily true for all different IMAP servers. (ICBW --
it was a /very/ cursory reading.) Usernames of the form
'name at example.com' are one of those things you can do with IMAP which
tend to come as a bit of a surprise to people used to other mailclient
[*] Mail::Box et al use Mail::IMAPClient behind the scenes.
Dr Matthew J Seaman MA, D.Phil. 7 Priory Courtyard
PGP: http://www.infracaninophile.co.uk/pgpkey Ramsgate
JID: matthew at infracaninophile.co.uk Kent, CT11 9PW
-------------- next part --------------
A non-text attachment was scrubbed...
Size: 267 bytes
Desc: OpenPGP digital signature
Url : http://lists.freebsd.org/pipermail/freebsd-questions/attachments/20120128/bd39ee17/signature.pgp
More information about the freebsd-questions