git-send-email: die if sendmail.* config is set

I've seen several people mis-configure git send-email on their first
attempt because they set the sendmail.* config options - not
sendemail.*. This patch detects this mistake and bails out with a
friendly warning.

Signed-off-by: Drew DeVault <sir@cmpwn.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Drew DeVault 2020-07-23 20:44:32 -04:00 committed by Junio C Hamano
parent 3d20111cbd
commit dd84e528a3
4 changed files with 68 additions and 0 deletions

View File

@ -61,3 +61,8 @@ sendemail.smtpBatchSize::
sendemail.smtpReloginDelay:: sendemail.smtpReloginDelay::
Seconds wait before reconnecting to smtp server. Seconds wait before reconnecting to smtp server.
See also the `--relogin-delay` option of linkgit:git-send-email[1]. See also the `--relogin-delay` option of linkgit:git-send-email[1].
sendemail.forbidSendmailVariables::
To avoid common misconfiguration mistakes, linkgit:git-send-email[1]
will abort with a warning if any configuration options for "sendmail"
exist. Set this variable to bypass the check.

View File

@ -250,6 +250,7 @@ my $chain_reply_to = 0;
my $use_xmailer = 1; my $use_xmailer = 1;
my $validate = 1; my $validate = 1;
my $target_xfer_encoding = 'auto'; my $target_xfer_encoding = 'auto';
my $forbid_sendmail_variables = 1;
my %config_bool_settings = ( my %config_bool_settings = (
"thread" => \$thread, "thread" => \$thread,
@ -263,6 +264,7 @@ my %config_bool_settings = (
"multiedit" => \$multiedit, "multiedit" => \$multiedit,
"annotate" => \$annotate, "annotate" => \$annotate,
"xmailer" => \$use_xmailer, "xmailer" => \$use_xmailer,
"forbidsendmailvariables" => \$forbid_sendmail_variables,
); );
my %config_settings = ( my %config_settings = (
@ -478,6 +480,12 @@ unless ($rc) {
usage(); usage();
} }
if ($forbid_sendmail_variables && (scalar Git::config_regexp("^sendmail[.]")) != 0) {
die __("fatal: found configuration options for 'sendmail'\n" .
"git-send-email is configured with the sendemail.* options - note the 'e'.\n" .
"Set sendemail.forbidSendmailVariables to false to disable this check.\n");
}
die __("Cannot run git format-patch from outside a repository\n") die __("Cannot run git format-patch from outside a repository\n")
if $format_patch and not $repo; if $format_patch and not $repo;

View File

@ -723,6 +723,32 @@ sub config_int {
return scalar _config_common({'kind' => '--int'}, @_); return scalar _config_common({'kind' => '--int'}, @_);
} }
=item config_regexp ( RE )
Retrieve the list of configuration key names matching the regular
expression C<RE>. The return value is a list of strings matching
this regex.
=cut
sub config_regexp {
my ($self, $regex) = _maybe_self(@_);
try {
my @cmd = ('config', '--name-only', '--get-regexp', $regex);
unshift @cmd, $self if $self;
my @matches = command(@cmd);
return @matches;
} catch Git::Error::Command with {
my $E = shift;
if ($E->value() == 1) {
my @matches = ();
return @matches;
} else {
throw $E;
}
};
}
# Common subroutine to implement bulk of what the config* family of methods # Common subroutine to implement bulk of what the config* family of methods
# do. This currently wraps command('config') so it is not so fast. # do. This currently wraps command('config') so it is not so fast.
sub _config_common { sub _config_common {

View File

@ -2142,4 +2142,33 @@ test_expect_success $PREREQ 'test that send-email works outside a repo' '
"$(pwd)/0001-add-master.patch" "$(pwd)/0001-add-master.patch"
' '
test_expect_success $PREREQ 'test that sendmail config is rejected' '
test_config sendmail.program sendmail &&
test_must_fail git send-email \
--from="Example <nobody@example.com>" \
--to=nobody@example.com \
--smtp-server="$(pwd)/fake.sendmail" \
HEAD^ 2>err &&
test_i18ngrep "found configuration options for '"'"sendmail"'"'" err
'
test_expect_success $PREREQ 'test that sendmail config rejection is specific' '
test_config resendmail.program sendmail &&
git send-email \
--from="Example <nobody@example.com>" \
--to=nobody@example.com \
--smtp-server="$(pwd)/fake.sendmail" \
HEAD^
'
test_expect_success $PREREQ 'test forbidSendmailVariables behavior override' '
test_config sendmail.program sendmail &&
test_config sendemail.forbidSendmailVariables false &&
git send-email \
--from="Example <nobody@example.com>" \
--to=nobody@example.com \
--smtp-server="$(pwd)/fake.sendmail" \
HEAD^
'
test_done test_done