1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768 |
- /*
- * SonarQube
- * Copyright (C) 2009-2023 SonarSource SA
- * mailto:info AT sonarsource DOT com
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
- package org.sonar.server.platform;
-
- import java.util.Optional;
- import org.sonar.api.Startable;
- import org.sonar.api.utils.MessageException;
- import org.slf4j.Logger;
- import org.slf4j.LoggerFactory;
- import org.sonar.server.platform.db.migration.version.DatabaseVersion;
-
- import static org.sonar.server.log.ServerProcessLogging.STARTUP_LOGGER_NAME;
-
- public class DatabaseServerCompatibility implements Startable {
-
- private static final String HIGHLIGHTER = "################################################################################";
-
- private final DatabaseVersion version;
-
- public DatabaseServerCompatibility(DatabaseVersion version) {
- this.version = version;
- }
-
- @Override
- public void start() {
- DatabaseVersion.Status status = version.getStatus();
- if (status == DatabaseVersion.Status.REQUIRES_DOWNGRADE) {
- throw MessageException.of("Database was upgraded to a more recent version of SonarQube. "
- + "A backup must probably be restored or the DB settings are incorrect.");
- }
- if (status == DatabaseVersion.Status.REQUIRES_UPGRADE) {
- Optional<Long> currentVersion = this.version.getVersion();
- if (currentVersion.isPresent() && currentVersion.get() < DatabaseVersion.MIN_UPGRADE_VERSION) {
- throw MessageException.of("The version of SonarQube is too old. Please upgrade to the Long Term Support version first.");
- }
-
- String msg = "The database must be manually upgraded. Please backup the database and browse /setup. "
- + "For more information: https://docs.sonarsource.com/sonarqube/latest/setup/upgrading";
- LoggerFactory.getLogger(DatabaseServerCompatibility.class).warn(msg);
- Logger logger = LoggerFactory.getLogger(STARTUP_LOGGER_NAME);
- logger.warn(HIGHLIGHTER);
- logger.warn(msg);
- logger.warn(HIGHLIGHTER);
- }
- }
-
- @Override
- public void stop() {
- // do nothing
- }
- }
|