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.

RuntimeManager.java 5.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232
  1. /*
  2. * Copyright 2013 gitblit.com.
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. package com.gitblit.manager;
  17. import java.io.File;
  18. import java.text.SimpleDateFormat;
  19. import java.util.Date;
  20. import java.util.Locale;
  21. import java.util.Map;
  22. import java.util.TimeZone;
  23. import org.slf4j.Logger;
  24. import org.slf4j.LoggerFactory;
  25. import com.gitblit.Constants;
  26. import com.gitblit.IStoredSettings;
  27. import com.gitblit.Keys;
  28. import com.gitblit.models.ServerSettings;
  29. import com.gitblit.models.ServerStatus;
  30. import com.gitblit.models.SettingModel;
  31. import com.gitblit.utils.StringUtils;
  32. import com.google.inject.Inject;
  33. import com.google.inject.Injector;
  34. import com.google.inject.Singleton;
  35. @Singleton
  36. public class RuntimeManager implements IRuntimeManager {
  37. private final Logger logger = LoggerFactory.getLogger(getClass());
  38. private final IStoredSettings settings;
  39. private final ServerStatus serverStatus;
  40. private final ServerSettings settingsModel;
  41. private File baseFolder;
  42. private TimeZone timezone;
  43. @Inject
  44. private Injector injector;
  45. @Inject
  46. public RuntimeManager(IStoredSettings settings) {
  47. this(settings, null);
  48. }
  49. public RuntimeManager(IStoredSettings settings, File baseFolder) {
  50. this.settings = settings;
  51. this.settingsModel = new ServerSettings();
  52. this.serverStatus = new ServerStatus();
  53. this.baseFolder = baseFolder == null ? new File("") : baseFolder;
  54. }
  55. @Override
  56. public RuntimeManager start() {
  57. logger.info("Basefolder : " + baseFolder.getAbsolutePath());
  58. logger.info("Settings : " + settings.toString());
  59. logTimezone("JVM timezone: ", TimeZone.getDefault());
  60. logTimezone("App timezone: ", getTimezone());
  61. logger.info("JVM locale : " + Locale.getDefault());
  62. logger.info("App locale : " + (getLocale() == null ? "<client>" : getLocale()));
  63. return this;
  64. }
  65. @Override
  66. public RuntimeManager stop() {
  67. return this;
  68. }
  69. @Override
  70. public Injector getInjector() {
  71. return injector;
  72. }
  73. @Override
  74. public File getBaseFolder() {
  75. return baseFolder;
  76. }
  77. @Override
  78. public void setBaseFolder(File folder) {
  79. this.baseFolder = folder;
  80. }
  81. /**
  82. * Returns the boot date of the Gitblit server.
  83. *
  84. * @return the boot date of Gitblit
  85. */
  86. @Override
  87. public Date getBootDate() {
  88. return serverStatus.bootDate;
  89. }
  90. @Override
  91. public ServerSettings getSettingsModel() {
  92. // ensure that the current values are updated in the setting models
  93. for (String key : settings.getAllKeys(null)) {
  94. SettingModel setting = settingsModel.get(key);
  95. if (setting == null) {
  96. // unreferenced setting, create a setting model
  97. setting = new SettingModel();
  98. setting.name = key;
  99. settingsModel.add(setting);
  100. }
  101. setting.currentValue = settings.getString(key, "");
  102. }
  103. // settingsModel.pushScripts = getAllScripts();
  104. return settingsModel;
  105. }
  106. /**
  107. * Returns the preferred timezone for the Gitblit instance.
  108. *
  109. * @return a timezone
  110. */
  111. @Override
  112. public TimeZone getTimezone() {
  113. if (timezone == null) {
  114. String tzid = settings.getString(Keys.web.timezone, null);
  115. if (StringUtils.isEmpty(tzid)) {
  116. timezone = TimeZone.getDefault();
  117. return timezone;
  118. }
  119. timezone = TimeZone.getTimeZone(tzid);
  120. }
  121. return timezone;
  122. }
  123. private void logTimezone(String type, TimeZone zone) {
  124. SimpleDateFormat df = new SimpleDateFormat("z Z");
  125. df.setTimeZone(zone);
  126. String offset = df.format(new Date());
  127. logger.info("{}{} ({})", new Object [] { type, zone.getID(), offset });
  128. }
  129. @Override
  130. public Locale getLocale() {
  131. String lc = settings.getString(Keys.web.forceDefaultLocale, null);
  132. if (!StringUtils.isEmpty(lc)) {
  133. int underscore = lc.indexOf('_');
  134. if (underscore > 0) {
  135. String lang = lc.substring(0, underscore);
  136. String cc = lc.substring(underscore + 1);
  137. return new Locale(lang, cc);
  138. } else {
  139. return new Locale(lc);
  140. }
  141. }
  142. return null;
  143. }
  144. /**
  145. * Is Gitblit running in debug mode?
  146. *
  147. * @return true if Gitblit is running in debug mode
  148. */
  149. @Override
  150. public boolean isDebugMode() {
  151. return settings.getBoolean(Keys.web.debugMode, false);
  152. }
  153. /**
  154. * Returns the file object for the specified configuration key.
  155. *
  156. * @return the file
  157. */
  158. @Override
  159. public File getFileOrFolder(String key, String defaultFileOrFolder) {
  160. String fileOrFolder = settings.getString(key, defaultFileOrFolder);
  161. return getFileOrFolder(fileOrFolder);
  162. }
  163. /**
  164. * Returns the file object which may have it's base-path determined by
  165. * environment variables for running on a cloud hosting service. All Gitblit
  166. * file or folder retrievals are (at least initially) funneled through this
  167. * method so it is the correct point to globally override/alter filesystem
  168. * access based on environment or some other indicator.
  169. *
  170. * @return the file
  171. */
  172. @Override
  173. public File getFileOrFolder(String fileOrFolder) {
  174. return com.gitblit.utils.FileUtils.resolveParameter(Constants.baseFolder$,
  175. baseFolder, fileOrFolder);
  176. }
  177. /**
  178. * Returns the runtime settings.
  179. *
  180. * @return runtime settings
  181. */
  182. @Override
  183. public IStoredSettings getSettings() {
  184. return settings;
  185. }
  186. /**
  187. * Updates the runtime settings.
  188. *
  189. * @param settings
  190. * @return true if the update succeeded
  191. */
  192. @Override
  193. public boolean updateSettings(Map<String, String> updatedSettings) {
  194. return settings.saveSettings(updatedSettings);
  195. }
  196. @Override
  197. public ServerStatus getStatus() {
  198. // update heap memory status
  199. serverStatus.heapAllocated = Runtime.getRuntime().totalMemory();
  200. serverStatus.heapFree = Runtime.getRuntime().freeMemory();
  201. return serverStatus;
  202. }
  203. }