Tek-Tips is the largest IT community on the Internet today!

Members share and learn making Tek-Tips Forums the best source of peer-reviewed technical information on the Internet!

  • Congratulations IamaSherpa on being selected by the Tek-Tips community for having the most helpful posts in the forums last week. Way to Go!

sendmail on my internal network 1

Status
Not open for further replies.

weedom

Programmer
Jan 29, 2005
7
GB
I've got a 192 network setup here at home, with a windoze client and a linux server. Neither my broadband supplier nor my host provide SMTP, so I thought I'd do my own.

I've succesfully sent email from the linux box to the outside world using command line SMTP to my hotmail (sorry) account, but if I try to connect to linux from windoze on port 25 or 587 I get the message "Connection refused".

I've read and followed faq14-1591, but the result was the same:

telnet 192.168.1.3 25 .... connection refused.

I'm a bit au-fait with perl, so I built a little daemon on the linux box which accepts connections on port 25. The server accepted connections no problem at all. Just "yep, hello, what do you want?". Which means it's not the firewall that's the problem.

I've read snippets about smapd in the oreilly bookshelf, but can't find anything on the net. I don't really see why I need to proxy this to such an extent. All I want to do is to allow *one* windoze box to talk to *one* linux box via SMTP.

I'm nearly sobbing with anguish... can anybody help me?? Please... I don't want to have to write a bespoke SMTP daemon in order to send a simple email.
 
Good try, but this is internal, not external.

I've personally blocked external incoming access to 25, regardless of what my ISP _say_ they have done :)

I have successfully managed to connect to a simple "echo" server (running on the same machine as sendmail (although not at the same time, of course)) from my windows box, using port 25. So it's not a firewall issue, it's a sendmail issue which I just cannot figure out for the life of me.

I'm inches off either a) signing up for an external paid-up SMTP service, or b) writing my own proxy on a wierd port, which'll pass messages onto the local sendmail.

But both options seem a real pain in the arse when I know that somewhere there is a one-line fix which I just can't find, yet.

Somebody knows the answer! I don't, but someone does! Please help!
 
Hi,

On linux box, can you type "netstat -an | grep 25" and paste here the result. I wonder if your sendmail listen on localhost only.

dbase77
 
netstat -an | grep 25:

tcp 0 0 127.0.0.1:25 0.0.0.0:* LISTEN
unix 3 [ ] STREAM CONNECTED 121425
unix 3 [ ] STREAM CONNECTED 121325 /tmp/orbit-dominic/linc-1499-0-2654cc36c4d3
unix 3 [ ] STREAM CONNECTED 121255

Which would suggest to me that you're right, sendmail is only listening on 25. Do you know how to change this?
 
Hi,

Can you open your sendmail.cf file and paste me line saying about "# SMTP daemon options". Example

O DaemonPortOptions=Port=smtp, Name=MTA

......
dbase77
 
Hi,

can you paste me your sendmail.mc file as well, please?

dbase77
 
# SMTP daemon options

O DaemonPortOptions=Port=smtp,Addr=127.0.0.1, Name=MTA

sendmail.mc looks like this: (sorry... it's rather long, and is simply the default that came when I re-installed RH9 the other day. I *have* made some effort to resolve this myself, as my initial post should demonstrate :)

divert(-1)dnl
dnl #
dnl # This is the sendmail macro config file for m4. If you make changes to
dnl # /etc/mail/sendmail.mc, you will need to regenerate the
dnl # /etc/mail/sendmail.cf file by confirming that the sendmail-cf package is
dnl # installed and then performing a
dnl #
dnl # make -C /etc/mail
dnl #
include(`/usr/share/sendmail-cf/m4/cf.m4')dnl
VERSIONID(`setup for Red Hat Linux')dnl
OSTYPE(`linux')dnl
dnl #
dnl # Uncomment and edit the following line if your outgoing mail needs to
dnl # be sent out through an external mail server:
dnl #
dnl define(`SMART_HOST',`smtp.your.provider')
dnl #
define(`confDEF_USER_ID',``8:12'')dnl
define(`confTRUSTED_USER', `smmsp')dnl
dnl define(`confAUTO_REBUILD')dnl
define(`confTO_CONNECT', `1m')dnl
define(`confTRY_NULL_MX_LIST',true)dnl
define(`confDONT_PROBE_INTERFACES',true)dnl
define(`PROCMAIL_MAILER_PATH',`/usr/bin/procmail')dnl
define(`ALIAS_FILE', `/etc/aliases')dnl
dnl define(`STATUS_FILE', `/etc/mail/statistics')dnl
define(`UUCP_MAILER_MAX', `2000000')dnl
define(`confUSERDB_SPEC', `/etc/mail/userdb.db')dnl
define(`confPRIVACY_FLAGS', `authwarnings,novrfy,noexpn,restrictqrun')dnl
define(`confAUTH_OPTIONS', `A')dnl
dnl #
dnl # The following allows relaying if the user authenticates, and disallows
dnl # plaintext authentication (PLAIN/LOGIN) on non-TLS links
dnl #
dnl define(`confAUTH_OPTIONS', `A p')dnl
dnl #
dnl # PLAIN is the preferred plaintext authentication method and used by
dnl # Mozilla Mail and Evolution, though Outlook Express and other MUAs do
dnl # use LOGIN. Other mechanisms should be used if the connection is not
dnl # guaranteed secure.
dnl #
dnl TRUST_AUTH_MECH(`EXTERNAL DIGEST-MD5 CRAM-MD5 LOGIN PLAIN')dnl
dnl define(`confAUTH_MECHANISMS', `EXTERNAL GSSAPI DIGEST-MD5 CRAM-MD5 LOGIN PLAIN')dnl
dnl #
dnl # Rudimentary information on creating certificates for sendmail TLS:
dnl # make -C /usr/share/ssl/certs usage
dnl #
dnl define(`confCACERT_PATH',`/usr/share/ssl/certs')
dnl define(`confCACERT',`/usr/share/ssl/certs/ca-bundle.crt')
dnl define(`confSERVER_CERT',`/usr/share/ssl/certs/sendmail.pem')
dnl define(`confSERVER_KEY',`/usr/share/ssl/certs/sendmail.pem')
dnl #
dnl # This allows sendmail to use a keyfile that is shared with OpenLDAP's
dnl # slapd, which requires the file to be readble by group ldap
dnl #
dnl define(`confDONT_BLAME_SENDMAIL',`groupreadablekeyfile')dnl
dnl #
dnl define(`confTO_QUEUEWARN', `4h')dnl
dnl define(`confTO_QUEUERETURN', `5d')dnl
dnl define(`confQUEUE_LA', `12')dnl
dnl define(`confREFUSE_LA', `18')dnl
define(`confTO_IDENT', `0')dnl
dnl FEATURE(delay_checks)dnl
FEATURE(`no_default_msa',`dnl')dnl
FEATURE(`smrsh',`/usr/sbin/smrsh')dnl
FEATURE(`mailertable',`hash -o /etc/mail/mailertable.db')dnl
FEATURE(`virtusertable',`hash -o /etc/mail/virtusertable.db')dnl
FEATURE(redirect)dnl
FEATURE(always_add_domain)dnl
FEATURE(use_cw_file)dnl
FEATURE(use_ct_file)dnl
dnl #
dnl # The -t option will retry delivery if e.g. the user runs over his quota.
dnl #
FEATURE(local_procmail,`',`procmail -t -Y -a $h -d $u')dnl
FEATURE(`access_db',`hash -T<TMPF> -o /etc/mail/access.db')dnl
FEATURE(`blacklist_recipients')dnl
EXPOSED_USER(`root')dnl
dnl #
dnl # The following causes sendmail to only listen on the IPv4 loopback address
dnl # 127.0.0.1 and not on any other network devices. Remove the loopback
dnl # address restriction to accept email from the internet or intranet.
dnl #
DAEMON_OPTIONS(`Port=smtp,Addr=127.0.0.1, Name=MTA')dnl
dnl #
dnl # The following causes sendmail to additionally listen to port 587 for
dnl # mail from MUAs that authenticate. Roaming users who can't reach their
dnl # preferred sendmail daemon due to port 25 being blocked or redirected find
dnl # this useful.
dnl #
dnl DAEMON_OPTIONS(`Port=submission, Name=MSA, M=Ea')dnl
dnl #
dnl # The following causes sendmail to additionally listen to port 465, but
dnl # starting immediately in TLS mode upon connecting. Port 25 or 587 followed
dnl # by STARTTLS is preferred, but roaming clients using Outlook Express can't
dnl # do STARTTLS on ports other than 25. Mozilla Mail can ONLY use STARTTLS
dnl # and doesn't support the deprecated smtps; Evolution <1.1.1 uses smtps
dnl # when SSL is enabled-- STARTTLS support is available in version 1.1.1.
dnl #
dnl # For this to work your OpenSSL certificates must be configured.
dnl #
dnl DAEMON_OPTIONS(`Port=smtps, Name=TLSMTA, M=s')dnl
dnl #
dnl # The following causes sendmail to additionally listen on the IPv6 loopback
dnl # device. Remove the loopback address restriction listen to the network.
dnl #
dnl # NOTE: binding both IPv4 and IPv6 daemon to the same port requires
dnl # a kernel patch
dnl #
dnl DAEMON_OPTIONS(`port=smtp,Addr=::1, Name=MTA-v6, Family=inet6')dnl
dnl #
dnl # We strongly recommend not accepting unresolvable domains if you want to
dnl # protect yourself from spam. However, the laptop and users on computers
dnl # that do not have 24x7 DNS do need this.
dnl #
FEATURE(`accept_unresolvable_domains')dnl
dnl #
dnl FEATURE(`relay_based_on_MX')dnl
dnl #
dnl # Also accept email sent to "localhost.localdomain" as local email.
dnl #
LOCAL_DOMAIN(`localhost.localdomain')dnl
dnl #
dnl # The following example makes mail from this host and any additional
dnl # specified domains appear to be sent from mydomain.com
dnl #
dnl MASQUERADE_AS(`painless.co.uk')dnl
dnl #
dnl # masquerade not just the headers, but the envelope as well
dnl #
dnl FEATURE(masquerade_envelope)dnl
dnl #
dnl # masquerade not just @mydomainalias.com, but @*.mydomainalias.com as well
dnl #
dnl FEATURE(masquerade_entire_domain)dnl
dnl #
dnl MASQUERADE_DOMAIN(localhost)dnl
dnl MASQUERADE_DOMAIN(localhost.localdomain)dnl
dnl MASQUERADE_DOMAIN(mydomainalias.com)dnl
dnl MASQUERADE_DOMAIN(mydomain.lan)dnl
MAILER(smtp)dnl
MAILER(procmail)dnl
 
Hi,

Either you edit your sendmail.cf or edit your sendmail.mc file. If you edit your sendmail.cf file you need to restart sendmail. If you edit your sendmail.mc file you need to rebuild your sendmail.

For sendmail.cf file:

change
# SMTP daemon options
O DaemonPortOptions=Port=smtp,Addr=127.0.0.1, Name=MTA

into
# SMTP daemon options
O DaemonPortOptions=Port=smtp, Name=MTA

For sendmail.mc file:
change
DAEMON_OPTIONS(`Port=smtp,Addr=127.0.0.1, Name=MTA')dnl

into
DAEMON_OPTIONS(`Port=smtp, Name=MTA')dnl


.........
dbase77


 
yay! That works a treat. Thankyou, thankyou, thankyou!

BUT... haven't I just created an open relay? I'll close port 25 through my firewall, naturally, but is there a way to tell sendmail who it can relay for and who it should ignore?
 
Hi,

If you want to only listen on LAN ip, you can change the line to use LAN ip instead of 127.0.0.1.

Example:
O DaemonPortOptions=Port=smtp,Addr=10.10.10.10, Name=MTA

DAEMON_OPTIONS(`Port=smtp,Addr=10.10.10.10, Name=MTA')dnl

By default sendmail is setup not to open relay. To allow only relay for your domain you can edit file /etc/mail/relay-domains and put it your ip address or your domain name. restart sendmail. To check for open relay, google.com for open relay check. One of the website will check for open relay for you.


........
dbase77
 
Status
Not open for further replies.

Part and Inventory Search

Sponsor

Back
Top