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:
parent
3d20111cbd
commit
dd84e528a3
@ -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.
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
26
perl/Git.pm
26
perl/Git.pm
@ -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 {
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user