summaryrefslogtreecommitdiffstats
path: root/src/com/gitblit/IUserService.java
diff options
context:
space:
mode:
authorJames Moger <james.moger@gitblit.com>2011-12-07 19:33:10 -0500
committerJames Moger <james.moger@gitblit.com>2011-12-07 19:33:10 -0500
commitfe24a0be919653d9e502f7729d9a804f2e28435d (patch)
treea63d2b07ce300843ae061d435c8891e8e5a930dc /src/com/gitblit/IUserService.java
parent7e8873a14ccc2cb25213489d7d7ba97f09673831 (diff)
downloadgitblit-fe24a0be919653d9e502f7729d9a804f2e28435d.tar.gz
gitblit-fe24a0be919653d9e502f7729d9a804f2e28435d.zip
Teams support.
Teams simplify the management of user-repository access permissions. Teams have a list of restricted repositories. Users are also added to teams and that grants them access to those repositories. Federation and RPC support are still in-progress.
Diffstat (limited to 'src/com/gitblit/IUserService.java')
-rw-r--r--src/com/gitblit/IUserService.java79
1 files changed, 79 insertions, 0 deletions
diff --git a/src/com/gitblit/IUserService.java b/src/com/gitblit/IUserService.java
index e143c794..98dbf0d6 100644
--- a/src/com/gitblit/IUserService.java
+++ b/src/com/gitblit/IUserService.java
@@ -17,6 +17,7 @@ package com.gitblit;
import java.util.List;
+import com.gitblit.models.TeamModel;
import com.gitblit.models.UserModel;
/**
@@ -122,6 +123,84 @@ public interface IUserService {
List<String> getAllUsernames();
/**
+ * Returns the list of all teams available to the login service.
+ *
+ * @return list of all teams
+ * @since 0.8.0
+ */
+ List<String> getAllTeamNames();
+
+ /**
+ * Returns the list of all users who are allowed to bypass the access
+ * restriction placed on the specified repository.
+ *
+ * @param role
+ * the repository name
+ * @return list of all usernames that can bypass the access restriction
+ */
+ List<String> getTeamnamesForRepositoryRole(String role);
+
+ /**
+ * Sets the list of all teams who are allowed to bypass the access
+ * restriction placed on the specified repository.
+ *
+ * @param role
+ * the repository name
+ * @param teamnames
+ * @return true if successful
+ */
+ boolean setTeamnamesForRepositoryRole(String role, List<String> teamnames);
+
+ /**
+ * Retrieve the team object for the specified team name.
+ *
+ * @param teamname
+ * @return a team object or null
+ * @since 0.8.0
+ */
+ TeamModel getTeamModel(String teamname);
+
+ /**
+ * Updates/writes a complete team object.
+ *
+ * @param model
+ * @return true if update is successful
+ * @since 0.8.0
+ */
+ boolean updateTeamModel(TeamModel model);
+
+ /**
+ * Updates/writes and replaces a complete team object keyed by teamname.
+ * This method allows for renaming a team.
+ *
+ * @param teamname
+ * the old teamname
+ * @param model
+ * the team object to use for teamname
+ * @return true if update is successful
+ * @since 0.8.0
+ */
+ boolean updateTeamModel(String teamname, TeamModel model);
+
+ /**
+ * Deletes the team object from the user service.
+ *
+ * @param model
+ * @return true if successful
+ * @since 0.8.0
+ */
+ boolean deleteTeamModel(TeamModel model);
+
+ /**
+ * Delete the team object with the specified teamname
+ *
+ * @param teamname
+ * @return true if successful
+ * @since 0.8.0
+ */
+ boolean deleteTeam(String teamname);
+
+ /**
* Returns the list of all users who are allowed to bypass the access
* restriction placed on the specified repository.
*