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.

AuthenticationProvider.java 4.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203
  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.auth;
  17. import java.io.File;
  18. import org.slf4j.Logger;
  19. import org.slf4j.LoggerFactory;
  20. import com.gitblit.Constants.AccountType;
  21. import com.gitblit.IStoredSettings;
  22. import com.gitblit.manager.IRuntimeManager;
  23. import com.gitblit.manager.IUserManager;
  24. import com.gitblit.models.TeamModel;
  25. import com.gitblit.models.UserModel;
  26. import com.gitblit.utils.ArrayUtils;
  27. import com.gitblit.utils.StringUtils;
  28. public abstract class AuthenticationProvider {
  29. public static NullProvider NULL_PROVIDER = new NullProvider();
  30. protected final Logger logger = LoggerFactory.getLogger(getClass());
  31. protected final String serviceName;
  32. protected File baseFolder;
  33. protected IStoredSettings settings;
  34. protected IRuntimeManager runtimeManager;
  35. protected IUserManager userManager;
  36. protected AuthenticationProvider(String serviceName) {
  37. this.serviceName = serviceName;
  38. }
  39. /**
  40. * Returns the file object for the specified configuration key.
  41. *
  42. * @return the file
  43. */
  44. public File getFileOrFolder(String key, String defaultFileOrFolder) {
  45. return runtimeManager.getFileOrFolder(key, defaultFileOrFolder);
  46. }
  47. public final void setup(IRuntimeManager runtimeManager, IUserManager userManager) {
  48. this.baseFolder = runtimeManager.getBaseFolder();
  49. this.settings = runtimeManager.getSettings();
  50. this.runtimeManager = runtimeManager;
  51. this.userManager = userManager;
  52. setup();
  53. }
  54. public String getServiceName() {
  55. return serviceName;
  56. }
  57. protected void setCookie(UserModel user, char [] password) {
  58. // create a user cookie
  59. if (StringUtils.isEmpty(user.cookie) && !ArrayUtils.isEmpty(password)) {
  60. user.cookie = StringUtils.getSHA1(user.username + new String(password));
  61. }
  62. }
  63. protected void updateUser(UserModel userModel) {
  64. // TODO implement user model change detection
  65. // account for new user and revised user
  66. // username
  67. // displayname
  68. // email address
  69. // cookie
  70. userManager.updateUserModel(userModel);
  71. }
  72. protected void updateTeam(TeamModel teamModel) {
  73. // TODO implement team model change detection
  74. // account for new team and revised team
  75. // memberships
  76. userManager.updateTeamModel(teamModel);
  77. }
  78. public abstract void setup();
  79. public abstract void stop();
  80. public abstract UserModel authenticate(String username, char[] password);
  81. public abstract AccountType getAccountType();
  82. /**
  83. * Does the user service support changes to credentials?
  84. *
  85. * @return true or false
  86. * @since 1.0.0
  87. */
  88. public abstract boolean supportsCredentialChanges();
  89. /**
  90. * Returns true if the user's display name can be changed.
  91. *
  92. * @param user
  93. * @return true if the user service supports display name changes
  94. */
  95. public abstract boolean supportsDisplayNameChanges();
  96. /**
  97. * Returns true if the user's email address can be changed.
  98. *
  99. * @param user
  100. * @return true if the user service supports email address changes
  101. */
  102. public abstract boolean supportsEmailAddressChanges();
  103. /**
  104. * Returns true if the user's team memberships can be changed.
  105. *
  106. * @param user
  107. * @return true if the user service supports team membership changes
  108. */
  109. public abstract boolean supportsTeamMembershipChanges();
  110. @Override
  111. public String toString() {
  112. return getServiceName() + " (" + getClass().getName() + ")";
  113. }
  114. public abstract static class UsernamePasswordAuthenticationProvider extends AuthenticationProvider {
  115. protected UsernamePasswordAuthenticationProvider(String serviceName) {
  116. super(serviceName);
  117. }
  118. @Override
  119. public void stop() {
  120. }
  121. }
  122. public static class NullProvider extends AuthenticationProvider {
  123. protected NullProvider() {
  124. super("NULL");
  125. }
  126. @Override
  127. public void setup() {
  128. }
  129. @Override
  130. public void stop() {
  131. }
  132. @Override
  133. public UserModel authenticate(String username, char[] password) {
  134. return null;
  135. }
  136. @Override
  137. public AccountType getAccountType() {
  138. return AccountType.LOCAL;
  139. }
  140. @Override
  141. public boolean supportsCredentialChanges() {
  142. return true;
  143. }
  144. @Override
  145. public boolean supportsDisplayNameChanges() {
  146. return true;
  147. }
  148. @Override
  149. public boolean supportsEmailAddressChanges() {
  150. return true;
  151. }
  152. @Override
  153. public boolean supportsTeamMembershipChanges() {
  154. return true;
  155. }
  156. }
  157. }