Move sendemail.allowRegisterNewEmail to auth.allowRegisterNewEmail
The sendemail section of the configuration is for settings related to how Gerrit sends emails to users. allowRegisterEmail controls whether or not users are allowed to register a new email address, which is not related to Gerrit's sending of email. Move the setting to the auth section, which is a more appropriate place for it. Change-Id: I06d9c4870060eb85bc4a05b536645d42df44e041
This commit is contained in:
@@ -482,6 +482,16 @@ editing gerrit.config and restarting the server.
|
|||||||
+
|
+
|
||||||
Default is true.
|
Default is true.
|
||||||
|
|
||||||
|
[[auth.allowRegisterNewEmail]]auth.allowRegisterNewEmail::
|
||||||
|
+
|
||||||
|
Whether users are allowed to register new email addresses.
|
||||||
|
+
|
||||||
|
In addition for the HTTP authentication type
|
||||||
|
link:#auth.httpemailheader[auth.httpemailheader] must *not* be set to
|
||||||
|
enable registration of new email addresses.
|
||||||
|
+
|
||||||
|
By default, true.
|
||||||
|
|
||||||
[[cache]]
|
[[cache]]
|
||||||
=== Section cache
|
=== Section cache
|
||||||
|
|
||||||
@@ -3154,16 +3164,6 @@ and all other properties of section sendemail are ignored.
|
|||||||
+
|
+
|
||||||
By default, true, allowing notifications to be sent.
|
By default, true, allowing notifications to be sent.
|
||||||
|
|
||||||
[[sendemail.allowRegisterNewEmail]]sendemail.allowRegisterNewEmail::
|
|
||||||
+
|
|
||||||
Whether users are allowed to register new email addresses.
|
|
||||||
+
|
|
||||||
In addition for the HTTP authentication type
|
|
||||||
link:#auth.httpemailheader[auth.httpemailheader] must *not* be set to
|
|
||||||
enable registration of new email addresses.
|
|
||||||
+
|
|
||||||
By default, true.
|
|
||||||
|
|
||||||
[[sendemail.connectTimeout]]sendemail.connectTimeout::
|
[[sendemail.connectTimeout]]sendemail.connectTimeout::
|
||||||
+
|
+
|
||||||
The connection timeout of opening a socket connected to a
|
The connection timeout of opening a socket connected to a
|
||||||
|
@@ -19,7 +19,6 @@ import com.google.gerrit.reviewdb.client.Account;
|
|||||||
import com.google.gerrit.reviewdb.client.AuthType;
|
import com.google.gerrit.reviewdb.client.AuthType;
|
||||||
import com.google.gerrit.reviewdb.server.ReviewDb;
|
import com.google.gerrit.reviewdb.server.ReviewDb;
|
||||||
import com.google.gerrit.server.config.AuthConfig;
|
import com.google.gerrit.server.config.AuthConfig;
|
||||||
import com.google.gerrit.server.mail.EmailSettings;
|
|
||||||
import com.google.inject.Inject;
|
import com.google.inject.Inject;
|
||||||
import com.google.inject.Singleton;
|
import com.google.inject.Singleton;
|
||||||
|
|
||||||
@@ -28,17 +27,14 @@ import java.util.Set;
|
|||||||
@Singleton
|
@Singleton
|
||||||
public class DefaultRealm extends AbstractRealm {
|
public class DefaultRealm extends AbstractRealm {
|
||||||
private final EmailExpander emailExpander;
|
private final EmailExpander emailExpander;
|
||||||
private final EmailSettings emailSettings;
|
|
||||||
private final AccountByEmailCache byEmail;
|
private final AccountByEmailCache byEmail;
|
||||||
private final AuthConfig authConfig;
|
private final AuthConfig authConfig;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
DefaultRealm(EmailExpander emailExpander,
|
DefaultRealm(EmailExpander emailExpander,
|
||||||
EmailSettings emailSettings,
|
|
||||||
AccountByEmailCache byEmail,
|
AccountByEmailCache byEmail,
|
||||||
AuthConfig authConfig) {
|
AuthConfig authConfig) {
|
||||||
this.emailExpander = emailExpander;
|
this.emailExpander = emailExpander;
|
||||||
this.emailSettings = emailSettings;
|
|
||||||
this.byEmail = byEmail;
|
this.byEmail = byEmail;
|
||||||
this.authConfig = authConfig;
|
this.authConfig = authConfig;
|
||||||
}
|
}
|
||||||
@@ -52,7 +48,7 @@ public class DefaultRealm extends AbstractRealm {
|
|||||||
case FULL_NAME:
|
case FULL_NAME:
|
||||||
return Strings.emptyToNull(authConfig.getHttpDisplaynameHeader()) == null;
|
return Strings.emptyToNull(authConfig.getHttpDisplaynameHeader()) == null;
|
||||||
case REGISTER_NEW_EMAIL:
|
case REGISTER_NEW_EMAIL:
|
||||||
return emailSettings.allowRegisterNewEmail
|
return authConfig.isAllowRegisterNewEmail()
|
||||||
&& Strings.emptyToNull(authConfig.getHttpEmailHeader()) == null;
|
&& Strings.emptyToNull(authConfig.getHttpEmailHeader()) == null;
|
||||||
default:
|
default:
|
||||||
return true;
|
return true;
|
||||||
@@ -60,7 +56,7 @@ public class DefaultRealm extends AbstractRealm {
|
|||||||
} else {
|
} else {
|
||||||
switch (field) {
|
switch (field) {
|
||||||
case REGISTER_NEW_EMAIL:
|
case REGISTER_NEW_EMAIL:
|
||||||
return emailSettings.allowRegisterNewEmail;
|
return authConfig.isAllowRegisterNewEmail();
|
||||||
default:
|
default:
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@@ -33,7 +33,6 @@ import com.google.gerrit.server.account.EmailExpander;
|
|||||||
import com.google.gerrit.server.auth.AuthenticationUnavailableException;
|
import com.google.gerrit.server.auth.AuthenticationUnavailableException;
|
||||||
import com.google.gerrit.server.config.AuthConfig;
|
import com.google.gerrit.server.config.AuthConfig;
|
||||||
import com.google.gerrit.server.config.GerritServerConfig;
|
import com.google.gerrit.server.config.GerritServerConfig;
|
||||||
import com.google.gerrit.server.mail.EmailSettings;
|
|
||||||
import com.google.gwtorm.server.SchemaFactory;
|
import com.google.gwtorm.server.SchemaFactory;
|
||||||
import com.google.inject.Inject;
|
import com.google.inject.Inject;
|
||||||
import com.google.inject.Singleton;
|
import com.google.inject.Singleton;
|
||||||
@@ -79,7 +78,6 @@ public class LdapRealm extends AbstractRealm {
|
|||||||
Helper helper,
|
Helper helper,
|
||||||
AuthConfig authConfig,
|
AuthConfig authConfig,
|
||||||
EmailExpander emailExpander,
|
EmailExpander emailExpander,
|
||||||
EmailSettings emailSettings,
|
|
||||||
@Named(LdapModule.GROUP_CACHE) final LoadingCache<String, Set<AccountGroup.UUID>> membershipCache,
|
@Named(LdapModule.GROUP_CACHE) final LoadingCache<String, Set<AccountGroup.UUID>> membershipCache,
|
||||||
@Named(LdapModule.USERNAME_CACHE) final LoadingCache<String, Optional<Account.Id>> usernameCache,
|
@Named(LdapModule.USERNAME_CACHE) final LoadingCache<String, Optional<Account.Id>> usernameCache,
|
||||||
@GerritServerConfig final Config config) {
|
@GerritServerConfig final Config config) {
|
||||||
@@ -98,7 +96,7 @@ public class LdapRealm extends AbstractRealm {
|
|||||||
if (optdef(config, "accountSshUserName", "DEFAULT") != null) {
|
if (optdef(config, "accountSshUserName", "DEFAULT") != null) {
|
||||||
readOnlyAccountFields.add(Account.FieldName.USER_NAME);
|
readOnlyAccountFields.add(Account.FieldName.USER_NAME);
|
||||||
}
|
}
|
||||||
if (!emailSettings.allowRegisterNewEmail) {
|
if (!authConfig.isAllowRegisterNewEmail()) {
|
||||||
readOnlyAccountFields.add(Account.FieldName.REGISTER_NEW_EMAIL);
|
readOnlyAccountFields.add(Account.FieldName.REGISTER_NEW_EMAIL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -60,6 +60,7 @@ public class AuthConfig {
|
|||||||
private final String cookiePath;
|
private final String cookiePath;
|
||||||
private final boolean cookieSecure;
|
private final boolean cookieSecure;
|
||||||
private final SignedToken emailReg;
|
private final SignedToken emailReg;
|
||||||
|
private final boolean allowRegisterNewEmail;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
AuthConfig(@GerritServerConfig final Config cfg)
|
AuthConfig(@GerritServerConfig final Config cfg)
|
||||||
@@ -90,7 +91,7 @@ public class AuthConfig {
|
|||||||
useContributorAgreements =
|
useContributorAgreements =
|
||||||
cfg.getBoolean("auth", "contributoragreements", false);
|
cfg.getBoolean("auth", "contributoragreements", false);
|
||||||
userNameToLowerCase = cfg.getBoolean("auth", "userNameToLowerCase", false);
|
userNameToLowerCase = cfg.getBoolean("auth", "userNameToLowerCase", false);
|
||||||
|
allowRegisterNewEmail = cfg.getBoolean("auth", "allowRegisterNewEmail", true);
|
||||||
|
|
||||||
String key = cfg.getString("auth", null, "registerEmailPrivateKey");
|
String key = cfg.getString("auth", null, "registerEmailPrivateKey");
|
||||||
if (key != null && !key.isEmpty()) {
|
if (key != null && !key.isEmpty()) {
|
||||||
@@ -297,4 +298,8 @@ public class AuthConfig {
|
|||||||
return authType == AuthType.LDAP ||
|
return authType == AuthType.LDAP ||
|
||||||
authType == AuthType.LDAP_BIND;
|
authType == AuthType.LDAP_BIND;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean isAllowRegisterNewEmail() {
|
||||||
|
return allowRegisterNewEmail;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -22,13 +22,11 @@ import org.eclipse.jgit.lib.Config;
|
|||||||
|
|
||||||
@Singleton
|
@Singleton
|
||||||
public class EmailSettings {
|
public class EmailSettings {
|
||||||
public final boolean allowRegisterNewEmail;
|
|
||||||
public final boolean includeDiff;
|
public final boolean includeDiff;
|
||||||
public final int maximumDiffSize;
|
public final int maximumDiffSize;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
EmailSettings(@GerritServerConfig Config cfg) {
|
EmailSettings(@GerritServerConfig Config cfg) {
|
||||||
allowRegisterNewEmail = cfg.getBoolean("sendemail", "allowRegisterNewEmail", true);
|
|
||||||
includeDiff = cfg.getBoolean("sendemail", "includeDiff", false);
|
includeDiff = cfg.getBoolean("sendemail", "includeDiff", false);
|
||||||
maximumDiffSize = cfg.getInt("sendemail", "maximumDiffSize", 256 << 10);
|
maximumDiffSize = cfg.getInt("sendemail", "maximumDiffSize", 256 << 10);
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user