diff options
| author | Junio C Hamano <gitster@pobox.com> | 2010-05-08 22:37:34 -0700 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2010-05-08 22:37:34 -0700 | 
| commit | daa81c4a4a48a76e542293c025972e6a870fec9b (patch) | |
| tree | 66ae06b7eaddd47f1d045eafdbcb04f01eee6c2a /git-send-email.perl | |
| parent | 909376a1c9078b7bb7b420113efa956b130e8809 (diff) | |
| parent | 69cf7bfd131ae6246931459a1e6513d51f0b0119 (diff) | |
| download | git-daa81c4a4a48a76e542293c025972e6a870fec9b.tar.gz | |
Merge branch 'bg/send-email-smtpdomain'
* bg/send-email-smtpdomain:
  send-email: Cleanup smtp-domain and add config
  Document send-email --smtp-domain
  send-email: Don't use FQDNs without a '.'
  send-email: Cleanup { style
Diffstat (limited to 'git-send-email.perl')
| -rwxr-xr-x | git-send-email.perl | 48 | 
1 files changed, 22 insertions, 26 deletions
| diff --git a/git-send-email.perl b/git-send-email.perl index ce569a9c8f..111c981229 100755 --- a/git-send-email.perl +++ b/git-send-email.perl @@ -132,8 +132,6 @@ my $have_email_valid = eval { require Email::Valid; 1 };  my $have_mail_address = eval { require Mail::Address; 1 };  my $smtp;  my $auth; -my $mail_domain_default = "localhost.localdomain"; -my $mail_domain;  sub unique_email_list(@);  sub cleanup_compose_files(); @@ -190,7 +188,7 @@ sub do_edit {  # Variables with corresponding config settings  my ($thread, $chain_reply_to, $suppress_from, $signed_off_by_cc, $cc_cmd);  my ($smtp_server, $smtp_server_port, $smtp_authuser, $smtp_encryption); -my ($identity, $aliasfiletype, @alias_files, @smtp_host_parts); +my ($identity, $aliasfiletype, @alias_files, @smtp_host_parts, $smtp_domain);  my ($validate, $confirm);  my (@suppress_cc); @@ -212,6 +210,7 @@ my %config_settings = (      "smtpserverport" => \$smtp_server_port,      "smtpuser" => \$smtp_authuser,      "smtppass" => \$smtp_authpass, +	"smtpdomain" => \$smtp_domain,      "to" => \@to,      "cc" => \@initial_cc,      "cccmd" => \$cc_cmd, @@ -283,7 +282,7 @@ my $rc = GetOptions("sender|from=s" => \$sender,  		    "smtp-ssl" => sub { $smtp_encryption = 'ssl' },  		    "smtp-encryption=s" => \$smtp_encryption,  		    "smtp-debug:i" => \$debug_net_smtp, -		    "smtp-domain:s" => \$mail_domain, +		    "smtp-domain:s" => \$smtp_domain,  		    "identity=s" => \$identity,  		    "annotate" => \$annotate,  		    "compose" => \$compose, @@ -761,8 +760,7 @@ sub extract_valid_address {  # We'll setup a template for the message id, using the "from" address:  my ($message_id_stamp, $message_id_serial); -sub make_message_id -{ +sub make_message_id {  	my $uniq;  	if (!defined $message_id_stamp) {  		$message_id_stamp = sprintf("%s-%s", time, $$); @@ -817,8 +815,7 @@ sub is_rfc2047_quoted {  }  # use the simplest quoting being able to handle the recipient -sub sanitize_address -{ +sub sanitize_address {  	my ($recipient) = @_;  	my ($recipient_name, $recipient_addr) = ($recipient =~ /^(.*?)\s*(<.*)/); @@ -863,21 +860,23 @@ sub sanitize_address  # This maildomain*() code is based on ideas in Perl library Test::Reporter  # /usr/share/perl5/Test/Reporter/Mail/Util.pm ==> sub _maildomain () -sub maildomain_net -{ +sub valid_fqdn { +	my $domain = shift; +	return !($^O eq 'darwin' && $domain =~ /\.local$/) && $domain =~ /\./; +} + +sub maildomain_net {  	my $maildomain;  	if (eval { require Net::Domain; 1 }) {  		my $domain = Net::Domain::domainname(); -		$maildomain = $domain -			unless $^O eq 'darwin' && $domain =~ /\.local$/; +		$maildomain = $domain if valid_fqdn($domain);  	}  	return $maildomain;  } -sub maildomain_mta -{ +sub maildomain_mta {  	my $maildomain;  	if (eval { require Net::SMTP; 1 }) { @@ -887,8 +886,7 @@ sub maildomain_mta  				my $domain = $smtp->domain;  				$smtp->quit; -				$maildomain = $domain -					unless $^O eq 'darwin' && $domain =~ /\.local$/; +				$maildomain = $domain if valid_fqdn($domain);  				last if $maildomain;  			} @@ -898,17 +896,15 @@ sub maildomain_mta  	return $maildomain;  } -sub maildomain -{ -	return maildomain_net() || maildomain_mta() || $mail_domain_default; +sub maildomain { +	return maildomain_net() || maildomain_mta() || 'localhost.localdomain';  }  # Returns 1 if the message was sent, and 0 otherwise.  # In actuality, the whole program dies when there  # is an error sending a message. -sub send_message -{ +sub send_message {  	my @recipients = unique_email_list(@to);  	@cc = (grep { my $cc = extract_valid_address($_);  		      not grep { $cc eq $_ } @recipients @@ -1005,18 +1001,18 @@ X-Mailer: git-send-email $gitversion  		if ($smtp_encryption eq 'ssl') {  			$smtp_server_port ||= 465; # ssmtp  			require Net::SMTP::SSL; -			$mail_domain ||= maildomain(); +			$smtp_domain ||= maildomain();  			$smtp ||= Net::SMTP::SSL->new($smtp_server, -						      Hello => $mail_domain, +						      Hello => $smtp_domain,  						      Port => $smtp_server_port);  		}  		else {  			require Net::SMTP; -			$mail_domain ||= maildomain(); +			$smtp_domain ||= maildomain();  			$smtp ||= Net::SMTP->new((defined $smtp_server_port)  						 ? "$smtp_server:$smtp_server_port"  						 : $smtp_server, -						 Hello => $mail_domain, +						 Hello => $smtp_domain,  						 Debug => $debug_net_smtp);  			if ($smtp_encryption eq 'tls' && $smtp) {  				require Net::SMTP::SSL; @@ -1039,7 +1035,7 @@ X-Mailer: git-send-email $gitversion  			die "Unable to initialize SMTP properly. Check config and use --smtp-debug. ",  			    "VALUES: server=$smtp_server ",  			    "encryption=$smtp_encryption ", -			    "maildomain=$mail_domain", +			    "hello=$smtp_domain",  			    defined $smtp_server_port ? "port=$smtp_server_port" : "";  		} | 
