mirror of
https://github.com/scm-manager/scm-manager.git
synced 2025-11-08 06:25:45 +01:00
added store-api
This commit is contained in:
62
scm-core/src/main/java/sonia/scm/store/Store.java
Normal file
62
scm-core/src/main/java/sonia/scm/store/Store.java
Normal file
@@ -0,0 +1,62 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) 2010, Sebastian Sdorra
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
* 3. Neither the name of SCM-Manager; nor the names of its
|
||||||
|
* contributors may be used to endorse or promote products derived from this
|
||||||
|
* software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||||
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* http://bitbucket.org/sdorra/scm-manager
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
package sonia.scm.store;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @author Sebastian Sdorra
|
||||||
|
*
|
||||||
|
* @param <T>
|
||||||
|
*/
|
||||||
|
public interface Store<T>
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public T get();
|
||||||
|
|
||||||
|
//~--- set methods ----------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param obejct
|
||||||
|
*/
|
||||||
|
public void set(T obejct);
|
||||||
|
}
|
||||||
@@ -31,7 +31,7 @@
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
package sonia.scm;
|
package sonia.scm.store;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
62
scm-core/src/main/java/sonia/scm/store/StoreFactory.java
Normal file
62
scm-core/src/main/java/sonia/scm/store/StoreFactory.java
Normal file
@@ -0,0 +1,62 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) 2010, Sebastian Sdorra
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
* 3. Neither the name of SCM-Manager; nor the names of its
|
||||||
|
* contributors may be used to endorse or promote products derived from this
|
||||||
|
* software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||||
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* http://bitbucket.org/sdorra/scm-manager
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
package sonia.scm.store;
|
||||||
|
|
||||||
|
//~--- non-JDK imports --------------------------------------------------------
|
||||||
|
|
||||||
|
import sonia.scm.Initable;
|
||||||
|
|
||||||
|
//~--- JDK imports ------------------------------------------------------------
|
||||||
|
|
||||||
|
import java.io.Closeable;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @author Sebastian Sdorra
|
||||||
|
*/
|
||||||
|
public interface StoreFactory extends Initable, Closeable
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param type
|
||||||
|
* @param name
|
||||||
|
* @param <T>
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public <T> Store<T> getStore(Class<T> type, String name);
|
||||||
|
}
|
||||||
@@ -105,11 +105,9 @@ public abstract class ManagerTestBase<T extends TypedObject,
|
|||||||
tempDirectory = new File(System.getProperty("java.io.tmpdir"),
|
tempDirectory = new File(System.getProperty("java.io.tmpdir"),
|
||||||
UUID.randomUUID().toString());
|
UUID.randomUUID().toString());
|
||||||
assertTrue(tempDirectory.mkdirs());
|
assertTrue(tempDirectory.mkdirs());
|
||||||
manager = createManager();
|
provider = mock(SCMContextProvider.class);
|
||||||
|
|
||||||
SCMContextProvider provider = mock(SCMContextProvider.class);
|
|
||||||
|
|
||||||
when(provider.getBaseDirectory()).thenReturn(tempDirectory);
|
when(provider.getBaseDirectory()).thenReturn(tempDirectory);
|
||||||
|
manager = createManager();
|
||||||
manager.init(provider);
|
manager.init(provider);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -143,6 +141,9 @@ public abstract class ManagerTestBase<T extends TypedObject,
|
|||||||
/** Field description */
|
/** Field description */
|
||||||
protected Manager<T, E> manager;
|
protected Manager<T, E> manager;
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
protected SCMContextProvider provider;
|
||||||
|
|
||||||
/** Field description */
|
/** Field description */
|
||||||
protected File tempDirectory;
|
protected File tempDirectory;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -43,6 +43,7 @@ import com.google.inject.servlet.GuiceServletContextListener;
|
|||||||
import sonia.scm.plugin.DefaultPluginManager;
|
import sonia.scm.plugin.DefaultPluginManager;
|
||||||
import sonia.scm.plugin.PluginManager;
|
import sonia.scm.plugin.PluginManager;
|
||||||
import sonia.scm.repository.RepositoryManager;
|
import sonia.scm.repository.RepositoryManager;
|
||||||
|
import sonia.scm.store.StoreFactory;
|
||||||
import sonia.scm.user.UserManager;
|
import sonia.scm.user.UserManager;
|
||||||
import sonia.scm.util.IOUtil;
|
import sonia.scm.util.IOUtil;
|
||||||
import sonia.scm.web.security.AuthenticationManager;
|
import sonia.scm.web.security.AuthenticationManager;
|
||||||
@@ -81,6 +82,9 @@ public class ContextListener extends GuiceServletContextListener
|
|||||||
|
|
||||||
// close UserManager
|
// close UserManager
|
||||||
IOUtil.close(injector.getInstance(UserManager.class));
|
IOUtil.close(injector.getInstance(UserManager.class));
|
||||||
|
|
||||||
|
// close StoreFactory
|
||||||
|
IOUtil.close(injector.getInstance(StoreFactory.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
super.contextDestroyed(servletContextEvent);
|
super.contextDestroyed(servletContextEvent);
|
||||||
@@ -110,15 +114,19 @@ public class ContextListener extends GuiceServletContextListener
|
|||||||
moduleList.add(0, main);
|
moduleList.add(0, main);
|
||||||
injector = Guice.createInjector(moduleList);
|
injector = Guice.createInjector(moduleList);
|
||||||
|
|
||||||
|
SCMContextProvider context = SCMContext.getContext();
|
||||||
|
|
||||||
|
// init StoreFactory
|
||||||
|
injector.getInstance(StoreFactory.class).init(context);
|
||||||
|
|
||||||
// init RepositoryManager
|
// init RepositoryManager
|
||||||
injector.getInstance(RepositoryManager.class).init(SCMContext.getContext());
|
injector.getInstance(RepositoryManager.class).init(context);
|
||||||
|
|
||||||
// init UserManager
|
// init UserManager
|
||||||
injector.getInstance(UserManager.class).init(SCMContext.getContext());
|
injector.getInstance(UserManager.class).init(context);
|
||||||
|
|
||||||
// init Authenticator
|
// init Authenticator
|
||||||
injector.getInstance(AuthenticationManager.class).init(
|
injector.getInstance(AuthenticationManager.class).init(context);
|
||||||
SCMContext.getContext());
|
|
||||||
|
|
||||||
return injector;
|
return injector;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -53,6 +53,8 @@ import sonia.scm.repository.xml.XmlRepositoryManager;
|
|||||||
import sonia.scm.security.EncryptionHandler;
|
import sonia.scm.security.EncryptionHandler;
|
||||||
import sonia.scm.security.MessageDigestEncryptionHandler;
|
import sonia.scm.security.MessageDigestEncryptionHandler;
|
||||||
import sonia.scm.security.SecurityContext;
|
import sonia.scm.security.SecurityContext;
|
||||||
|
import sonia.scm.store.JAXBStoreFactory;
|
||||||
|
import sonia.scm.store.StoreFactory;
|
||||||
import sonia.scm.user.UserManager;
|
import sonia.scm.user.UserManager;
|
||||||
import sonia.scm.user.xml.XmlUserManager;
|
import sonia.scm.user.xml.XmlUserManager;
|
||||||
import sonia.scm.util.DebugServlet;
|
import sonia.scm.util.DebugServlet;
|
||||||
@@ -152,6 +154,7 @@ public class ScmServletModule extends ServletModule
|
|||||||
|
|
||||||
ScmConfiguration config = getScmConfiguration(context);
|
ScmConfiguration config = getScmConfiguration(context);
|
||||||
|
|
||||||
|
bind(StoreFactory.class).to(JAXBStoreFactory.class);
|
||||||
bind(ScmConfiguration.class).toInstance(config);
|
bind(ScmConfiguration.class).toInstance(config);
|
||||||
bind(PluginManager.class).toInstance(pluginManager);
|
bind(PluginManager.class).toInstance(pluginManager);
|
||||||
bind(EncryptionHandler.class).to(MessageDigestEncryptionHandler.class);
|
bind(EncryptionHandler.class).to(MessageDigestEncryptionHandler.class);
|
||||||
|
|||||||
@@ -54,11 +54,38 @@ import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
|
|||||||
*
|
*
|
||||||
* @author Sebastian Sdorra
|
* @author Sebastian Sdorra
|
||||||
*/
|
*/
|
||||||
@XmlRootElement
|
@XmlRootElement(name = "repository-db")
|
||||||
@XmlAccessorType(XmlAccessType.FIELD)
|
@XmlAccessorType(XmlAccessType.FIELD)
|
||||||
public class XmlRepositoryDatabase
|
public class XmlRepositoryDatabase
|
||||||
{
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param type
|
||||||
|
* @param name
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
static String createKey(String type, String name)
|
||||||
|
{
|
||||||
|
return type.concat(":").concat(name);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param repository
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
static String createKey(Repository repository)
|
||||||
|
{
|
||||||
|
return createKey(repository.getType(), repository.getName());
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Method description
|
* Method description
|
||||||
*
|
*
|
||||||
@@ -220,35 +247,6 @@ public class XmlRepositoryDatabase
|
|||||||
this.lastModified = lastModified;
|
this.lastModified = lastModified;
|
||||||
}
|
}
|
||||||
|
|
||||||
//~--- methods --------------------------------------------------------------
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Method description
|
|
||||||
*
|
|
||||||
*
|
|
||||||
* @param type
|
|
||||||
* @param name
|
|
||||||
*
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
static String createKey(String type, String name)
|
|
||||||
{
|
|
||||||
return type.concat(":").concat(name);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Method description
|
|
||||||
*
|
|
||||||
*
|
|
||||||
* @param repository
|
|
||||||
*
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
static String createKey(Repository repository)
|
|
||||||
{
|
|
||||||
return createKey(repository.getType(), repository.getName());
|
|
||||||
}
|
|
||||||
|
|
||||||
//~--- fields ---------------------------------------------------------------
|
//~--- fields ---------------------------------------------------------------
|
||||||
|
|
||||||
/** Field description */
|
/** Field description */
|
||||||
|
|||||||
@@ -46,7 +46,6 @@ import sonia.scm.ConfigurationException;
|
|||||||
import sonia.scm.HandlerEvent;
|
import sonia.scm.HandlerEvent;
|
||||||
import sonia.scm.SCMContext;
|
import sonia.scm.SCMContext;
|
||||||
import sonia.scm.SCMContextProvider;
|
import sonia.scm.SCMContextProvider;
|
||||||
import sonia.scm.StoreException;
|
|
||||||
import sonia.scm.Type;
|
import sonia.scm.Type;
|
||||||
import sonia.scm.repository.AbstractRepositoryManager;
|
import sonia.scm.repository.AbstractRepositoryManager;
|
||||||
import sonia.scm.repository.PermissionType;
|
import sonia.scm.repository.PermissionType;
|
||||||
@@ -57,13 +56,14 @@ import sonia.scm.repository.RepositoryException;
|
|||||||
import sonia.scm.repository.RepositoryHandler;
|
import sonia.scm.repository.RepositoryHandler;
|
||||||
import sonia.scm.repository.RepositoryHandlerNotFoundException;
|
import sonia.scm.repository.RepositoryHandlerNotFoundException;
|
||||||
import sonia.scm.security.SecurityContext;
|
import sonia.scm.security.SecurityContext;
|
||||||
|
import sonia.scm.store.Store;
|
||||||
|
import sonia.scm.store.StoreFactory;
|
||||||
import sonia.scm.user.User;
|
import sonia.scm.user.User;
|
||||||
import sonia.scm.util.AssertUtil;
|
import sonia.scm.util.AssertUtil;
|
||||||
import sonia.scm.util.IOUtil;
|
import sonia.scm.util.IOUtil;
|
||||||
|
|
||||||
//~--- JDK imports ------------------------------------------------------------
|
//~--- JDK imports ------------------------------------------------------------
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
@@ -74,11 +74,6 @@ import java.util.Map;
|
|||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
import javax.xml.bind.JAXBContext;
|
|
||||||
import javax.xml.bind.JAXBException;
|
|
||||||
import javax.xml.bind.Marshaller;
|
|
||||||
import javax.xml.bind.Unmarshaller;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @author Sebastian Sdorra
|
* @author Sebastian Sdorra
|
||||||
@@ -88,8 +83,7 @@ public class XmlRepositoryManager extends AbstractRepositoryManager
|
|||||||
{
|
{
|
||||||
|
|
||||||
/** Field description */
|
/** Field description */
|
||||||
public static final String DATABASEFILE =
|
public static final String STORE_NAME = "repositories";
|
||||||
"config".concat(File.separator).concat("repositories.xml");
|
|
||||||
|
|
||||||
/** Field description */
|
/** Field description */
|
||||||
private static final Logger logger =
|
private static final Logger logger =
|
||||||
@@ -103,14 +97,16 @@ public class XmlRepositoryManager extends AbstractRepositoryManager
|
|||||||
*
|
*
|
||||||
*
|
*
|
||||||
* @param securityContextProvider
|
* @param securityContextProvider
|
||||||
|
* @param storeFactory
|
||||||
* @param handlerSet
|
* @param handlerSet
|
||||||
*/
|
*/
|
||||||
@Inject
|
@Inject
|
||||||
public XmlRepositoryManager(
|
public XmlRepositoryManager(
|
||||||
Provider<SecurityContext> securityContextProvider,
|
Provider<SecurityContext> securityContextProvider,
|
||||||
Set<RepositoryHandler> handlerSet)
|
StoreFactory storeFactory, Set<RepositoryHandler> handlerSet)
|
||||||
{
|
{
|
||||||
this.securityContextProvider = securityContextProvider;
|
this.securityContextProvider = securityContextProvider;
|
||||||
|
this.store = storeFactory.getStore(XmlRepositoryDatabase.class, STORE_NAME);
|
||||||
handlerMap = new HashMap<String, RepositoryHandler>();
|
handlerMap = new HashMap<String, RepositoryHandler>();
|
||||||
types = new HashSet<Type>();
|
types = new HashSet<Type>();
|
||||||
|
|
||||||
@@ -118,19 +114,6 @@ public class XmlRepositoryManager extends AbstractRepositoryManager
|
|||||||
{
|
{
|
||||||
addHandler(handler);
|
addHandler(handler);
|
||||||
}
|
}
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
JAXBContext context =
|
|
||||||
JAXBContext.newInstance(XmlRepositoryDatabase.class);
|
|
||||||
|
|
||||||
marshaller = context.createMarshaller();
|
|
||||||
unmarshaller = context.createUnmarshaller();
|
|
||||||
}
|
|
||||||
catch (JAXBException ex)
|
|
||||||
{
|
|
||||||
throw new StoreException(ex);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//~--- methods --------------------------------------------------------------
|
//~--- methods --------------------------------------------------------------
|
||||||
@@ -239,17 +222,10 @@ public class XmlRepositoryManager extends AbstractRepositoryManager
|
|||||||
@Override
|
@Override
|
||||||
public void init(SCMContextProvider context)
|
public void init(SCMContextProvider context)
|
||||||
{
|
{
|
||||||
File directory = context.getBaseDirectory();
|
repositoryDB = store.get();
|
||||||
|
|
||||||
repositoryDBFile = new File(directory, DATABASEFILE);
|
if (repositoryDB == null)
|
||||||
|
|
||||||
if (repositoryDBFile.exists())
|
|
||||||
{
|
{
|
||||||
loadDB();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
IOUtil.mkdirs(repositoryDBFile.getParentFile());
|
|
||||||
repositoryDB = new XmlRepositoryDatabase();
|
repositoryDB = new XmlRepositoryDatabase();
|
||||||
repositoryDB.setCreationTime(System.currentTimeMillis());
|
repositoryDB.setCreationTime(System.currentTimeMillis());
|
||||||
}
|
}
|
||||||
@@ -508,38 +484,13 @@ public class XmlRepositoryManager extends AbstractRepositoryManager
|
|||||||
PermissionType.READ);
|
PermissionType.READ);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Method description
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
private void loadDB()
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
repositoryDB =
|
|
||||||
(XmlRepositoryDatabase) unmarshaller.unmarshal(repositoryDBFile);
|
|
||||||
}
|
|
||||||
catch (JAXBException ex)
|
|
||||||
{
|
|
||||||
throw new StoreException(ex);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Method description
|
* Method description
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
private void storeDB()
|
private void storeDB()
|
||||||
{
|
{
|
||||||
try
|
store.set(repositoryDB);
|
||||||
{
|
|
||||||
repositoryDB.setLastModified(System.currentTimeMillis());
|
|
||||||
marshaller.marshal(repositoryDB, repositoryDBFile);
|
|
||||||
}
|
|
||||||
catch (JAXBException ex)
|
|
||||||
{
|
|
||||||
throw new StoreException(ex);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//~--- get methods ----------------------------------------------------------
|
//~--- get methods ----------------------------------------------------------
|
||||||
@@ -609,24 +560,18 @@ public class XmlRepositoryManager extends AbstractRepositoryManager
|
|||||||
|
|
||||||
//~--- fields ---------------------------------------------------------------
|
//~--- fields ---------------------------------------------------------------
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
private final Store<XmlRepositoryDatabase> store;
|
||||||
|
|
||||||
/** Field description */
|
/** Field description */
|
||||||
private Map<String, RepositoryHandler> handlerMap;
|
private Map<String, RepositoryHandler> handlerMap;
|
||||||
|
|
||||||
/** Field description */
|
|
||||||
private Marshaller marshaller;
|
|
||||||
|
|
||||||
/** Field description */
|
/** Field description */
|
||||||
private XmlRepositoryDatabase repositoryDB;
|
private XmlRepositoryDatabase repositoryDB;
|
||||||
|
|
||||||
/** Field description */
|
|
||||||
private File repositoryDBFile;
|
|
||||||
|
|
||||||
/** Field description */
|
/** Field description */
|
||||||
private Provider<SecurityContext> securityContextProvider;
|
private Provider<SecurityContext> securityContextProvider;
|
||||||
|
|
||||||
/** Field description */
|
/** Field description */
|
||||||
private Set<Type> types;
|
private Set<Type> types;
|
||||||
|
|
||||||
/** Field description */
|
|
||||||
private Unmarshaller unmarshaller;
|
|
||||||
}
|
}
|
||||||
|
|||||||
153
scm-webapp/src/main/java/sonia/scm/store/JAXBStore.java
Normal file
153
scm-webapp/src/main/java/sonia/scm/store/JAXBStore.java
Normal file
@@ -0,0 +1,153 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) 2010, Sebastian Sdorra
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
* 3. Neither the name of SCM-Manager; nor the names of its
|
||||||
|
* contributors may be used to endorse or promote products derived from this
|
||||||
|
* software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||||
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* http://bitbucket.org/sdorra/scm-manager
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
package sonia.scm.store;
|
||||||
|
|
||||||
|
//~--- non-JDK imports --------------------------------------------------------
|
||||||
|
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
//~--- JDK imports ------------------------------------------------------------
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
|
||||||
|
import javax.xml.bind.JAXBContext;
|
||||||
|
import javax.xml.bind.JAXBException;
|
||||||
|
import javax.xml.bind.Marshaller;
|
||||||
|
import javax.xml.bind.Unmarshaller;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @author Sebastian Sdorra
|
||||||
|
*
|
||||||
|
* @param <T>
|
||||||
|
*/
|
||||||
|
public class JAXBStore<T> implements Store<T>
|
||||||
|
{
|
||||||
|
|
||||||
|
/** the logger for JAXBStore */
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(JAXBStore.class);
|
||||||
|
|
||||||
|
//~--- constructors ---------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructs ...
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param type
|
||||||
|
* @param configFile
|
||||||
|
*/
|
||||||
|
public JAXBStore(Class<T> type, File configFile)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
JAXBContext context = JAXBContext.newInstance(type);
|
||||||
|
|
||||||
|
marshaller = context.createMarshaller();
|
||||||
|
marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, Boolean.TRUE);
|
||||||
|
unmarshaller = context.createUnmarshaller();
|
||||||
|
this.configFile = configFile;
|
||||||
|
}
|
||||||
|
catch (JAXBException ex)
|
||||||
|
{
|
||||||
|
throw new StoreException(ex);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- get methods ----------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public T get()
|
||||||
|
{
|
||||||
|
T result = null;
|
||||||
|
|
||||||
|
if (configFile.exists())
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
result = (T) unmarshaller.unmarshal(configFile);
|
||||||
|
}
|
||||||
|
catch (JAXBException ex)
|
||||||
|
{
|
||||||
|
throw new StoreException(ex);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- set methods ----------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param object
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void set(T object)
|
||||||
|
{
|
||||||
|
if (logger.isDebugEnabled())
|
||||||
|
{
|
||||||
|
logger.debug("store {} to {}", object.getClass().getName(),
|
||||||
|
configFile.getPath());
|
||||||
|
}
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
marshaller.marshal(object, configFile);
|
||||||
|
}
|
||||||
|
catch (JAXBException ex)
|
||||||
|
{
|
||||||
|
throw new StoreException(ex);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- fields ---------------------------------------------------------------
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
private File configFile;
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
private Marshaller marshaller;
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
private Unmarshaller unmarshaller;
|
||||||
|
}
|
||||||
128
scm-webapp/src/main/java/sonia/scm/store/JAXBStoreFactory.java
Normal file
128
scm-webapp/src/main/java/sonia/scm/store/JAXBStoreFactory.java
Normal file
@@ -0,0 +1,128 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) 2010, Sebastian Sdorra
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
* 3. Neither the name of SCM-Manager; nor the names of its
|
||||||
|
* contributors may be used to endorse or promote products derived from this
|
||||||
|
* software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||||
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* http://bitbucket.org/sdorra/scm-manager
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
package sonia.scm.store;
|
||||||
|
|
||||||
|
//~--- non-JDK imports --------------------------------------------------------
|
||||||
|
|
||||||
|
import com.google.inject.Singleton;
|
||||||
|
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
import sonia.scm.SCMContextProvider;
|
||||||
|
import sonia.scm.util.IOUtil;
|
||||||
|
|
||||||
|
//~--- JDK imports ------------------------------------------------------------
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @author Sebastian Sdorra
|
||||||
|
*/
|
||||||
|
@Singleton
|
||||||
|
public class JAXBStoreFactory implements StoreFactory
|
||||||
|
{
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String CONFIGDIRECTORY_NAME = "config";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String FILE_EXTENSION = ".xml";
|
||||||
|
|
||||||
|
/** the logger for JAXBStoreFactory */
|
||||||
|
private static final Logger logger =
|
||||||
|
LoggerFactory.getLogger(JAXBStoreFactory.class);
|
||||||
|
|
||||||
|
//~--- methods --------------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @throws IOException
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void close() throws IOException
|
||||||
|
{
|
||||||
|
|
||||||
|
// do nothing
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param context
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void init(SCMContextProvider context)
|
||||||
|
{
|
||||||
|
configDirectory = new File(context.getBaseDirectory(),
|
||||||
|
CONFIGDIRECTORY_NAME);
|
||||||
|
IOUtil.mkdirs(configDirectory);
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- get methods ----------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param type
|
||||||
|
* @param name
|
||||||
|
* @param <T>
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public <T> Store<T> getStore(Class<T> type, String name)
|
||||||
|
{
|
||||||
|
File configFile = new File(configDirectory, name.concat(FILE_EXTENSION));
|
||||||
|
|
||||||
|
if (logger.isDebugEnabled())
|
||||||
|
{
|
||||||
|
logger.debug("create store for {} at {}", type.getName(),
|
||||||
|
configFile.getPath());
|
||||||
|
}
|
||||||
|
|
||||||
|
return new JAXBStore<T>(type, configFile);
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- fields ---------------------------------------------------------------
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
private File configDirectory;
|
||||||
|
}
|
||||||
@@ -43,9 +43,10 @@ import org.slf4j.Logger;
|
|||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import sonia.scm.SCMContextProvider;
|
import sonia.scm.SCMContextProvider;
|
||||||
import sonia.scm.StoreException;
|
|
||||||
import sonia.scm.security.ScmSecurityException;
|
import sonia.scm.security.ScmSecurityException;
|
||||||
import sonia.scm.security.SecurityContext;
|
import sonia.scm.security.SecurityContext;
|
||||||
|
import sonia.scm.store.Store;
|
||||||
|
import sonia.scm.store.StoreFactory;
|
||||||
import sonia.scm.user.AbstractUserManager;
|
import sonia.scm.user.AbstractUserManager;
|
||||||
import sonia.scm.user.User;
|
import sonia.scm.user.User;
|
||||||
import sonia.scm.user.UserAllreadyExistException;
|
import sonia.scm.user.UserAllreadyExistException;
|
||||||
@@ -56,7 +57,6 @@ import sonia.scm.util.Util;
|
|||||||
|
|
||||||
//~--- JDK imports ------------------------------------------------------------
|
//~--- JDK imports ------------------------------------------------------------
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
|
|
||||||
@@ -64,10 +64,6 @@ import java.util.Collection;
|
|||||||
import java.util.LinkedList;
|
import java.util.LinkedList;
|
||||||
|
|
||||||
import javax.xml.bind.JAXB;
|
import javax.xml.bind.JAXB;
|
||||||
import javax.xml.bind.JAXBContext;
|
|
||||||
import javax.xml.bind.JAXBException;
|
|
||||||
import javax.xml.bind.Marshaller;
|
|
||||||
import javax.xml.bind.Unmarshaller;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
@@ -81,8 +77,7 @@ public class XmlUserManager extends AbstractUserManager
|
|||||||
public static final String ADMIN_PATH = "/sonia/scm/config/admin-account.xml";
|
public static final String ADMIN_PATH = "/sonia/scm/config/admin-account.xml";
|
||||||
|
|
||||||
/** Field description */
|
/** Field description */
|
||||||
public static final String DATABASEFILE =
|
public static final String STORE_NAME = "users";
|
||||||
"config".concat(File.separator).concat("users.xml");
|
|
||||||
|
|
||||||
/** Field description */
|
/** Field description */
|
||||||
public static final String TYPE = "xml";
|
public static final String TYPE = "xml";
|
||||||
@@ -98,23 +93,14 @@ public class XmlUserManager extends AbstractUserManager
|
|||||||
*
|
*
|
||||||
*
|
*
|
||||||
* @param scurityContextProvider
|
* @param scurityContextProvider
|
||||||
|
* @param storeFactory
|
||||||
*/
|
*/
|
||||||
@Inject
|
@Inject
|
||||||
public XmlUserManager(Provider<SecurityContext> scurityContextProvider)
|
public XmlUserManager(Provider<SecurityContext> scurityContextProvider,
|
||||||
|
StoreFactory storeFactory)
|
||||||
{
|
{
|
||||||
this.scurityContextProvider = scurityContextProvider;
|
this.scurityContextProvider = scurityContextProvider;
|
||||||
|
this.store = storeFactory.getStore(XmlUserDatabase.class, STORE_NAME);
|
||||||
try
|
|
||||||
{
|
|
||||||
JAXBContext context = JAXBContext.newInstance(XmlUserDatabase.class);
|
|
||||||
|
|
||||||
marshaller = context.createMarshaller();
|
|
||||||
unmarshaller = context.createUnmarshaller();
|
|
||||||
}
|
|
||||||
catch (JAXBException ex)
|
|
||||||
{
|
|
||||||
throw new StoreException(ex);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//~--- methods --------------------------------------------------------------
|
//~--- methods --------------------------------------------------------------
|
||||||
@@ -235,17 +221,10 @@ public class XmlUserManager extends AbstractUserManager
|
|||||||
@Override
|
@Override
|
||||||
public void init(SCMContextProvider context)
|
public void init(SCMContextProvider context)
|
||||||
{
|
{
|
||||||
File directory = context.getBaseDirectory();
|
userDB = store.get();
|
||||||
|
|
||||||
userDBFile = new File(directory, DATABASEFILE);
|
if (userDB == null)
|
||||||
|
|
||||||
if (userDBFile.exists())
|
|
||||||
{
|
{
|
||||||
loadDB();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
IOUtil.mkdirs(userDBFile.getParentFile());
|
|
||||||
userDB = new XmlUserDatabase();
|
userDB = new XmlUserDatabase();
|
||||||
userDB.setCreationTime(System.currentTimeMillis());
|
userDB.setCreationTime(System.currentTimeMillis());
|
||||||
createAdminAccount();
|
createAdminAccount();
|
||||||
@@ -395,53 +374,24 @@ public class XmlUserManager extends AbstractUserManager
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Method description
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
private void loadDB()
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
userDB = (XmlUserDatabase) unmarshaller.unmarshal(userDBFile);
|
|
||||||
}
|
|
||||||
catch (JAXBException ex)
|
|
||||||
{
|
|
||||||
throw new StoreException(ex);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Method description
|
* Method description
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
private void storeDB()
|
private void storeDB()
|
||||||
{
|
{
|
||||||
try
|
userDB.setLastModified(System.currentTimeMillis());
|
||||||
{
|
store.set(userDB);
|
||||||
userDB.setLastModified(System.currentTimeMillis());
|
|
||||||
marshaller.marshal(userDB, userDBFile);
|
|
||||||
}
|
|
||||||
catch (JAXBException ex)
|
|
||||||
{
|
|
||||||
throw new StoreException(ex);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//~--- fields ---------------------------------------------------------------
|
//~--- fields ---------------------------------------------------------------
|
||||||
|
|
||||||
/** Field description */
|
|
||||||
private Marshaller marshaller;
|
|
||||||
|
|
||||||
/** Field description */
|
/** Field description */
|
||||||
private Provider<SecurityContext> scurityContextProvider;
|
private Provider<SecurityContext> scurityContextProvider;
|
||||||
|
|
||||||
/** Field description */
|
/** Field description */
|
||||||
private Unmarshaller unmarshaller;
|
private Store<XmlUserDatabase> store;
|
||||||
|
|
||||||
/** Field description */
|
/** Field description */
|
||||||
private XmlUserDatabase userDB;
|
private XmlUserDatabase userDB;
|
||||||
|
|
||||||
/** Field description */
|
|
||||||
private File userDBFile;
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -37,6 +37,8 @@ package sonia.scm.repository;
|
|||||||
|
|
||||||
import sonia.scm.Manager;
|
import sonia.scm.Manager;
|
||||||
import sonia.scm.repository.xml.XmlRepositoryManager;
|
import sonia.scm.repository.xml.XmlRepositoryManager;
|
||||||
|
import sonia.scm.store.JAXBStoreFactory;
|
||||||
|
import sonia.scm.store.StoreFactory;
|
||||||
|
|
||||||
//~--- JDK imports ------------------------------------------------------------
|
//~--- JDK imports ------------------------------------------------------------
|
||||||
|
|
||||||
@@ -63,7 +65,11 @@ public class XmlRepositoryManagerTest extends RepositoryManagerTestBase
|
|||||||
|
|
||||||
handlerSet.add(new DummyRepositoryHandler());
|
handlerSet.add(new DummyRepositoryHandler());
|
||||||
|
|
||||||
return new XmlRepositoryManager(getAdminSecurityContextProvider(),
|
StoreFactory factory = new JAXBStoreFactory();
|
||||||
|
|
||||||
|
factory.init(provider);
|
||||||
|
|
||||||
|
return new XmlRepositoryManager(getAdminSecurityContextProvider(), factory,
|
||||||
handlerSet);
|
handlerSet);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -35,6 +35,8 @@ package sonia.scm.user;
|
|||||||
|
|
||||||
//~--- non-JDK imports --------------------------------------------------------
|
//~--- non-JDK imports --------------------------------------------------------
|
||||||
|
|
||||||
|
import sonia.scm.store.JAXBStoreFactory;
|
||||||
|
import sonia.scm.store.StoreFactory;
|
||||||
import sonia.scm.user.xml.XmlUserManager;
|
import sonia.scm.user.xml.XmlUserManager;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -53,6 +55,10 @@ public class XmlUserManagerTest extends UserManagerTestBase
|
|||||||
@Override
|
@Override
|
||||||
public UserManager createManager()
|
public UserManager createManager()
|
||||||
{
|
{
|
||||||
return new XmlUserManager(getAdminSecurityContextProvider());
|
StoreFactory factory = new JAXBStoreFactory();
|
||||||
|
|
||||||
|
factory.init(provider);
|
||||||
|
|
||||||
|
return new XmlUserManager(getAdminSecurityContextProvider(), factory);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user