summaryrefslogtreecommitdiffstats
path: root/src/main/java/com/gitblit/auth/AuthenticationProvider.java
diff options
context:
space:
mode:
authorJames Moger <james.moger@gitblit.com>2014-09-26 08:01:07 -0600
committerJames Moger <james.moger@gitblit.com>2014-09-26 08:01:07 -0600
commit3636765f0d46e513cb7aa1c665c49b933f435b22 (patch)
tree1aecf7437204b5cfd03cbfbef093e4b2442e49e5 /src/main/java/com/gitblit/auth/AuthenticationProvider.java
parentba04d6d62e443cbd23c0544094aa2e55d01b2d0f (diff)
parent6e3481850db665f9cafc9a554a748e3c9cbd50f5 (diff)
downloadgitblit-3636765f0d46e513cb7aa1c665c49b933f435b22.tar.gz
gitblit-3636765f0d46e513cb7aa1c665c49b933f435b22.zip
Merged #191 "Allow authentication providers to control user and team role changes"
Diffstat (limited to 'src/main/java/com/gitblit/auth/AuthenticationProvider.java')
-rw-r--r--src/main/java/com/gitblit/auth/AuthenticationProvider.java30
1 files changed, 30 insertions, 0 deletions
diff --git a/src/main/java/com/gitblit/auth/AuthenticationProvider.java b/src/main/java/com/gitblit/auth/AuthenticationProvider.java
index 29051df8..da9a7af7 100644
--- a/src/main/java/com/gitblit/auth/AuthenticationProvider.java
+++ b/src/main/java/com/gitblit/auth/AuthenticationProvider.java
@@ -21,6 +21,7 @@ import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.gitblit.Constants.AccountType;
+import com.gitblit.Constants.Role;
import com.gitblit.IStoredSettings;
import com.gitblit.manager.IRuntimeManager;
import com.gitblit.manager.IUserManager;
@@ -138,6 +139,24 @@ public abstract class AuthenticationProvider {
*/
public abstract boolean supportsTeamMembershipChanges();
+ /**
+ * Returns true if the user's role can be changed.
+ *
+ * @param user
+ * @param role
+ * @return true if the user's role can be changed
+ */
+ public abstract boolean supportsRoleChanges(UserModel user, Role role);
+
+ /**
+ * Returns true if the team's role can be changed.
+ *
+ * @param user
+ * @param role
+ * @return true if the team's role can be changed
+ */
+ public abstract boolean supportsRoleChanges(TeamModel team, Role role);
+
@Override
public String toString() {
return getServiceName() + " (" + getClass().getName() + ")";
@@ -199,5 +218,16 @@ public abstract class AuthenticationProvider {
public boolean supportsTeamMembershipChanges() {
return true;
}
+
+ @Override
+ public boolean supportsRoleChanges(UserModel user, Role role) {
+ return true;
+ }
+
+ @Override
+ public boolean supportsRoleChanges(TeamModel team, Role role) {
+ return true;
+ }
+
}
}