We help IT Professionals succeed at work.

We've partnered with Certified Experts, Carl Webster and Richard Faulkner, to bring you two Citrix podcasts. Learn about 2020 trends and get answers to your biggest Citrix questions!Listen Now

x

Perl script with sendmail

tucker040197
tucker040197 asked
on
Medium Priority
448 Views
Last Modified: 2013-12-25
I need to know how to make the script that I have attached at the end of this message send email as the user who submits the form. The form is supposed to subscribe someone to a listserver, when one enters their name and email address, it should subscribe them. However, as it works now, the email is being sent as nobody@cissus.mobot.org(this is the server where the script resides). Instead I need the script to actually send the mail as if it were coming from the submitted email address. Otherwise the person cannot post to the list from their real machine.
Here is the script:

#!/opt/gnu/bin/perl
require "/usr/local/HTTPD/cgi-bin/cgi-lib.pl";
&ReadParse;

open (MAIL, "| /usr/lib/sendmail -oi -t" );
print MAIL <<NOTIFY;
To: listproc\@mobot.mobot.org
From:$in{'email'}\n

sub ical-l $in{'fullname'}

NOTIFY
close MAIL;


print "Content-type:text/html\n\n";
print <<RECEIVED;
<html>
<body text="#666600" link="#ff3300" vlink="#ff9900" alink="#ffff00" background=\
\
"http://www.mobot.org/ical/icalbg.gif">

<title>You Have Been Added!!!</title>
<center>
<font size="+2"><b>You Have Been Added!!!</b></font><P>
</center><P>
<b>The email address <b>$in{'newemail'}</b> will be used to notify you
of any ICAL-Botany submissions.
RECEIVED

print <<FOOTER;
<hr width=70% size=5>
<center><a href="http://www.mobot.org/ical/"><== Orphan
Home</a></center>

</body></html>
FOOTER



exit;
Comment
Watch Question

Commented:
Two suggestions:

1) Put a SPACE after the From: in the header.

2) Add the header Reply-To: $in{'email'}\n

Good luck

Author

Commented:
This still does not work, there must be some other level of information to the email message that is not normally viewed. The following is the actual text that shows up in an email message submitted by the form:

>
Date: Fri, 4 Apr 1997 09:16:42 -0600 (CST)
From: ficken@cissus.mobot.org
To: listproc@mobot.mobot.org

sub ical-l Keven Ficken
>

This is identical to what the message looks like when I actually send it from an email client, in which case the subscription will be successful, but for some reason in this instance it still does not work. When I try to send the message from the form, the list admin gets a message copied to him that is a reply to nobody@cissus.mobot.org saying that he is already a member of the list and thus can't subscribe(we do have nobody@cissus.mobot.org on the list so that non-members can submit to the list). I am stumped as to where the list gets the nobody address from the message I send and how to change the nobody to the submitted address.

Commented:
It gets it as the program was run by nobody@cissus.mbot.org.

However, as I understood it, the -oi flag should kill that.

As another suggestion, as a workaround, try:

open (MAIL, "| /usr/lib/sendmail -t To: listproc\@mobot.mobot.org " );

instead as the open?  If this also fails, I will read the
sendmail manaual page fully!

Commented:
Eek, typo there..  Remove the To: from the suggested line!

It is meant to replace the current open line..

Author

Commented:
Adjusted points to 75
You can set the "from" address in Sendmail by using the -f parameter (i.e. /.../sendmail -fmyname@mydomain ).  Your process must be running as root or another trusted user to do this, otherwise you'll receive an "X-authentication" message in the e-mail header, but this may not be that big of a problem because the e-mail will still appear to be "from" the user address you
specify.

If you don't use the -f parameter, sendmail will send the message as designated coming from whatever user process the web server is running as.  By modifying the e-mail headers, you can set the reply-to, but the only way to force the original "X-sender" is by using the -f parameter.

So you should change your original reference to sendmail to look something like this:

open (MAIL, "| /usr/lib/sendmail -f$in{'email'} ..." );

I haven't tested this, but you get the idea.  HOWEVER, note that this also represents a rather serious potential security hole.  If one of the form fields ends up on the Unix command line, you better run some serious checks on the email variable value to make sure it contains no destructive characters - if you don't user's can potentially execute unix commands as the web server user!  Be sure to remove any characters from the email value that would have special purpose under your particular version of Unix (i.e. |,+,& etc..)

Let me also just state for the record that it's debatable as to whether the convenience of allowing a push-button maillist subscription from a web page is worth the hassel you can end up with when users enter invalid e-mail addresses.  

 - wisdom

Not the solution you were looking for? Getting a personalized solution is easy.

Ask the Experts
Access more of Experts Exchange with a free account
Thanks for using Experts Exchange.

Create a free account to continue.

Limited access with a free account allows you to:

  • View three pieces of content (articles, solutions, posts, and videos)
  • Ask the experts questions (counted toward content limit)
  • Customize your dashboard and profile

*This site is protected by reCAPTCHA and the Google Privacy Policy and Terms of Service apply.

OR

Please enter a first name

Please enter a last name

8+ characters (letters, numbers, and a symbol)

By clicking, you agree to the Terms of Use and Privacy Policy.