summaryrefslogtreecommitdiffstats
path: root/src/com/gitblit/UserServiceWrapper.java
diff options
context:
space:
mode:
Diffstat (limited to 'src/com/gitblit/UserServiceWrapper.java')
-rw-r--r--src/com/gitblit/UserServiceWrapper.java221
1 files changed, 0 insertions, 221 deletions
diff --git a/src/com/gitblit/UserServiceWrapper.java b/src/com/gitblit/UserServiceWrapper.java
deleted file mode 100644
index 88eab488..00000000
--- a/src/com/gitblit/UserServiceWrapper.java
+++ /dev/null
@@ -1,221 +0,0 @@
-/*
- * Copyright 2011 gitblit.com.
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-package com.gitblit;
-
-import java.io.File;
-import java.io.IOException;
-import java.text.MessageFormat;
-import java.util.List;
-
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import com.gitblit.models.TeamModel;
-import com.gitblit.models.UserModel;
-
-/**
- * This class wraps the default user service and is recommended as the starting
- * point for custom user service implementations.
- *
- * This does seem a little convoluted, but the idea is to allow IUserService to
- * evolve and be replaced without hampering custom implementations.
- *
- * The most common need for a custom IUserService is to override authentication
- * and then delegate to one of Gitblit's user services. Subclassing this allows
- * for authentication customization without having to keep-up-with IUSerService
- * API changes.
- *
- * @author James Moger
- *
- */
-public abstract class UserServiceWrapper implements IUserService {
-
- protected IUserService defaultService;
-
- private final Logger logger = LoggerFactory.getLogger(UserServiceWrapper.class);
-
- public UserServiceWrapper() {
- }
-
- @SuppressWarnings("deprecation")
- @Override
- public final void setup(IStoredSettings settings) {
- File realmFile = GitBlit.getFileOrFolder(Keys.realm.userService, "users.conf");
- if (realmFile.exists()) {
- // load the existing realm file
- if (realmFile.getName().toLowerCase().endsWith(".properties")) {
- // load the v0.5.0 - v0.7.0 properties-based realm file
- defaultService = new FileUserService(realmFile);
-
- // automatically create a users.conf realm file from the
- // original users.properties file
- File usersConfig = new File(realmFile.getParentFile(), "users.conf");
- if (!usersConfig.exists()) {
- logger.info(MessageFormat.format("Automatically creating {0} based on {1}",
- usersConfig.getAbsolutePath(), realmFile.getAbsolutePath()));
- ConfigUserService configService = new ConfigUserService(usersConfig);
- for (String username : defaultService.getAllUsernames()) {
- UserModel userModel = defaultService.getUserModel(username);
- configService.updateUserModel(userModel);
- }
- }
-
- // issue suggestion about switching to users.conf
- logger.warn("Please consider using \"users.conf\" instead of the deprecated \"users.properties\" file");
- } else if (realmFile.getName().toLowerCase().endsWith(".conf")) {
- // load the config-based realm file
- defaultService = new ConfigUserService(realmFile);
- }
- } else {
- // Create a new realm file and add the default admin
- // account. This is necessary for bootstrapping a dynamic
- // environment like running on a cloud service.
- // As of v0.8.0 the default realm file is ConfigUserService.
- try {
- realmFile = GitBlit.getFileOrFolder(Keys.realm.userService, "users.conf");
- realmFile.createNewFile();
- defaultService = new ConfigUserService(realmFile);
- UserModel admin = new UserModel("admin");
- admin.password = "admin";
- admin.canAdmin = true;
- admin.excludeFromFederation = true;
- defaultService.updateUserModel(admin);
- } catch (IOException x) {
- logger.error(MessageFormat.format("COULD NOT CREATE REALM FILE {0}!", realmFile), x);
- }
- }
-
- // call subclass setup
- setupService(settings);
- }
-
- /**
- * Subclasses must implement this method.
- *
- * @param settings
- */
- public abstract void setupService(IStoredSettings settings);
-
- @Override
- public boolean supportsCookies() {
- return defaultService.supportsCookies();
- }
-
- @Override
- public char[] getCookie(UserModel model) {
- return defaultService.getCookie(model);
- }
-
- @Override
- public UserModel authenticate(char[] cookie) {
- return defaultService.authenticate(cookie);
- }
-
- @Override
- public UserModel authenticate(String username, char[] password) {
- return defaultService.authenticate(username, password);
- }
-
- @Override
- public UserModel getUserModel(String username) {
- return defaultService.getUserModel(username);
- }
-
- @Override
- public boolean updateUserModel(UserModel model) {
- return defaultService.updateUserModel(model);
- }
-
- @Override
- public boolean updateUserModel(String username, UserModel model) {
- return defaultService.updateUserModel(username, model);
- }
-
- @Override
- public boolean deleteUserModel(UserModel model) {
- return defaultService.deleteUserModel(model);
- }
-
- @Override
- public boolean deleteUser(String username) {
- return defaultService.deleteUser(username);
- }
-
- @Override
- public List<String> getAllUsernames() {
- return defaultService.getAllUsernames();
- }
-
- @Override
- public List<String> getAllTeamNames() {
- return defaultService.getAllTeamNames();
- }
-
- @Override
- public List<String> getTeamnamesForRepositoryRole(String role) {
- return defaultService.getTeamnamesForRepositoryRole(role);
- }
-
- @Override
- public boolean setTeamnamesForRepositoryRole(String role, List<String> teamnames) {
- return defaultService.setTeamnamesForRepositoryRole(role, teamnames);
- }
-
- @Override
- public TeamModel getTeamModel(String teamname) {
- return defaultService.getTeamModel(teamname);
- }
-
- @Override
- public boolean updateTeamModel(TeamModel model) {
- return defaultService.updateTeamModel(model);
- }
-
- @Override
- public boolean updateTeamModel(String teamname, TeamModel model) {
- return defaultService.updateTeamModel(teamname, model);
- }
-
- @Override
- public boolean deleteTeamModel(TeamModel model) {
- return defaultService.deleteTeamModel(model);
- }
-
- @Override
- public boolean deleteTeam(String teamname) {
- return defaultService.deleteTeam(teamname);
- }
-
- @Override
- public List<String> getUsernamesForRepositoryRole(String role) {
- return defaultService.getUsernamesForRepositoryRole(role);
- }
-
- @Override
- public boolean setUsernamesForRepositoryRole(String role, List<String> usernames) {
- return defaultService.setUsernamesForRepositoryRole(role, usernames);
- }
-
- @Override
- public boolean renameRepositoryRole(String oldRole, String newRole) {
- return defaultService.renameRepositoryRole(oldRole, newRole);
- }
-
- @Override
- public boolean deleteRepositoryRole(String role) {
- return defaultService.deleteRepositoryRole(role);
- }
-}