Forums / Developer / Comments on Webmail wanted

Comments on Webmail wanted

Author Message

Gabriel Ambuehl

Monday 05 May 2003 11:49:39 am

After having made some reasonable progress with my calendar module I think I'll be taking on webmail.

But I have several questions before I start:
- Is anyone, maybe inside eZ?, already working on a webmail module?
- Mail storage. There are two basic possibilities for this: IMAP (in which case I'd use PEAR's IMAP module to avoid having cclient installed) or the SQL DB itself in which case you need to configure the mail server to feed data in there.

IMHO, IMAP makes more sense as it allows people to use other email clients as well (personally, I hate webmail, I only ever us e it when I'm traveling, otherwise I want to use my beloved TheBat) but then again, an SQL storage might be desirable from an administrative point of view (replication, storage, auditing and what not).

Of course, I'd appreciate any comments.

If going the IMAP route, how are the feelings about iframe'ing an existing webmail client (probably Squirrelmail which is by far the nicest one I've tried, the UI might be very 96'ish but it's fast and universally useable) with some modifications to allow for single logon? I think the GREAT advantage of that approach is that you can save tremendous amounts of server resources as there's no need for ezpublish to be invoked at all if the user is only using the webmail client.

Patching a fully fledged standalone solution to use templates seems like a nightmare as most people will still echo their content on a line by line basis which means that one would have to buffer the output somehow which is going to be a MAJOR PITA to be done right.

The other option is to write a template friendly client from scratch (or maybe look into the 2.2.8 client which might be storing its mails in a DB, I'm not entirely sure) which isn't exactly a one day project either, I had a shot at webmail clients years ago and gave up after a few hours as I didn't feel like writing a MIME decoder at the time, nowadays, those are available of the shelf.

Thoughts? Comments?

Visit http://triligon.org

Paulo Almeida

Monday 05 May 2003 2:36:16 pm

Hi

First, i want to thank you for your iniciative.

IMHO the webmail module should use IMAP because os quotas. Will you create a quota module? Even so, seen this example: everyone in a company had quota os 50MB of mail, except 10 guys with no quota limit and they save all their mail, this could be large GB of mail, I don't really know which option is the best. I still bet in IMAP.

Squirrelmail is fantastic (their plugins capacity is great), but his look is not very costumizable. Will addressbook be separated of ez :-( :-( ? Or create a plugin for squirrel to get addresses in and ez3 DB.

Best regard

Paulo Almeida

PACPI.COM Internet Consulting
http://pacpi.com

Gabriel Ambuehl

Monday 05 May 2003 2:56:42 pm

Quota should be implemented by the mailserver. Another point for an IMAP based solution.

Now I had my thoughts about the addressbook myself, ideally, we should standardize a form of contact DB first, probably built on top of of the content module.

Visit http://triligon.org

Paulo Almeida

Monday 05 May 2003 3:14:52 pm

Yes, i prefer imap, just because imap already has that implemented.

To addressbook I don't seen the necessity of create a fixed form, just create something like users module. The admin can create an class with attributes that he need, webmail module only need to know the first and second name, and email address, easilly addressed to an ini file (i think).
Or (even better) to create totally the contact module of ez2.2, we need an contact class, and an email class (to enable lots of email addresses per contact). With this webmail "search" all email nodes with that the contact as parent node (i hope you understand what i am talking about :-P ).

Paulo Almeida

PACPI.COM Internet Consulting
http://pacpi.com

Tony Wood

Monday 05 May 2003 3:39:53 pm

I don't want to sound negative, but is webmail worth it? Most people have their own preferred messaging again on their platform and Squirrel mail is top notch already.
I see the goal of a feedback enabled CMS such as eZ is to remove the need for work related emails. Most emails and IM are related to a subject so its better to keep the number of emails down and get feedback directly to the site.
Also most people will not use their webserver as a incoming MTA only outgoing as its more secure that way.

I don't see the need for webmail on an eZ site apart from notification messaging. Am i missing the point?

Tony

Tony Wood : twitter.com/tonywood
Vision with Technology
Experts in eZ Publish consulting & development

Power to the Editor!

Free eZ Training : http://www.VisionWT.com/training
eZ Future Podcast : http://www.VisionWT.com/eZ-Future

geovanni rosetto

Monday 05 May 2003 3:52:23 pm

Gabriel,
I like your initiative in writing solutions for eZ publish and contributing to this community.

Here are my thoughts about webmail.

>- Mail storage. There are two basic possibilities for this: IMAP (in which
>case I'd use PEAR's IMAP module to avoid having cclient installed) or the
>SQL DB itself in which case you need to configure the mail server to feed
>data in there.

Personally, I think any webmail client should be built around IMAP. Why? Collaboration, collaboration, collaboration! Why would you want to rebuilt the wheel?
Remember that "integration" is part of ONE unified system so, no matter where people are, they should always be able to get their messages anywhere. This includes all folders created in the user's mailbox (inbox, drafs, sent, deleted, subfolder, etc.) This could also make eZ publish appealing for other users to migrate over :P.

>If going the IMAP route, how are the feelings about iframe'ing an existing webmail
>client (probably Squirrelmail which is by far the nicest one I've tried, the UI might
>be very 96'ish but it's fast and universally useable)

The UI should be unified with eZ publish standard template system, so if people modify the "main" template in eZ publish the webmail UI should also change. Frames should not be used because it's not supported in all browsers, let your cell phone's Web browser read those framed pages. There is also an advantage in making plain vanilla HTML pages (CSS perhaps), for example when you want to notify users that they have 96 new messages in their inbox, you might want to show it like this on a left column: Inbox (96)
As the user clicks on a new message perhaps on the right side of the window, the whole page refreshes this way updating the inbox status to: Inbox (95).

>with some modifications to allow
>for single logon? I think the GREAT advantage of that approach is that you can save
>tremendous amounts of server resources as there's no need for ezpublish to be
>invoked at all if the user is only using the webmail client.

Solutions:
1. Liberty Alliance Project (http://www.projectliberty.org)
2. Add new tables to eZ publish database with this fields to be added by the user in their profile's page:

MAIL SERVER SETTINGS:

Incoming Mail Server (IMAP):
Outgoing Mail Server (SMTP): << You will need SMTP for sending mail, IMAP can't do this!
Username:
Password:

[SAVE SETTINGS] << Button

User's name and other info can be obtained from eZ publish default user table and auto-filled by the module, but open if the users want to change it later.

I really like your idea and I wish you good luck. I wish I help you code, but I am no programmer. If you need testers let me know.

Regards,

geo

Gabriel Ambuehl

Monday 05 May 2003 4:24:15 pm

Tony: As to the why: mostly because I'm bored. I ain't got anything real to do or well I have but thats so mind numbing that I need to have some balance at doing something that's halfway fun as I DO go mad if I haven't got something that keeps me busy (some say I've gone mad a long time ago but that's a different matter).

Basically, I think you're right about trying to build CRM features into ezpublish and I'll help anyone that really wants to have a take on it. However, at least in our case, email isn't going to go away anytime soon. Personally, I could care less for webbased email but essentially, I'm trying to build a solution that I could go selling when its reasonably progressed and a lot of people need email features.

As to not running an incoming MTA on the webserver, 100% agreed but there's no need for that, either.

Visit http://triligon.org

Gabriel Ambuehl

Monday 05 May 2003 4:36:25 pm

Geovanni:
That's the main reason why I'd go for IMAP, too. However, there are a certain things that I like about RDBMS backed mail storage, mostly easy audit and full text search. Then again if you do what Tony suggests and just build CRM features into ezpublish, that's mostly a moot point.

Actually, it might make sense to write a small script that parses mails and adds them into ezpublish for archiving purposes. When I come to think of it, that's probably what I'm gonna do next. It's reasonably straight forward (I have root access on all my servers so I can do whatever I want with my MTA, like piping mails into the scripts).

>The UI should be unified with eZ publish standard template >system, so if people modify the "main" template in eZ publish >the webmail UI should also change.

Not gonna happen. It's just too much work to get Squirrelmail to do that. If you want to do that, you're speaking about writing a webmail app from scratch. And I'm quite certain that I know why eZ didn't do that this time. I don't know whether you know Squirrelmail yourself, but that one does exactly what you mean WRT to sticking to HTML. It doesn't look very nice but it gets the job done. And it's fast if you're in some internet cafe that got a 33.6k uplink somewhere on the other side of the world. I happen to like to travel to distant places and there has been more than one occasion where I was thankful our webmail client was so lightweight.

projectliberty: I didnt like the Passport concept and I don't like a more open approach to the same either. In fact, I'm not gonna use sites that use that web wide single sign on crap. Bad enough they track my IP, they don't need to get force fed my data.

SMTP server is not needed, PHP's mail function takes care of that already.

User's realname, emailaddress, IMAP server/login/password can easily be stored as three new fields in the user class (first two are already there) and retrieved from there.

As to not using frames, there aren't any really useable webmail clients without them. If you want to read mail on your mobile, buy one that supports POP3 (Sony Ericsson t68i does an acceptable job, their P800 an outstanding one), WML is a seriously flawed technology and IMNSHO it's wasted time trying to render anything into WML as nobody is using it anyway.

 

Visit http://triligon.org

Gabriel Ambuehl

Monday 05 May 2003 4:41:41 pm

While it's 01:44 here, I'm currently heavily tending towards the following:

- Finalizing a format to store contacts inside the content module [1]. in order to enable the next step:
- Writing a plugin for Squirrelmail to allow the contact database to be used.

- A mail archive feature, that takes mail from STDIN, decodes MIME and stores it as appropriate content objects for further reference. Going from there, it should be quite trivial to allow user to reply to such mails, too. That's the basis of you're CRM then.

Additionally, I might do the single sign on thingy (if you're really lazy, you can always POST the login to the webmail client, not exactly secure but not too bad either if you disable caching).

[1] Any suggestions for a data structure are welcome. I have my ideas, nothing groundbreaking but if you have something truly unique, I'd like to hear.

Now off to bed ;-)

Visit http://triligon.org

geovanni rosetto

Monday 05 May 2003 5:29:28 pm

Gabriel:

>Actually, it might make sense to write a small script that parses mails and adds them
>into ezpublish for archiving purposes. When I come to think of it, that's probably
>what I'm gonna do next. It's reasonably straight forward (I have root access on all my
>servers so I can do whatever I want with my MTA, like piping mails into the scripts).

Huh?! Do you mean to add all your messages in eZ publish? What happened to whole concept of the mail server and have one centralized placed where all messages are saved? Doesn't the mail server do all the 'messaging'? Why not distribute the workload? You have to remember that eZ pulbish is a Content Management System not a Messaging System!

>Not gonna happen. It's just too much work to get Squirrelmail to do that.

I didn't know you were modifying (porting) SquirrelMail!!

>And I'm quite certain that I know why eZ didn't do that this time.

Actually, I think they didn't implement this because they didn't have the functionality written on time, but it's coming in version 3.1. Read it yourself...

eZ bulk mail
Requires some new functionality, which will be introduced in 3.1.

http://www.ez.no/developer/news/how_to_implement_ez_publish_22_functionality_in_30

>ProjectLiberty: Bad enough they track my IP, they don't need to get force fed my data.

I agree with you on this.

>SMTP server is not needed, PHP's mail function takes care of that already.

You're right. I forgot about this, but if the message could send to the mail server for delivery it would be much better. Plus a copy of the message will be sitting in the 'Sent' folder.

>User's realname, emailaddress, IMAP server/login/password can easily be stored as
>three new fields in the user class (first two are already there) and retrieved from there.

This is a good idea. :)

>If you want to read mail on your mobile, buy one that supports POP3 (Sony Ericsson t68i
>does an acceptable job, their P800 an outstanding one)

Do you think people are going to replace their mobile phone just because they don't a mail client on their phone?
Believe me, people take a lot of time to adapt to new technologies, and they are not going to buy the 'Sony Ericsson t68i'.

POP3? Again, why store your message elsewhere?

Regards,

geo

Tony Wood

Tuesday 06 May 2003 12:16:41 am

Gabriel,

I see your point :)
Go for it... I look forward to seeing the results...

Tony

Tony Wood : twitter.com/tonywood
Vision with Technology
Experts in eZ Publish consulting & development

Power to the Editor!

Free eZ Training : http://www.VisionWT.com/training
eZ Future Podcast : http://www.VisionWT.com/eZ-Future

Gabriel Ambuehl

Tuesday 06 May 2003 3:25:21 am

Geovanni:

As to storing the mails in ezpublish: that allows for centralized, eternal storage of all mails. In many companies I've worked with, mail was the primary medium where any information got entered, even very important stuff you want to have for future reference.

Knowing that their email is available for everyone will also stop employees from using company email accounts for private purposes which is a good thing as it means the company has less liability.

Furthermore, you definitely want to have a central mail storage for auditing purposes, we've encountered various cases where employees sent mails that were diametral to the companies interests and in court, a central DB will come in very handy.

This doesn't mean that the users won't be able to use POP3 or IMAP for their mail retrival if they want so. It's not even really the same feature, think of it as email archive integrated into ezpublish more than a messaging solution (though you could of course push it to be a messaging solution with some more work).

ezbulkmail: is a news letter system which is trivial compared to a good webmail client. Not what I'm working on in any case.

SMTP: mail() will already send mails to SMTP hosts if you want it to. I'm not going to reinvent the wheel here. As to storing messages in Sent, that's easily done.

Mobile mail retrieval: GPRS costs in Europe are outrageous so few people in my target market will even use their phone for mails. The ones who do, already have phones capable of doing so, the other ones can't be bothered. And then there are the ones like me who actually have phones that can act as email client but can't be bothered to work with such a small screen keyboard.

POP3 is also easily provided by running another daemon. Many environments will actually be running IMAP and POP3 side by side, accessing the same storage, not a problem at all.

Visit http://triligon.org

Dan Zembrosky

Wednesday 04 June 2003 1:28:47 am

I have no technical knowledge but I am looking forward to this and thank you greatly for the work.

eZ debug

Timing: Jan 18 2025 11:17:32
Script start
Timing: Jan 18 2025 11:17:32
Module start 'content'
Timing: Jan 18 2025 11:17:32
Module end 'content'
Timing: Jan 18 2025 11:17:33
Script end

Main resources:

Total runtime0.9899 sec
Peak memory usage4,096.0000 KB
Database Queries230

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0057 588.8281180.8359
Module start 'content' 0.00570.8222 769.6641823.4766
Module end 'content' 0.82790.1619 1,593.1406365.3125
Script end 0.9898  1,958.4531 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00460.4667210.0002
Check MTime0.00180.1775210.0001
Mysql Total
Database connection0.00090.090510.0009
Mysqli_queries0.872588.14072300.0038
Looping result0.00350.35022280.0000
Template Total0.957696.720.4788
Template load0.00220.221420.0011
Template processing0.955496.519320.4777
Template load and register function0.00020.024510.0002
states
state_id_array0.00100.102510.0010
state_identifier_array0.00080.083620.0004
Override
Cache load0.00220.22581380.0000
Sytem overhead
Fetch class attribute can translate value0.00230.235860.0004
Fetch class attribute name0.00150.1515150.0001
XML
Image XML parsing0.00160.157160.0003
class_abstraction
Instantiating content class attribute0.00000.0033170.0000
General
dbfile0.00450.4545330.0001
String conversion0.00000.000530.0000
Note: percentages do not add up to 100% because some accumulators overlap

CSS/JS files loaded with "ezjscPacker" during request:

CacheTypePacklevelSourceFiles
CSS0extension/community/design/community/stylesheets/ext/jquery.autocomplete.css
extension/community_design/design/suncana/stylesheets/scrollbars.css
extension/community_design/design/suncana/stylesheets/tabs.css
extension/community_design/design/suncana/stylesheets/roadmap.css
extension/community_design/design/suncana/stylesheets/content.css
extension/community_design/design/suncana/stylesheets/star-rating.css
extension/community_design/design/suncana/stylesheets/syntax_and_custom_tags.css
extension/community_design/design/suncana/stylesheets/buttons.css
extension/community_design/design/suncana/stylesheets/tweetbox.css
extension/community_design/design/suncana/stylesheets/jquery.fancybox-1.3.4.css
extension/bcsmoothgallery/design/standard/stylesheets/magnific-popup.css
extension/sevenx/design/simple/stylesheets/star_rating.css
extension/sevenx/design/simple/stylesheets/libs/fontawesome/css/all.min.css
extension/sevenx/design/simple/stylesheets/main.v02.css
extension/sevenx/design/simple/stylesheets/main.v02.res.css
JS0extension/ezjscore/design/standard/lib/yui/3.17.2/build/yui/yui-min.js
extension/ezjscore/design/standard/javascript/jquery-3.7.0.min.js
extension/community_design/design/suncana/javascript/jquery.ui.core.min.js
extension/community_design/design/suncana/javascript/jquery.ui.widget.min.js
extension/community_design/design/suncana/javascript/jquery.easing.1.3.js
extension/community_design/design/suncana/javascript/jquery.ui.tabs.js
extension/community_design/design/suncana/javascript/jquery.hoverIntent.min.js
extension/community_design/design/suncana/javascript/jquery.popmenu.js
extension/community_design/design/suncana/javascript/jScrollPane.js
extension/community_design/design/suncana/javascript/jquery.mousewheel.js
extension/community_design/design/suncana/javascript/jquery.cycle.all.js
extension/sevenx/design/simple/javascript/jquery.scrollTo.js
extension/community_design/design/suncana/javascript/jquery.cookie.js
extension/community_design/design/suncana/javascript/ezstarrating_jquery.js
extension/community_design/design/suncana/javascript/jquery.initboxes.js
extension/community_design/design/suncana/javascript/app.js
extension/community_design/design/suncana/javascript/twitterwidget.js
extension/community_design/design/suncana/javascript/community.js
extension/community_design/design/suncana/javascript/roadmap.js
extension/community_design/design/suncana/javascript/ez.js
extension/community_design/design/suncana/javascript/ezshareevents.js
extension/sevenx/design/simple/javascript/main.js

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1node/view/full.tplfull/forum_topic.tplextension/sevenx/design/simple/override/templates/full/forum_topic.tplEdit templateOverride template
13content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
29content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
19content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
4content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 67
 Number of unique templates used: 6

Time used to render debug report: 0.0002 secs