* stable-2.16: Use dom-if instead of css when hiding gr-http-password MysqlAccountPatchReviewStore: Fix duplicate key detection Bazel: Bump minimum supported version to 0.26.1 Change-Id: I5e15b9c04145336c63640ea5cf359648c7e063b3
68 lines
2.4 KiB
Java
68 lines
2.4 KiB
Java
// Copyright (C) 2017 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.schema;
|
|
|
|
import com.google.gerrit.exceptions.DuplicateKeyException;
|
|
import com.google.gerrit.exceptions.StorageException;
|
|
import com.google.gerrit.server.config.GerritServerConfig;
|
|
import com.google.gerrit.server.config.SitePaths;
|
|
import com.google.gerrit.server.config.ThreadSettingsConfig;
|
|
import com.google.inject.Inject;
|
|
import com.google.inject.Singleton;
|
|
import java.sql.SQLException;
|
|
import java.sql.Statement;
|
|
import org.eclipse.jgit.lib.Config;
|
|
|
|
@Singleton
|
|
public class MysqlAccountPatchReviewStore extends JdbcAccountPatchReviewStore {
|
|
|
|
@Inject
|
|
MysqlAccountPatchReviewStore(
|
|
@GerritServerConfig Config cfg,
|
|
SitePaths sitePaths,
|
|
ThreadSettingsConfig threadSettingsConfig) {
|
|
super(cfg, sitePaths, threadSettingsConfig);
|
|
}
|
|
|
|
@Override
|
|
public StorageException convertError(String op, SQLException err) {
|
|
switch (err.getErrorCode()) {
|
|
case 1022: // ER_DUP_KEY
|
|
case 1062: // ER_DUP_ENTRY
|
|
case 1169: // ER_DUP_UNIQUE;
|
|
return new DuplicateKeyException("ACCOUNT_PATCH_REVIEWS", err);
|
|
|
|
default:
|
|
if (err.getCause() == null && err.getNextException() != null) {
|
|
err.initCause(err.getNextException());
|
|
}
|
|
return new StorageException(op + " failure on ACCOUNT_PATCH_REVIEWS", err);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
protected void doCreateTable(Statement stmt) throws SQLException {
|
|
stmt.executeUpdate(
|
|
"CREATE TABLE IF NOT EXISTS account_patch_reviews ("
|
|
+ "account_id INTEGER DEFAULT 0 NOT NULL, "
|
|
+ "change_id INTEGER DEFAULT 0 NOT NULL, "
|
|
+ "patch_set_id INTEGER DEFAULT 0 NOT NULL, "
|
|
+ "file_name VARCHAR(255) DEFAULT '' NOT NULL, "
|
|
+ "CONSTRAINT primary_key_account_patch_reviews "
|
|
+ "PRIMARY KEY (change_id, patch_set_id, account_id, file_name)"
|
|
+ ")");
|
|
}
|
|
}
|