com.atlassian.crowd.directory
Class InternalDirectory
java.lang.Object
com.atlassian.crowd.directory.AbstractInternalDirectory
com.atlassian.crowd.directory.InternalDirectory
- All Implemented Interfaces:
- InternalRemoteDirectory, RemoteDirectory, Attributes
public class InternalDirectory
- extends AbstractInternalDirectory
Internal directory connector.
Stores all entity information to the database used by the Crowd Server.
Note that this implementation is used for an Actual InternalDirectory, and there is a related class
CachingDirectory that does local caching of remote objects.
| Fields inherited from class com.atlassian.crowd.directory.AbstractInternalDirectory |
ATTRIBUTE_PASSWORD_HISTORY_COUNT, ATTRIBUTE_PASSWORD_MAX_ATTEMPTS, ATTRIBUTE_PASSWORD_MAX_CHANGE_TIME, ATTRIBUTE_PASSWORD_REGEX, ATTRIBUTE_USER_ENCRYPTION_METHOD, attributes, DESCRIPTIVE_NAME, directoryDao, directoryId, groupDao, internalDirectoryUtils, membershipDao, passwordEncoderFactory, userDao |
| Methods inherited from class com.atlassian.crowd.directory.AbstractInternalDirectory |
addGroup, addGroupToGroup, addUserToGroup, authenticate, currentPrincipalInvalidPasswordAttempts, encryptCredential, findGroupByName, findGroupWithAttributesByName, findUserByName, findUserWithAttributesByName, getDescriptiveName, getDirectoryId, getEncoder, getKeys, getValue, getValues, isEmpty, isGroupDirectGroupMember, isRolesDisabled, isUserDirectGroupMember, removeAllGroups, removeAllUsers, removeGroup, removeGroupAttributes, removeGroupFromGroup, removeUser, removeUserAttributes, removeUserFromGroup, renameGroup, renameUser, requiresPasswordChange, searchGroupRelationships, searchGroups, searchUsers, setAttributes, setDirectoryId, storeGroupAttributes, storeUserAttributes, supportsInactiveAccounts, supportsNestedGroups, testConnection, updateGroup, updateUser, updateUserCredential |
| Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
InternalDirectory
public InternalDirectory(InternalDirectoryUtils internalDirectoryUtils,
PasswordEncoderFactory passwordEncoderFactory,
DirectoryDao directoryDao,
UserDao userDao,
GroupDao groupDao,
MembershipDao membershipDao)
addUser
public User addUser(UserTemplate user,
PasswordCredential credential)
throws InvalidCredentialException,
InvalidUserException
- Adds a user and the following custom attributes:
- RemotePrincipalConstants.PASSWORD_LASTCHANGED set to the current time.
- RemotePrincipalConstants.REQUIRES_PASSWORD_CHANGE set to false.
- Specified by:
addUser in interface RemoteDirectory- Specified by:
addUser in class AbstractInternalDirectory
- Parameters:
user - template of the user to add.credential - password. May be null, since JIRA creates a user in two steps
- Returns:
- added user.
- Throws:
UserNotFoundException - the user could not be looked up after creation
DirectoryNotFoundException - the directory with the ID of user.directoryId does not exist.
InvalidCredentialException - the password does not match the regular expression standard defined by the directory.
InvalidUserException - The supplied user is invalid.
addLocalGroup
public Group addLocalGroup(GroupTemplate group)
throws InvalidGroupException
- Specified by:
addLocalGroup in interface InternalRemoteDirectory- Specified by:
addLocalGroup in class AbstractInternalDirectory
- Throws:
InvalidGroupException
addAllUsers
public java.util.Collection<User> addAllUsers(java.util.Set<UserTemplateWithCredentialAndAttributes> users)
addAllGroups
public java.util.Collection<Group> addAllGroups(java.util.Set<GroupTemplate> groups)
throws DirectoryNotFoundException
- Throws:
DirectoryNotFoundException
addAllUsersToGroup
public java.util.Collection<java.lang.String> addAllUsersToGroup(java.util.Set<java.lang.String> userNames,
java.lang.String groupName)
throws GroupNotFoundException
- Throws:
GroupNotFoundException
Copyright © 2010 Atlassian. All Rights Reserved.