/* * RHQ Management Platform * Copyright (C) 2005-2010 Red Hat, Inc. * All rights reserved. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation version 2 of the License. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ package org.rhq.coregui.client.gwt; import java.util.Set; import com.google.gwt.user.client.rpc.RemoteService; import org.rhq.core.domain.auth.Principal; import org.rhq.core.domain.auth.Subject; import org.rhq.core.domain.criteria.SubjectCriteria; import org.rhq.core.domain.util.PageList; /** * @see org.rhq.enterprise.server.auth.SubjectManagerLocal */ public interface SubjectGWTService extends RemoteService { /** * Creates a new principal (username and password) in the internal database. The password will be encoded before * being stored. * * @param username The username part of the principal * @param password The password part ofthe principal * @throws Exception if the principal could not be added */ void createPrincipal(String username, String password) throws RuntimeException; /** * Create a a new subject. This <b>ignores</b> the roles in <code>subject</code>. The created subject will not be * assigned to any roles; use the {@link org.rhq.enterprise.server.authz.RoleManagerLocal role manager} to assign roles to a subject. * * @param subjectToCreate The subject to be created. * @return the newly persisted {@link Subject} */ Subject createSubject(Subject subjectToCreate) throws RuntimeException; /** * Creates a new subject, including their assigned roles, as well as an associated principal with the specified * password. * * @param subjectToCreate the subject to be created (which will never be the same as <code>subject</code>) * @param password the password for the principal to be created for the new user * * @return the persisted subject */ Subject createSubject(Subject subjectToCreate, String password) throws RuntimeException; /** * Deletes the given set of users, including both the {@link Subject} and {@link org.rhq.core.domain.auth.Principal} objects associated with * those users. * * @param subjectIds identifies the subject IDs for all the users that are to be deleted * @throws Exception if failed to delete one or more users */ void deleteSubjects(int[] subjectIds) throws RuntimeException; /** * Logs a user into the system. This will authenticate the given user with the given password. If the user was * already logged in, the current session will be used but the password will still need to be authenticated. * * @param username The name of the user. * @param password The password. * @return The subject of the authenticated user. * @throws org.rhq.enterprise.server.exception.LoginException * if the login failed for some reason */ Subject login(String username, String password) throws RuntimeException; /** * Logs out a user. * * @param sessionId The sessionId for the subject */ void logout(int sessionId) throws RuntimeException; /** * Updates an existing subject with new data. This does <b>not</b> cascade any changes to the roles and it * will <b>NOT</b> save the subject's preferences (the reason for that is that the preferences * are still updated both in the old JSF UI as well as in the GWT UI and figuring out what values * changed requires some more work than simply saving the GWT's view of the preferences). * * @param subjectToModify the subject whose data is to be updated (which may or may not be the same as <code>user</code>) * * @return the merged subject, which may or may not be the same instance of <code>subjectToModify</code> */ Subject updateSubject(Subject subjectToModify) throws RuntimeException; /** * Updates an existing subject with new data. This cascades changes to roles and LDAP roles, so the passed-in * subject should be fully-fetched (i.e. both roles and LDAP roles should be fetched). * * @param subjectToModify the subject whose data is to be updated (which may or may not be the same as <code>user</code>) * @param newPassword if non-null, a new password to be set on the user's associated Principal * * @return the merged subject, which may or may not be the same instance of <code>subjectToModify</code> */ Subject updateSubject(Subject subjectToModify, String newPassword) throws RuntimeException; /** * This will update the preferences of the supplied subject (which might or might not be the same as the * current user). * * @param subjectToModify the subject to modify the preferences of * @param changedPrefs the set of preference names that are known to have changed - only the preferences * with these names will be persisted to the database. * @return the subject with the preferences updated to match the persisted state (which might contain * additional changes - this is because the prefs are still being updated both in the GWT and JSF UIs). * * @throws RuntimeException */ Subject updateSubjectPreferences(Subject subjectToModify, Set<String> changedPrefs) throws RuntimeException; /** * A combination of {@link #updateSubject(Subject)} and {@link #updateSubjectPreferences(Subject, Set)} methods. * <p> * This method will therefore modify both the subject and the preferences that changed. * * @param subjectToModify * @param changedPrefs * @return * @throws RuntimeException */ Subject updateSubjectAndPreferences(Subject subjectToModify, Set<String> changedPrefs) throws RuntimeException; /** * Queries subjects using current logged in user. * * @param criteria details for the search * @return PageList<Subject> matching criteria. */ PageList<Subject> findSubjectsByCriteria(SubjectCriteria criteria) throws RuntimeException; /** * Checks the subject passed in for LDAP processing, to optionally: * i) perform registration of new RHQ LDAP user * ii) handles case insentive username matches. * iii) update ldap user->role ldap assignments * * @param subjectToModify the subject * @param password the LDAP password */ Subject processSubjectForLdap(Subject subjectToModify, String password) throws RuntimeException; /** * Checks that the user exists <b>and</b> has a {@link Principal} associated with it. This means that the user both * exists and is authenticated via JDBC. An LDAP user will not have a {@link Principal} because it is authenticated * via the LDAP server, not from the database. * * @param username the user whose existence is to be checked * * @return <code>true</code> if the user exists and has a {@link Principal}, <code>false</code> otherwise */ boolean isUserWithPrincipal(String username) throws RuntimeException; /** * Checks if the provided credentials are correct. * @param username * @param password * @return */ Subject checkAuthentication(String username, String password) throws RuntimeException; }