Hello,

Along with the refactoring, can we begin
including tiny bits of IMAP support code
and marking those experiment, and turned
off by default?

I have been watching James's progress for
the last 3 years now, hoping for IMAP
support ( I can't use James without it )
and this seems like the only way IMAP is
going to ever get into main branch.  IMAP
support has been 'coming soon' for at
least those 3 years I've known of James.

Currently, I am looking at pulling the
IMAP code out of Foedus
[ http://sourceforge.net/projects/foedus ]
and maybe integrating with MINA and using
that as a base for a simple IMAP only
server.  Alternatively, we can work
together.

Having IMAP locked away in its own
branch secludes the effort from the rest
of the project and I think that's at
least partly why it hasn't been done
yet.  That, and the fact that there
hasn't been an *authorative* detailed
plan on how to get that subproject
completed.

Regards,
Kervin



Stefano Bagnara wrote:
I'm planning a few changes in the main blocks and cleaning the assembly.

Here are a few example:

1) Remove unused dependecy from the current assembly: e.g.
org.apache.james.services.MailStore from
SMTPServer/RemoteManager/POP3Server,
org.apache.james.services.JamesConnectionManager from James,
org.apache.avalon.cornerstone.services.threads.ThreadManager from
JamesSpoolManager.

2) Deprecate/Remove unused methods from common interfaces: e.g. MailServer
provides 4 sendMails methods but only 1 is used from SMTPHandler and
MessageProcessor. The other 3 methods are always accessed via the
MailetContext interface (provided by the same component: James).

3) Remove the inboundSpool concept from the MailStore by promoting the
"inbound" SpoolRepository to a toplevel block that James and
JamesSpoolManager will depend on. 2 advantages: possibility to implement
multiple spoolmanagers with multiple spoolrepositories, limit the
interdependencies of components (the Spoolmanager does not need the full
MailStore but only the inbound spoolrepository).

4) Promote MailetLoader and MatcherLoader to block components: this allow us
to make them easily configurable and allow to limit the knowledge needed by
the SpoolManager (the spoolmanager itself does not need the MailetContext
knowledge). To do that we need to change the Loaders to be Serviceable and
to remove the MailetContext parameter from the load calls.

5) More to come....
I would like to know if any committer is against this kind of changes.

The number 3, for example, will need minor config.xml changes (the inbound
spool conf moved outside the spoolmanager conf).

The others will be transparent for users that didn't change the assembly
(MOST users).

I will track every change with a JIRA issue and the consequent svn commit so
you can check my work.

Including internal "API" changes (as for number 2) is a point in favor of
3.0 instead 2.3.0 for the next release.

Stefano


---------------------------------------------------------------------
To unsubscribe, e-mail: [EMAIL PROTECTED]
For additional commands, e-mail: [EMAIL PROTECTED]






---------------------------------------------------------------------
To unsubscribe, e-mail: [EMAIL PROTECTED]
For additional commands, e-mail: [EMAIL PROTECTED]

Reply via email to