
* stable-2.15: Update git submodules [GitwebServlet] Use logger built-in formatting [GitwebServlet] Avoid empty error flooding the logs MoveChangeIT: Test moving a change to a branch where label does not exist GerritPersonIdentProvider: Sanitize user.name and user.email values OutgoingEmail: Reduce visibility of methods OutgoingEmail: Remove unused public methods OutgoingEmail: Annotate methods with @Nullable OutgoingEmail#getUserNameEmailFor: Protect against null accountId OutgoingEmail#getNameEmailFor: Protect against null accountId OutgoingEmail#getName{Email}For: Use helpers from Account AbstractIndexTests: Add --wide option to show-queue command invocation AbstractIndexTests: Add assertions on change index count AbstractIndexTests: Use correct command to index project acceptance/SshSession: Add helper methods to assert about success/failure dev-bazel: Add 'elastic' and 'docker' to list of test groups dev-bazel: Improve section about running Elasticsearch tests AbstractIndexTests: Add coverage for index projects command ReadOnlyChangeIndex: Reduce visibility to package AbstractIndexTests: Refactor to simplify and use Java stream API Elasticsearch: Improve introduction in elasticsearch section Elasticsearch: Add support for version 6.3.0 ElasticVersionTest: Add explicit test for 5.6.10 ElasticContainer: Update to version 5.6.10 Due to incompatibility with methods in the Account class, the following changes done on stable-2.14 are reverted in this merge. A different solution to the potential null account Ids will need to be done for the master branch: I383efdcd7 - OutgoingEmail: Annotate methods with @Nullable Ibb6994a5b - OutgoingEmail#getUserNameEmailFor: Protect against null accountId I8145ca79d - OutgoingEmail#getNameEmailFor: Protect against null accountId I9d55ec3f1 - OutgoingEmail#getName{Email}For: Use helpers from Account This reverts commit4fbf7ffb18
. This reverts commitaac761785b
. This reverts commitd75352f042
. This reverts commitddf27f44c8
. Change-Id: I467d26843e44d02394f2b4cc86d0306ba836368b
50 lines
1.7 KiB
Java
50 lines
1.7 KiB
Java
// Copyright (C) 2009 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.server;
|
|
|
|
import static com.google.common.base.MoreObjects.firstNonNull;
|
|
|
|
import com.google.gerrit.server.config.GerritServerConfig;
|
|
import com.google.inject.Inject;
|
|
import com.google.inject.Provider;
|
|
import com.google.inject.Singleton;
|
|
import org.eclipse.jgit.lib.Config;
|
|
import org.eclipse.jgit.lib.PersonIdent;
|
|
import org.eclipse.jgit.lib.UserConfig;
|
|
|
|
/** Provides {@link PersonIdent} annotated with {@link GerritPersonIdent}. */
|
|
@Singleton
|
|
public class GerritPersonIdentProvider implements Provider<PersonIdent> {
|
|
private final String name;
|
|
private final String email;
|
|
|
|
@Inject
|
|
public GerritPersonIdentProvider(@GerritServerConfig Config cfg) {
|
|
StringBuilder name = new StringBuilder();
|
|
PersonIdent.appendSanitized(
|
|
name, firstNonNull(cfg.getString("user", null, "name"), "Gerrit Code Review"));
|
|
this.name = name.toString();
|
|
|
|
StringBuilder email = new StringBuilder();
|
|
PersonIdent.appendSanitized(email, cfg.get(UserConfig.KEY).getCommitterEmail());
|
|
this.email = email.toString();
|
|
}
|
|
|
|
@Override
|
|
public PersonIdent get() {
|
|
return new PersonIdent(name, email);
|
|
}
|
|
}
|