You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

GlobalContainer.java 7.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  1. /*
  2. * SonarQube
  3. * Copyright (C) 2009-2021 SonarSource SA
  4. * mailto:info AT sonarsource DOT com
  5. *
  6. * This program is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU Lesser General Public
  8. * License as published by the Free Software Foundation; either
  9. * version 3 of the License, or (at your option) any later version.
  10. *
  11. * This program is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  14. * Lesser General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU Lesser General Public License
  17. * along with this program; if not, write to the Free Software Foundation,
  18. * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  19. */
  20. package org.sonar.scanner.bootstrap;
  21. import java.time.Clock;
  22. import java.util.List;
  23. import java.util.Map;
  24. import org.apache.commons.lang.StringUtils;
  25. import org.sonar.api.CoreProperties;
  26. import org.sonar.api.Plugin;
  27. import org.sonar.api.SonarEdition;
  28. import org.sonar.api.SonarQubeSide;
  29. import org.sonar.api.SonarQubeVersion;
  30. import org.sonar.api.SonarRuntime;
  31. import org.sonar.api.internal.MetadataLoader;
  32. import org.sonar.api.internal.SonarRuntimeImpl;
  33. import org.sonar.api.notifications.AnalysisWarnings;
  34. import org.sonar.api.utils.MessageException;
  35. import org.sonar.api.utils.System2;
  36. import org.sonar.api.utils.UriReader;
  37. import org.sonar.api.utils.Version;
  38. import org.sonar.api.utils.log.Logger;
  39. import org.sonar.api.utils.log.Loggers;
  40. import org.sonar.core.extension.CoreExtensionRepositoryImpl;
  41. import org.sonar.core.extension.CoreExtensionsLoader;
  42. import org.sonar.core.platform.ComponentContainer;
  43. import org.sonar.core.platform.PluginClassLoader;
  44. import org.sonar.core.platform.PluginClassloaderFactory;
  45. import org.sonar.core.platform.PluginInfo;
  46. import org.sonar.core.platform.PluginRepository;
  47. import org.sonar.core.util.DefaultHttpDownloader;
  48. import org.sonar.core.util.UuidFactoryImpl;
  49. import org.sonar.scanner.extension.ScannerCoreExtensionsInstaller;
  50. import org.sonar.scanner.notifications.DefaultAnalysisWarnings;
  51. import org.sonar.scanner.platform.DefaultServer;
  52. import org.sonar.scanner.repository.DefaultMetricsRepositoryLoader;
  53. import org.sonar.scanner.repository.DefaultNewCodePeriodLoader;
  54. import org.sonar.scanner.repository.MetricsRepositoryLoader;
  55. import org.sonar.scanner.repository.MetricsRepositoryProvider;
  56. import org.sonar.scanner.repository.NewCodePeriodLoader;
  57. import org.sonar.scanner.repository.settings.DefaultGlobalSettingsLoader;
  58. import org.sonar.scanner.repository.settings.GlobalSettingsLoader;
  59. import org.sonar.scanner.scan.ProjectScanContainer;
  60. public class GlobalContainer extends ComponentContainer {
  61. private static final Logger LOG = Loggers.get(GlobalContainer.class);
  62. private final Map<String, String> scannerProperties;
  63. private GlobalContainer(Map<String, String> scannerProperties) {
  64. super();
  65. this.scannerProperties = scannerProperties;
  66. }
  67. public static GlobalContainer create(Map<String, String> scannerProperties, List<?> extensions) {
  68. GlobalContainer container = new GlobalContainer(scannerProperties);
  69. container.add(extensions);
  70. return container;
  71. }
  72. @Override
  73. protected void doBeforeStart() {
  74. ScannerProperties rawScannerProperties = new ScannerProperties(scannerProperties);
  75. GlobalAnalysisMode globalMode = new GlobalAnalysisMode(rawScannerProperties);
  76. add(rawScannerProperties);
  77. add(globalMode);
  78. addBootstrapComponents();
  79. }
  80. private static void checkJavaVersion(AnalysisWarnings analysisWarnings) {
  81. try {
  82. String.class.getMethod("isBlank");
  83. } catch (NoSuchMethodException e) {
  84. LOG.warn("SonarScanner will require Java 11 to run, starting in SonarQube 9.x");
  85. analysisWarnings.addUnique("SonarScanner will require Java 11 to run, starting in SonarQube 9.x. Please upgrade the version of Java that executes the scanner.");
  86. }
  87. }
  88. private void addBootstrapComponents() {
  89. Version apiVersion = MetadataLoader.loadVersion(System2.INSTANCE);
  90. SonarEdition edition = MetadataLoader.loadEdition(System2.INSTANCE);
  91. DefaultAnalysisWarnings analysisWarnings = new DefaultAnalysisWarnings(System2.INSTANCE);
  92. if (edition != SonarEdition.SONARCLOUD) {
  93. checkJavaVersion(analysisWarnings);
  94. }
  95. LOG.debug("{} {}", edition.getLabel(), apiVersion);
  96. add(
  97. // plugins
  98. ScannerPluginRepository.class,
  99. PluginClassLoader.class,
  100. PluginClassloaderFactory.class,
  101. ScannerPluginJarExploder.class,
  102. ExtensionInstaller.class,
  103. new SonarQubeVersion(apiVersion),
  104. new GlobalServerSettingsProvider(),
  105. new GlobalConfigurationProvider(),
  106. new ScannerWsClientProvider(),
  107. DefaultServer.class,
  108. new GlobalTempFolderProvider(),
  109. DefaultHttpDownloader.class,
  110. analysisWarnings,
  111. UriReader.class,
  112. PluginFiles.class,
  113. System2.INSTANCE,
  114. Clock.systemDefaultZone(),
  115. new MetricsRepositoryProvider(),
  116. UuidFactoryImpl.INSTANCE);
  117. addIfMissing(SonarRuntimeImpl.forSonarQube(apiVersion, SonarQubeSide.SCANNER, edition), SonarRuntime.class);
  118. addIfMissing(ScannerPluginInstaller.class, PluginInstaller.class);
  119. add(CoreExtensionRepositoryImpl.class, CoreExtensionsLoader.class, ScannerCoreExtensionsInstaller.class);
  120. addIfMissing(DefaultGlobalSettingsLoader.class, GlobalSettingsLoader.class);
  121. addIfMissing(DefaultNewCodePeriodLoader.class, NewCodePeriodLoader.class);
  122. addIfMissing(DefaultMetricsRepositoryLoader.class, MetricsRepositoryLoader.class);
  123. }
  124. @Override
  125. protected void doAfterStart() {
  126. installPlugins();
  127. loadCoreExtensions();
  128. long startTime = System.currentTimeMillis();
  129. String taskKey = StringUtils.defaultIfEmpty(scannerProperties.get(CoreProperties.TASK), CoreProperties.SCAN_TASK);
  130. if (taskKey.equals("views")) {
  131. throw MessageException.of("The task 'views' was removed with SonarQube 7.1. " +
  132. "You can safely remove this call since portfolios and applications are automatically re-calculated.");
  133. } else if (!taskKey.equals(CoreProperties.SCAN_TASK)) {
  134. throw MessageException.of("Tasks support was removed in SonarQube 7.6.");
  135. }
  136. String analysisMode = StringUtils.defaultIfEmpty(scannerProperties.get("sonar.analysis.mode"), "publish");
  137. if (!analysisMode.equals("publish")) {
  138. throw MessageException.of("The preview mode, along with the 'sonar.analysis.mode' parameter, is no more supported. You should stop using this parameter.");
  139. }
  140. new ProjectScanContainer(this).execute();
  141. LOG.info("Analysis total time: {}", formatTime(System.currentTimeMillis() - startTime));
  142. }
  143. private void installPlugins() {
  144. PluginRepository pluginRepository = getComponentByType(PluginRepository.class);
  145. for (PluginInfo pluginInfo : pluginRepository.getPluginInfos()) {
  146. Plugin instance = pluginRepository.getPluginInstance(pluginInfo.getKey());
  147. addExtension(pluginInfo, instance);
  148. }
  149. }
  150. private void loadCoreExtensions() {
  151. CoreExtensionsLoader loader = getComponentByType(CoreExtensionsLoader.class);
  152. loader.load();
  153. }
  154. static String formatTime(long time) {
  155. long h = time / (60 * 60 * 1000);
  156. long m = (time - h * 60 * 60 * 1000) / (60 * 1000);
  157. long s = (time - h * 60 * 60 * 1000 - m * 60 * 1000) / 1000;
  158. long ms = time % 1000;
  159. final String format;
  160. if (h > 0) {
  161. format = "%1$d:%2$02d:%3$02d.%4$03d s";
  162. } else if (m > 0) {
  163. format = "%2$d:%3$02d.%4$03d s";
  164. } else {
  165. format = "%3$d.%4$03d s";
  166. }
  167. return String.format(format, h, m, s, ms);
  168. }
  169. }