Merge "Add a defaultDisplayName server config"

This commit is contained in:
Patrick Hiesel 2020-02-14 10:38:33 +00:00 committed by Gerrit Code Review
commit 4c0f07cb04
8 changed files with 86 additions and 5 deletions

View File

@ -121,6 +121,27 @@ If `NONE`, no users other than the current user are visible.
+ +
Default is `ALL`. Default is `ALL`.
[[accounts.defaultDisplayName]]accounts.defaultDisplayName::
+
If a user account does not have a display name set, which is the normal
case, then this configuration value chooses the strategy how to choose
the display name. Note that this strategy is not applied by the backend.
If the AccountInfo has the display name unset, then the client has to
apply this strategy.
+
If `FULL_NAME`, then the (full) name of the user is chosen from
link:rest-api-accounts.html#account-info[AccountInfo].
+
If `FIRST_NAME`, then the first word (i.e. everything until first
whitespace character) of the (full) name of the user is chosen from
link:rest-api-accounts.html#account-info[AccountInfo].
+
If `USERNAME`, then the username of the user is chosen from
link:rest-api-accounts.html#account-info[AccountInfo]. If that is not
set, then the (full) name will be used.
+
Default is `FULL_NAME`.
[[addreviewer]] [[addreviewer]]
=== Section addreviewer === Section addreviewer

View File

@ -1423,6 +1423,9 @@ section.
|`visibility` | |`visibility` |
link:config-gerrit.html#accounts.visibility[Visibility setting for link:config-gerrit.html#accounts.visibility[Visibility setting for
accounts]. accounts].
|`default_display_name`|The default strategy for choosing the display
name in the UI, see also
link:config-gerrit.html#accounts.defaultDisplayName[gerrit.config].
|============================= |=============================
[[auth-info]] [[auth-info]]

View File

@ -0,0 +1,40 @@
// Copyright (C) 2020 The Android Open Source Project
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package com.google.gerrit.extensions.common;
/**
* Fallback rule for choosing a display name, if it is not explicitly set. This rule will not be
* applied by the backend, but should be applied by the user interface.
*/
public enum AccountDefaultDisplayName {
/**
* If the display name for an account is not set, then the (full) name will be used as the display
* name in the user interface.
*/
FULL_NAME,
/**
* If the display name for an account is not set, then the first name (i.e. full name until first
* whitespace character) will be used as the display name in the user interface.
*/
FIRST_NAME,
/**
* If the display name for an account is not set, then the username will be used as the display
* name in the user interface. If the username is also not set, then the (full) name will be used.
*/
USERNAME
}

View File

@ -35,9 +35,11 @@ public class AccountInfo {
/** /**
* The display name of the user. This allows users to control how their name is displayed in the * The display name of the user. This allows users to control how their name is displayed in the
* UI. It will likely be unset for most users. Host admins will just choose a default (full name, * UI. It will likely be unset for most users. This account property is just a way to opt out of
* user name, first name, ...) for all users, and this account property is just a way to opt out * the host wide default strategy of choosing the display name, see
* of the host wide default strategy of choosing the display name. * accounts.accountDefaultDisplayName in the server config. The default strategy is not applied by
* the backend. The display name will just be left unset, and the client has to load and apply the
* default strategy.
*/ */
public String displayName; public String displayName;

View File

@ -22,4 +22,7 @@ package com.google.gerrit.extensions.common;
public class AccountsInfo { public class AccountsInfo {
/** The value of the {@code accounts.visibility} parameter in {@code gerrit.config}. */ /** The value of the {@code accounts.visibility} parameter in {@code gerrit.config}. */
public AccountVisibility visibility; public AccountVisibility visibility;
/** The value of the {@code accounts.visibility} parameter in {@code gerrit.config}. */
public AccountDefaultDisplayName defaultDisplayName;
} }

View File

@ -22,6 +22,7 @@ import com.google.gerrit.extensions.api.changes.ActionVisitor;
import com.google.gerrit.extensions.api.projects.CommentLinkInfo; import com.google.gerrit.extensions.api.projects.CommentLinkInfo;
import com.google.gerrit.extensions.auth.oauth.OAuthLoginProvider; import com.google.gerrit.extensions.auth.oauth.OAuthLoginProvider;
import com.google.gerrit.extensions.auth.oauth.OAuthTokenEncrypter; import com.google.gerrit.extensions.auth.oauth.OAuthTokenEncrypter;
import com.google.gerrit.extensions.common.AccountDefaultDisplayName;
import com.google.gerrit.extensions.common.AccountVisibility; import com.google.gerrit.extensions.common.AccountVisibility;
import com.google.gerrit.extensions.config.CapabilityDefinition; import com.google.gerrit.extensions.config.CapabilityDefinition;
import com.google.gerrit.extensions.config.CloneCommand; import com.google.gerrit.extensions.config.CloneCommand;
@ -269,6 +270,9 @@ public class GerritGlobalModule extends FactoryModule {
factory(InboundEmailRejectionSender.Factory.class); factory(InboundEmailRejectionSender.Factory.class);
bind(PermissionCollection.Factory.class); bind(PermissionCollection.Factory.class);
bind(AccountVisibility.class).toProvider(AccountVisibilityProvider.class).in(SINGLETON); bind(AccountVisibility.class).toProvider(AccountVisibilityProvider.class).in(SINGLETON);
AccountDefaultDisplayName accountDefaultDisplayName =
cfg.getEnum("accounts", null, "defaultDisplayName", AccountDefaultDisplayName.FULL_NAME);
bind(AccountDefaultDisplayName.class).toInstance(accountDefaultDisplayName);
factory(ProjectOwnerGroupsProvider.Factory.class); factory(ProjectOwnerGroupsProvider.Factory.class);
factory(SubmitRuleEvaluator.Factory.class); factory(SubmitRuleEvaluator.Factory.class);

View File

@ -20,6 +20,7 @@ import com.google.common.base.CharMatcher;
import com.google.common.base.Strings; import com.google.common.base.Strings;
import com.google.common.collect.Lists; import com.google.common.collect.Lists;
import com.google.gerrit.common.data.ContributorAgreement; import com.google.gerrit.common.data.ContributorAgreement;
import com.google.gerrit.extensions.common.AccountDefaultDisplayName;
import com.google.gerrit.extensions.common.AccountsInfo; import com.google.gerrit.extensions.common.AccountsInfo;
import com.google.gerrit.extensions.common.AuthInfo; import com.google.gerrit.extensions.common.AuthInfo;
import com.google.gerrit.extensions.common.ChangeConfigInfo; import com.google.gerrit.extensions.common.ChangeConfigInfo;
@ -74,6 +75,7 @@ import org.eclipse.jgit.lib.Config;
public class GetServerInfo implements RestReadView<ConfigResource> { public class GetServerInfo implements RestReadView<ConfigResource> {
private final Config config; private final Config config;
private final AccountVisibilityProvider accountVisibilityProvider; private final AccountVisibilityProvider accountVisibilityProvider;
private final AccountDefaultDisplayName accountDefaultDisplayName;
private final AuthConfig authConfig; private final AuthConfig authConfig;
private final Realm realm; private final Realm realm;
private final PluginMapContext<DownloadScheme> downloadSchemes; private final PluginMapContext<DownloadScheme> downloadSchemes;
@ -96,6 +98,7 @@ public class GetServerInfo implements RestReadView<ConfigResource> {
public GetServerInfo( public GetServerInfo(
@GerritServerConfig Config config, @GerritServerConfig Config config,
AccountVisibilityProvider accountVisibilityProvider, AccountVisibilityProvider accountVisibilityProvider,
AccountDefaultDisplayName accountDefaultDisplayName,
AuthConfig authConfig, AuthConfig authConfig,
Realm realm, Realm realm,
PluginMapContext<DownloadScheme> downloadSchemes, PluginMapContext<DownloadScheme> downloadSchemes,
@ -115,6 +118,7 @@ public class GetServerInfo implements RestReadView<ConfigResource> {
SitePaths sitePaths) { SitePaths sitePaths) {
this.config = config; this.config = config;
this.accountVisibilityProvider = accountVisibilityProvider; this.accountVisibilityProvider = accountVisibilityProvider;
this.accountDefaultDisplayName = accountDefaultDisplayName;
this.authConfig = authConfig; this.authConfig = authConfig;
this.realm = realm; this.realm = realm;
this.downloadSchemes = downloadSchemes; this.downloadSchemes = downloadSchemes;
@ -156,6 +160,7 @@ public class GetServerInfo implements RestReadView<ConfigResource> {
private AccountsInfo getAccountsInfo() { private AccountsInfo getAccountsInfo() {
AccountsInfo info = new AccountsInfo(); AccountsInfo info = new AccountsInfo();
info.visibility = accountVisibilityProvider.get(); info.visibility = accountVisibilityProvider.get();
info.defaultDisplayName = accountDefaultDisplayName;
return info; return info;
} }

View File

@ -25,6 +25,7 @@ import com.google.gerrit.common.RawInputUtil;
import com.google.gerrit.extensions.api.plugins.InstallPluginInput; import com.google.gerrit.extensions.api.plugins.InstallPluginInput;
import com.google.gerrit.extensions.client.AccountFieldName; import com.google.gerrit.extensions.client.AccountFieldName;
import com.google.gerrit.extensions.client.AuthType; import com.google.gerrit.extensions.client.AuthType;
import com.google.gerrit.extensions.common.AccountDefaultDisplayName;
import com.google.gerrit.extensions.common.AccountVisibility; import com.google.gerrit.extensions.common.AccountVisibility;
import com.google.gerrit.extensions.common.ServerInfo; import com.google.gerrit.extensions.common.ServerInfo;
import com.google.gerrit.server.config.AllProjectsNameProvider; import com.google.gerrit.server.config.AllProjectsNameProvider;
@ -41,6 +42,7 @@ public class ServerInfoIT extends AbstractDaemonTest {
@Test @Test
// accounts // accounts
@GerritConfig(name = "accounts.visibility", value = "VISIBLE_GROUP") @GerritConfig(name = "accounts.visibility", value = "VISIBLE_GROUP")
@GerritConfig(name = "accounts.defaultDisplayName", value = "FIRST_NAME")
// auth // auth
@GerritConfig(name = "auth.type", value = "HTTP") @GerritConfig(name = "auth.type", value = "HTTP")
@ -82,6 +84,7 @@ public class ServerInfoIT extends AbstractDaemonTest {
// accounts // accounts
assertThat(i.accounts.visibility).isEqualTo(AccountVisibility.VISIBLE_GROUP); assertThat(i.accounts.visibility).isEqualTo(AccountVisibility.VISIBLE_GROUP);
assertThat(i.accounts.defaultDisplayName).isEqualTo(AccountDefaultDisplayName.FIRST_NAME);
// auth // auth
assertThat(i.auth.authType).isEqualTo(AuthType.HTTP); assertThat(i.auth.authType).isEqualTo(AuthType.HTTP);