blob: b273ab29942d1ada3a4bbf7d952f83bcaf3c4208 [file] [log] [blame]
// 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.plugins.codeowners.backend.proto;
import com.google.common.annotations.VisibleForTesting;
import com.google.gerrit.plugins.codeowners.backend.AbstractFileBasedCodeOwnerBackend;
import com.google.gerrit.plugins.codeowners.backend.CodeOwnerConfig;
import com.google.gerrit.plugins.codeowners.backend.CodeOwnerConfigFile;
import com.google.gerrit.plugins.codeowners.backend.PathExpressionMatcher;
import com.google.gerrit.plugins.codeowners.backend.SimplePathExpressionMatcher;
import com.google.gerrit.plugins.codeowners.backend.config.CodeOwnersPluginConfiguration;
import com.google.gerrit.server.GerritPersonIdent;
import com.google.gerrit.server.git.GitRepositoryManager;
import com.google.gerrit.server.git.meta.MetaDataUpdate;
import com.google.gerrit.server.update.RetryHelper;
import com.google.inject.Inject;
import com.google.inject.Singleton;
import java.util.Optional;
import org.eclipse.jgit.lib.PersonIdent;
/**
* Backend that supports a proto syntax for storing {@link CodeOwnerConfig}s.
*
* <p><strong>Note:</strong> This backend is currently only experimental and should not be used in
* production. The reason for this is that the proto syntax is not finalized yet and backwards
* incompatible changes to it are likely to happen. Instead it's recommended to use the {@link
* com.google.gerrit.plugins.codeowners.backend.findowners.FindOwnersBackend}.
*/
@Singleton
public class ProtoBackend extends AbstractFileBasedCodeOwnerBackend {
/** The ID of this code owner backend. */
public static final String ID = "proto";
/** The name of the files in which {@link CodeOwnerConfig}s are stored. */
@VisibleForTesting public static final String CODE_OWNER_CONFIG_FILE_NAME = "OWNERS_METADATA";
@Inject
ProtoBackend(
CodeOwnersPluginConfiguration codeOwnersPluginConfiguration,
GitRepositoryManager repoManager,
@GerritPersonIdent PersonIdent serverIdent,
MetaDataUpdate.InternalFactory metaDataUpdateInternalFactory,
RetryHelper retryHelper,
CodeOwnerConfigFile.Factory codeOwnerConfigFileFactory,
ProtoCodeOwnerConfigParser codeOwnerConfigParser) {
super(
codeOwnersPluginConfiguration,
repoManager,
serverIdent,
metaDataUpdateInternalFactory,
retryHelper,
CODE_OWNER_CONFIG_FILE_NAME,
codeOwnerConfigFileFactory,
codeOwnerConfigParser);
}
@Override
public Optional<PathExpressionMatcher> getPathExpressionMatcher() {
return Optional.of(SimplePathExpressionMatcher.INSTANCE);
}
}