+/*
+ * 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.
+ * 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 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;
import org.argeo.security.ui.admin.SecurityAdminPlugin;
/** 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 = JcrUtils.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();
}
+ /* 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);
+ }
}
}