/*
- * Copyright (C) 2007-2012 Mathieu Baudier
+ * Copyright (C) 2007-2012 Argeo GmbH
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
package org.argeo.security.ui.admin.editors;
import javax.jcr.Node;
+import javax.jcr.Repository;
import javax.jcr.RepositoryException;
import javax.jcr.Session;
import org.argeo.ArgeoException;
-import org.argeo.jcr.ArgeoNames;
+import org.argeo.jcr.JcrUtils;
import org.argeo.jcr.UserJcrUtils;
import org.argeo.security.UserAdminService;
import org.argeo.security.jcr.JcrUserDetails;
/** Editor for an Argeo user. */
public class ArgeoUserEditor extends FormEditor {
- public final static String ID = "org.argeo.security.ui.admin.adminArgeoUserEditor";
+ public final static String ID = SecurityAdminPlugin.PLUGIN_ID
+ + ".adminArgeoUserEditor";
- private JcrUserDetails userDetails;
- private Node userHome;
- private UserAdminService userAdminService;
+ /* DEPENDENCY INJECTION */
private Session session;
+ private UserAdminService userAdminService;
+
+ // private Node userHome;
+ private Node userProfile;
+ private JcrUserDetails userDetails;
public void init(IEditorSite site, IEditorInput input)
throws PartInitException {
super.init(site, input);
String username = ((ArgeoUserEditorInput) getEditorInput())
.getUsername();
- userHome = UserJcrUtils.getUserHome(session, username);
+ userProfile = UserJcrUtils.getUserProfile(session, username);
if (userAdminService.userExists(username)) {
userDetails = (JcrUserDetails) userAdminService
protected void addPages() {
try {
- addPage(new DefaultUserMainPage(this,
- userHome.getNode(ArgeoNames.ARGEO_PROFILE)));
+ addPage(new DefaultUserMainPage(this, userProfile));
addPage(new UserRolesPage(this, userDetails, userAdminService));
} catch (Exception e) {
throw new ArgeoException("Cannot add pages", e);
userRolesPage.setUserDetails(userDetails);
+ // FIXME rather use a refresh command. Fails when called by another
+ // view.
// refresh users view
IWorkbench iw = SecurityAdminPlugin.getDefault().getWorkbench();
UsersView usersView = (UsersView) iw.getActiveWorkbenchWindow()
.getActivePage().findView(UsersView.ID);
- usersView.refresh();
+ if (usersView != null)
+ usersView.refresh();
}
@Override
userRolesPage.refresh();
}
+ @Override
+ public void dispose() {
+ JcrUtils.logoutQuietly(session);
+ super.dispose();
+ }
+
+ /* DEPENDENCY INJECTION */
public void setUserAdminService(UserAdminService userAdminService) {
this.userAdminService = userAdminService;
}
-
- public void setSession(Session session) {
- this.session = session;
+
+ public void setRepository(Repository repository) {
+ try {
+ session = repository.login();
+ } catch (RepositoryException re) {
+ throw new ArgeoException("Unable to initialise local session", re);
+ }
}
}