michaelb@wshb.csms.com ( WSHB Operations Eng) (12/04/90)
I'm going to be setting up a new Xenix box soon and I'd like to avoid some of the hoops I have had to jump through before. What I am thinking of doing is just completely leaving the SCO mail stuff out during the installation and putting in a more unix like mail system, ie. no /usr/lib/mail/execmail or other wierdness. I run all of the other boxes with smail2.5 patched to understand xenix conventions. Does anyone have suggestions or meaningful experiences with a whole subsystem replacement? Should I get smail3.1 working? Or should I think about going full force and snarfing sendmail and rmail sources from uunet? This box will have only uucp connections for the near future, but might wind up with a thinwire on the back in a couple of years. Do I need to plan for this now or cross that bridge when I get there? Comments? Michael -- Michael Batchelor--Systems/Operations Engineer #compliments and complaints WSHB - An International Broadcast Station of # letterbox@csms.com The Christian Science Monitor Syndicate, Inc. #technical questions and reports michaelb@wshb.csms.com +1 803 625 4880 # letterbox-tech@csms.com
chip@chinacat.Unicom.COM (Chip Rosenthal) (12/06/90)
In article <885@wshb.csms.com> michaelb@wshb.csms.com ( WSHB Operations Eng) writes: >What I am thinking of doing is just completely leaving the SCO mail stuff >out during the installation and putting in a more unix like mail system, >ie. no /usr/lib/mail/execmail or other wierdness. I agree with you 90% :-) I have run two different mail configurations under SCO XENIX. One was Elm+smail2.5+deliver, the other (and current configuration) is Elm+smail3.1. However, neither of these approaches provides a "binmail" function - and that is required. For example, cron needs to be able to call "mail" to send its messages. Furthermore, the plain vanilla mailx/Mail user agent is sometimes nice to have. Both of these functions are served by the SCO /usr/bin/mail program, and therefore, you are going to want to keep that. So why not just ln smail to /bin/mail? Well - the semantics are different. You need the "-s subject" support of binmail. Furthermore, binmail treats the entire input as message body, where smail handles embedded headers. The difference is subtle. If the cron output contains an error message such as "/usr/spool/blurfl: bad directory", smail will think you are sending a message with no body, just a header line called "/usr/spool/blurfl:". I often use SCO's /usr/bin/mail to do mailbox editing. Unfortunately, the Elm editing function puts you in the editor with the entire mailbox, whereas the /usr/bin/mail function lets you edit a single message. Unless you are willing to write or port a binmail (absolutely required) and maybe a mailx/Mail (nice to have), you need SCO's /usr/bin/mail. Since you need that, you need to provide a /usr/lib/mail/execmail for /usr/bin/mail to talk to. So, do not plan on divesting yourself of SCO's mail system totally. At the very least, you need to load on their /usr/bin/mail, provide a /usr/lib/mailrc which says "set execmail", and provide a /usr/lib/mail/execmail which either kicks stuff over to smail (either flavor - 2.5 or 3.1) or let smail masquarade as execmail. Myself, I just load up SCO's entire mail system, move their /usr/bin/rmail and /usr/lib/mail/execmail out of the way, and then dump my junk on top. >Should I get smail3.1 working? Or should I think about >going full force and snarfing sendmail and rmail sources from uunet? I am a satisfied smail3.1 customer - I feel no compunction to mess around with sendmail. Smail3.1 compiles right out of the box on XENIX/386 3.2. A /usr/lib/mail/execmail replacement, written by Chip Salzenberg, is included in the smail3.1 distribution. My preference is to hack smail3.1 so it understands the execmail switches, and just install it under that name. Both these hacks should look familiar - we've done them for smail2.5 as well. >This box will have only uucp connections for the near future, but might >wind up with a thinwire on the back in a couple of years. Do I need to plan >for this now or cross that bridge when I get there? Smail2.5/deliver is usable with an external SMTP client - but it's not pretty. I've done it for an Excelan LAN Workplace system. As soon as I got my hands on an smail3.1 which linked with the Excelan socket library, I immediately converted over to smail3.1. When you do SMTP, I think you will want smail3.1. Smail3.1 is a good thing. It's more work than smail2.5, but a lot less than sendmail. However, there isn't anything you need today that smail2.5/deliver won't do. Knowing you will need to convert someday, though, is one point in favor of doing it now. On the other hand, it seems silly to put a lot of energy into preparing for a possible event years down the road. Hell, I feel satisfied if I have a coherent computing plan in place which runs through next month, let alone next year. :-) -- Chip Rosenthal 512-482-8260 | We was raising insurance premiums, ma. Unicom Systems Development | We was spreading fear of arson. <chip@chinacat.Unicom.COM> | - Michelle Shocked
woods@eci386.uucp (Greg A. Woods) (12/10/90)
In article <1731@chinacat.Unicom.COM> chip@chinacat.Unicom.COM (Chip Rosenthal) writes: > However, neither of these approaches provides a "binmail" function - and > that is required. For example, cron needs to be able to call "mail" to > send its messages. Furthermore, the plain vanilla mailx/Mail user agent > is sometimes nice to have. Both of these functions are served by the SCO > /usr/bin/mail program, and therefore, you are going to want to keep that. Yes, you do want some original "/bin/mail" support. BTW, did SCO really move /bin/mail to /usr/bin? What sillyness! No, I actually thought SCO removed /bin/mail entirely, and renamed /usr/bin/{mailx,Mail} to /usr/bin/mail. Anyway, smail *does* provide this functionality quite well. We've been using it for a long time now on various types of systems. The svbinmail trick, which can be used on XENIX as well, is the secret. If /usr/bin/mail was renamed mailx, and if svbinmail (linked to /bin/mail) exec()'ed either smail (for sending), or your MUA (for reading), depending upon the use of arguments. > So why not just ln smail to /bin/mail? Well - the semantics are different. > You need the "-s subject" support of binmail. Furthermore, binmail treats > the entire input as message body, where smail handles embedded headers. > The difference is subtle. If the cron output contains an error message > such as "/usr/spool/blurfl: bad directory", smail will think you are > sending a message with no body, just a header line called > "/usr/spool/blurfl:". The /bin/mail on most non-XENIX systems doesn't have '-s subject' anyway, and /bin/mail on SysV does *not* treat the entire input as the body either. /bin/mail on SysV assumes the first non-conforming, or blank, line will constitute the end of the header, and the start of the body (though the SVID does not document this behavior). As for the embedded header problem, you can't have it both ways. On SysV this cannot be fixed without breaking /usr/bin/mailx, which relies upon this feature. The real bug is in cron, which could use mailx, or send a properly formatted message to mail. I usually fix all scripts that use mail to do something like the following: ( echo "Subject: $0: {failure,notice}" echo cat /tmp/$$stderr ) | mail $admin >[.... many lines of complication deleted! ....] > At the very least, you need to load on their /usr/bin/mail, provide a > /usr/lib/mailrc which says "set execmail", and provide a > /usr/lib/mail/execmail which either kicks stuff over to smail (either > flavor - 2.5 or 3.1) or let smail masquarade as execmail. Whew. What about "set sendmail=/bin/smail"? Or is SCO's /usr/bin/mail missing this SVID defined feature? I can't remember. > When you do SMTP, I think you will want smail3.1. Smail3.1 is a good > thing. It's more work than smail2.5, but a lot less than sendmail. > However, there isn't anything you need today that smail2.5/deliver won't > do. Knowing you will need to convert someday, though, is one point in > favor of doing it now. > > On the other hand, it seems silly to put a lot of energy into preparing > for a possible event years down the road. [....] K.I.S.S. Need I say more? Let us look at this from the point of view of simple functionality: 1. a simple MTA for aliasing and routing mail. - smail-2.5 can do this quite well 2. simple mail user agent for sending mail (i.e. /bin/mail in SysV). - use svbinmail (part of smail-2.5) installed as /bin/mail to decide if the caller is sending, or reading, mail, and exec either smail or fancy MUA (may require changes to the decision-making logic for fancy MUA's). 3. local delivery agent (LDA) for sending to files and pipes (called upon by smail only). - lmail-2.6 does this quite well - deliver may work fine too, but I've never tried it. 4. your favorite MUA (mine is mush) (uses smail only for the MTA). - or rename /usr/bin/mail to mailx and stick with it, if the "set sendmail=/bin/mail" feature works. It has been a very long time since I had to set up such a system on XENIX, so don't believe everything I say! :-) The biggest thing to worry about is compatability of mailbox locking schemes. The MUA and LDA must respect each others locks, or otherwise you'll lose mail! -- Greg A. Woods woods@{eci386,gate,robohack,ontmoh,tmsoft}.UUCP ECI and UniForum Canada +1-416-443-1734 [h] +1-416-595-5425 [w] VE3TCP Toronto, Ontario CANADA Political speech and writing are largely the defense of the indefensible-ORWELL