Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310
  1. /*
  2. * Copyright 2012 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.wicket.pages;
  17. import java.io.Serializable;
  18. import java.util.ArrayList;
  19. import java.util.Arrays;
  20. import java.util.Collections;
  21. import java.util.Comparator;
  22. import java.util.List;
  23. import java.util.Locale;
  24. import org.apache.wicket.PageParameters;
  25. import org.apache.wicket.ajax.AjaxRequestTarget;
  26. import org.apache.wicket.ajax.markup.html.form.AjaxButton;
  27. import org.apache.wicket.markup.html.basic.Label;
  28. import org.apache.wicket.markup.html.form.Form;
  29. import org.apache.wicket.markup.html.panel.Fragment;
  30. import org.apache.wicket.markup.repeater.Item;
  31. import org.apache.wicket.markup.repeater.data.DataView;
  32. import org.apache.wicket.markup.repeater.data.ListDataProvider;
  33. import org.apache.wicket.model.IModel;
  34. import org.apache.wicket.model.Model;
  35. import com.gitblit.GitBlitException;
  36. import com.gitblit.Keys;
  37. import com.gitblit.models.Menu.ParameterMenuItem;
  38. import com.gitblit.models.NavLink;
  39. import com.gitblit.models.NavLink.DropDownPageMenuNavLink;
  40. import com.gitblit.models.ProjectModel;
  41. import com.gitblit.models.RepositoryModel;
  42. import com.gitblit.models.UserModel;
  43. import com.gitblit.utils.StringUtils;
  44. import com.gitblit.wicket.GitBlitWebApp;
  45. import com.gitblit.wicket.GitBlitWebSession;
  46. import com.gitblit.wicket.GitblitRedirectException;
  47. import com.gitblit.wicket.WicketUtils;
  48. import com.gitblit.wicket.panels.BooleanOption;
  49. import com.gitblit.wicket.panels.ChoiceOption;
  50. import com.gitblit.wicket.panels.ProjectRepositoryPanel;
  51. import com.gitblit.wicket.panels.SshKeysPanel;
  52. import com.gitblit.wicket.panels.TextOption;
  53. import com.gitblit.wicket.panels.UserTitlePanel;
  54. public class UserPage extends RootPage {
  55. List<ProjectModel> projectModels = new ArrayList<ProjectModel>();
  56. public UserPage() {
  57. super();
  58. throw new GitblitRedirectException(GitBlitWebApp.get().getHomePage());
  59. }
  60. public UserPage(PageParameters params) {
  61. super(params);
  62. setup(params);
  63. }
  64. @Override
  65. protected boolean reusePageParameters() {
  66. return true;
  67. }
  68. private void setup(PageParameters params) {
  69. setupPage("", "");
  70. // check to see if we should display a login message
  71. boolean authenticateView = app().settings().getBoolean(Keys.web.authenticateViewPages, true);
  72. if (authenticateView && !GitBlitWebSession.get().isLoggedIn()) {
  73. authenticationError("Please login");
  74. return;
  75. }
  76. String userName = WicketUtils.getUsername(params);
  77. if (StringUtils.isEmpty(userName)) {
  78. throw new GitblitRedirectException(GitBlitWebApp.get().getHomePage());
  79. }
  80. UserModel user = app().users().getUserModel(userName);
  81. if (user == null) {
  82. // construct a temporary user model
  83. user = new UserModel(userName);
  84. }
  85. add(new UserTitlePanel("userTitlePanel", user, user.username));
  86. UserModel sessionUser = GitBlitWebSession.get().getUser();
  87. boolean isMyProfile = sessionUser != null && sessionUser.equals(user);
  88. if (isMyProfile) {
  89. addPreferences(user);
  90. if (app().gitblit().isServingSSH()) {
  91. // show the SSH key management tab
  92. addSshKeys(user);
  93. } else {
  94. // SSH daemon is disabled, hide keys tab
  95. add(new Label("sshKeysLink").setVisible(false));
  96. add(new Label("sshKeysTab").setVisible(false));
  97. }
  98. } else {
  99. // visiting user
  100. add(new Label("preferencesLink").setVisible(false));
  101. add(new Label("preferencesTab").setVisible(false));
  102. add(new Label("sshKeysLink").setVisible(false));
  103. add(new Label("sshKeysTab").setVisible(false));
  104. }
  105. List<RepositoryModel> repositories = getRepositories(params);
  106. Collections.sort(repositories, new Comparator<RepositoryModel>() {
  107. @Override
  108. public int compare(RepositoryModel o1, RepositoryModel o2) {
  109. // reverse-chronological sort
  110. return o2.lastChange.compareTo(o1.lastChange);
  111. }
  112. });
  113. final ListDataProvider<RepositoryModel> dp = new ListDataProvider<RepositoryModel>(repositories);
  114. DataView<RepositoryModel> dataView = new DataView<RepositoryModel>("repositoryList", dp) {
  115. private static final long serialVersionUID = 1L;
  116. @Override
  117. public void populateItem(final Item<RepositoryModel> item) {
  118. final RepositoryModel entry = item.getModelObject();
  119. ProjectRepositoryPanel row = new ProjectRepositoryPanel("repository",
  120. getLocalizer(), this, showAdmin, entry, getAccessRestrictions());
  121. item.add(row);
  122. }
  123. };
  124. add(dataView);
  125. }
  126. @Override
  127. protected void addDropDownMenus(List<NavLink> navLinks) {
  128. PageParameters params = getPageParameters();
  129. DropDownPageMenuNavLink menu = new DropDownPageMenuNavLink("gb.filters",
  130. UserPage.class);
  131. // preserve time filter option on repository choices
  132. menu.menuItems.addAll(getRepositoryFilterItems(params));
  133. // preserve repository filter option on time choices
  134. menu.menuItems.addAll(getTimeFilterItems(params));
  135. if (menu.menuItems.size() > 0) {
  136. // Reset Filter
  137. menu.menuItems.add(new ParameterMenuItem(getString("gb.reset")));
  138. }
  139. navLinks.add(menu);
  140. }
  141. private void addPreferences(UserModel user) {
  142. // add preferences
  143. Form<Void> prefs = new Form<Void>("prefsForm");
  144. List<Language> languages = Arrays.asList(
  145. new Language("English","en"),
  146. new Language("Español", "es"),
  147. new Language("Français", "fr"),
  148. new Language("日本語", "ja"),
  149. new Language("한국말", "ko"),
  150. new Language("Nederlands", "nl"),
  151. new Language("Norsk", "no"),
  152. new Language("Język Polski", "pl"),
  153. new Language("Português", "pt_BR"),
  154. new Language("中文", "zh_CN"));
  155. Locale locale = user.getPreferences().getLocale();
  156. if (locale == null) {
  157. // user has not specified language preference
  158. // try server default preference
  159. String lc = app().settings().getString(Keys.web.forceDefaultLocale, null);
  160. if (StringUtils.isEmpty(lc)) {
  161. // server default language is not configured
  162. // try browser preference
  163. Locale sessionLocale = GitBlitWebSession.get().getLocale();
  164. if (sessionLocale != null) {
  165. locale = sessionLocale;
  166. }
  167. } else {
  168. }
  169. }
  170. Language preferredLanguage = null;
  171. if (locale != null) {
  172. String localeCode = locale.getLanguage();
  173. if (!StringUtils.isEmpty(locale.getCountry())) {
  174. localeCode += "_" + locale.getCountry();
  175. }
  176. for (Language language : languages) {
  177. if (language.code.equals(localeCode)) {
  178. // language_COUNTRY match
  179. preferredLanguage = language;
  180. } else if (preferredLanguage != null && language.code.startsWith(locale.getLanguage())) {
  181. // language match
  182. preferredLanguage = language;
  183. }
  184. }
  185. }
  186. final IModel<String> displayName = Model.of(user.getDisplayName());
  187. final IModel<String> emailAddress = Model.of(user.emailAddress == null ? "" : user.emailAddress);
  188. final IModel<Language> language = Model.of(preferredLanguage);
  189. final IModel<Boolean> emailMeOnMyTicketChanges = Model.of(user.getPreferences().isEmailMeOnMyTicketChanges());
  190. prefs.add(new TextOption("displayName",
  191. getString("gb.displayName"),
  192. getString("gb.displayNameDescription"),
  193. displayName).setVisible(app().authentication().supportsDisplayNameChanges(user)));
  194. prefs.add(new TextOption("emailAddress",
  195. getString("gb.emailAddress"),
  196. getString("gb.emailAddressDescription"),
  197. emailAddress).setVisible(app().authentication().supportsEmailAddressChanges(user)));
  198. prefs.add(new ChoiceOption<Language>("language",
  199. getString("gb.languagePreference"),
  200. getString("gb.languagePreferenceDescription"),
  201. language,
  202. languages));
  203. prefs.add(new BooleanOption("emailMeOnMyTicketChanges",
  204. getString("gb.emailMeOnMyTicketChanges"),
  205. getString("gb.emailMeOnMyTicketChangesDescription"),
  206. emailMeOnMyTicketChanges).setVisible(app().notifier().isSendingMail()));
  207. prefs.add(new AjaxButton("save") {
  208. private static final long serialVersionUID = 1L;
  209. @Override
  210. protected void onSubmit(AjaxRequestTarget target, Form<?> form) {
  211. UserModel user = GitBlitWebSession.get().getUser();
  212. user.displayName = displayName.getObject();
  213. user.emailAddress = emailAddress.getObject();
  214. Language lang = language.getObject();
  215. if (lang != null) {
  216. user.getPreferences().setLocale(lang.code);
  217. }
  218. user.getPreferences().setEmailMeOnMyTicketChanges(emailMeOnMyTicketChanges.getObject());
  219. try {
  220. app().gitblit().reviseUser(user.username, user);
  221. setRedirect(true);
  222. setResponsePage(UserPage.class, WicketUtils.newUsernameParameter(user.username));
  223. } catch (GitBlitException e) {
  224. // logger.error("Failed to update user " + user.username, e);
  225. // error(getString("gb.failedToUpdateUser"), false);
  226. }
  227. }
  228. });
  229. // add the preferences tab
  230. add(new Fragment("preferencesLink", "preferencesLinkFragment", this).setRenderBodyOnly(true));
  231. Fragment fragment = new Fragment("preferencesTab", "preferencesTabFragment", this);
  232. fragment.add(prefs);
  233. add(fragment.setRenderBodyOnly(true));
  234. }
  235. private void addSshKeys(final UserModel user) {
  236. Fragment keysTab = new Fragment("sshKeysTab", "sshKeysTabFragment", this);
  237. keysTab.add(new SshKeysPanel("sshKeysPanel", user, getClass(), getPageParameters()));
  238. // add the SSH keys tab
  239. add(new Fragment("sshKeysLink", "sshKeysLinkFragment", this).setRenderBodyOnly(true));
  240. add(keysTab.setRenderBodyOnly(true));
  241. }
  242. private class Language implements Serializable {
  243. private static final long serialVersionUID = 1L;
  244. final String name;
  245. final String code;
  246. public Language(String name, String code) {
  247. this.name = name;
  248. this.code = code;
  249. }
  250. @Override
  251. public String toString() {
  252. return name + " (" + code +")";
  253. }
  254. }
  255. }