[Security] Adding more extensive PHPDoc to UserInterface, AdvancedUserInterface and UserProviderInterface

This commit is contained in:
Ryan Weaver 2012-01-07 15:37:07 -06:00
parent 561cde7743
commit 8ee9161e6b
3 changed files with 87 additions and 10 deletions

View File

@ -12,8 +12,20 @@
namespace Symfony\Component\Security\Core\User; namespace Symfony\Component\Security\Core\User;
/** /**
* AdvancedUserInterface adds status flags to a regular account. * Adds extra features to a user class related to account status flags.
* *
* This interface can be implemented in place of UserInterface if you'd like
* the authentication system to consider different account status flags
* during authentication. If any of the methods in this interface return
* false, authentication will fail.
*
* If you need to perform custom logic for any of these situations, then
* you will need to register an exception listener and watch for the specific
* exception instances thrown in each case. All exceptions are a subclass
* of AccountStatusException
*
* @see UserInterface
* @see Symfony\Component\Security\Core\Exception\AccountStatusException
* @author Fabien Potencier <fabien@symfony.com> * @author Fabien Potencier <fabien@symfony.com>
*/ */
interface AdvancedUserInterface extends UserInterface interface AdvancedUserInterface extends UserInterface
@ -21,6 +33,11 @@ interface AdvancedUserInterface extends UserInterface
/** /**
* Checks whether the user's account has expired. * Checks whether the user's account has expired.
* *
* Internally, if this method returns false, the authentication system
* will throw an AccountExpiredException and prevent login.
*
* @see Symfony\Component\Security\Core\Exception\AccountExpiredException
*
* @return Boolean true if the user's account is non expired, false otherwise * @return Boolean true if the user's account is non expired, false otherwise
*/ */
function isAccountNonExpired(); function isAccountNonExpired();
@ -28,6 +45,11 @@ interface AdvancedUserInterface extends UserInterface
/** /**
* Checks whether the user is locked. * Checks whether the user is locked.
* *
* Internally, if this method returns false, the authentication system
* will throw a LockedException and prevent login.
*
* @see Symfony\Component\Security\Core\Exception\LockedException
*
* @return Boolean true if the user is not locked, false otherwise * @return Boolean true if the user is not locked, false otherwise
*/ */
function isAccountNonLocked(); function isAccountNonLocked();
@ -35,6 +57,11 @@ interface AdvancedUserInterface extends UserInterface
/** /**
* Checks whether the user's credentials (password) has expired. * Checks whether the user's credentials (password) has expired.
* *
* Internally, if this method returns false, the authentication system
* will throw a CredentialsExpiredException and prevent login.
*
* @see Symfony\Component\Security\Core\Exception\CredentialsExpiredException
*
* @return Boolean true if the user's credentials are non expired, false otherwise * @return Boolean true if the user's credentials are non expired, false otherwise
*/ */
function isCredentialsNonExpired(); function isCredentialsNonExpired();
@ -42,6 +69,11 @@ interface AdvancedUserInterface extends UserInterface
/** /**
* Checks whether the user is enabled. * Checks whether the user is enabled.
* *
* Internally, if this method returns false, the authentication system
* will throw a DisabledException and prevent login.
*
* @see Symfony\Component\Security\Core\Exception\DisabledException
*
* @return Boolean true if the user is enabled, false otherwise * @return Boolean true if the user is enabled, false otherwise
*/ */
function isEnabled(); function isEnabled();

View File

@ -12,8 +12,20 @@
namespace Symfony\Component\Security\Core\User; namespace Symfony\Component\Security\Core\User;
/** /**
* UserInterface is the interface that user classes must implement. * Represents the interface that all user classes must implement.
* *
* This interface is useful because the authentication layer can deal with
* the object through its lifecycle, using the object to get the encoded
* password (for checking against a submitted password), assigning roles
* and so on.
*
* Regardless of how your user are loaded or where they come from (a database,
* configuration, web service, etc), you will have a class that implements
* this interface. Objects that implement this interface are created and
* loaded by different objects that implement UserProviderInterface
*
* @see UserProviderInterface
* @see AdvancedUserInterface
* @author Fabien Potencier <fabien@symfony.com> * @author Fabien Potencier <fabien@symfony.com>
*/ */
interface UserInterface interface UserInterface
@ -21,6 +33,17 @@ interface UserInterface
/** /**
* Returns the roles granted to the user. * Returns the roles granted to the user.
* *
* <code>
* public function getRoles()
* {
* return array('ROLE_USER');
* }
* </code>
*
* Alternatively, the roles might be stored on a ``roles`` property,
* and populated in any number of different ways when the user object
* is created.
*
* @return Role[] The user roles * @return Role[] The user roles
*/ */
function getRoles(); function getRoles();
@ -28,12 +51,17 @@ interface UserInterface
/** /**
* Returns the password used to authenticate the user. * Returns the password used to authenticate the user.
* *
* This should be the encoded password. On authentication, a plain-text
* password will be salted, encoded, and then compared to this value.
*
* @return string The password * @return string The password
*/ */
function getPassword(); function getPassword();
/** /**
* Returns the salt. * Returns the salt that was originally used to encode the password.
*
* This can return null if the password was not encoded using a salt.
* *
* @return string The salt * @return string The salt
*/ */
@ -49,11 +77,16 @@ interface UserInterface
/** /**
* Removes sensitive data from the user. * Removes sensitive data from the user.
* *
* This is important if, at any given point, sensitive information like
* the plain-text password is stored on this object.
*
* @return void * @return void
*/ */
function eraseCredentials(); function eraseCredentials();
/** /**
* Returns whether or not the given user is equivalent to *this* user.
*
* The equality comparison should neither be done by referential equality * The equality comparison should neither be done by referential equality
* nor by comparing identities (i.e. getId() === getId()). * nor by comparing identities (i.e. getId() === getId()).
* *

View File

@ -12,9 +12,19 @@
namespace Symfony\Component\Security\Core\User; namespace Symfony\Component\Security\Core\User;
/** /**
* UserProviderInterface is the implementation that all user provider must * Represents a class that loads UserInterface objects from some source for the authentication system.
* implement.
* *
* In a typical authentication configuration, a username (i.e. some unique
* user identifier) credential enters the system (via form login, or any
* method). The user provider that is configured with that authentication
* method is asked to load the UserInterface object for the given username
* (via loadUserByUsername) so that the rest of the process can continue.
*
* Internally, a user provider can load users from any source (databases,
* configuration, web service). This is totally independent of how the authentication
* information is submitted or what the UserInterface object looks like.
*
* @see Symfony\Component\Security\Core\User\UserInterface
* @author Fabien Potencier <fabien@symfony.com> * @author Fabien Potencier <fabien@symfony.com>
*/ */
interface UserProviderInterface interface UserProviderInterface
@ -25,7 +35,8 @@ interface UserProviderInterface
* This method must throw UsernameNotFoundException if the user is not * This method must throw UsernameNotFoundException if the user is not
* found. * found.
* *
* @throws UsernameNotFoundException if the user is not found * @see UsernameNotFoundException
* @throws Symfony\Component\Security\Core\Exception\UsernameNotFoundException if the user is not found
* @param string $username The username * @param string $username The username
* *
* @return UserInterface * @return UserInterface
@ -35,11 +46,12 @@ interface UserProviderInterface
/** /**
* Refreshes the user for the account interface. * Refreshes the user for the account interface.
* *
* It is up to the implementation if it decides to reload the user data * It is up to the implementation to decide if the user data should be
* from the database, or if it simply merges the passed User into the * totally reloaded (e.g. from the database), or if the UserInterface
* identity map of an entity manager. * object can just be merged into some internal array of users / identity
* map.
* *
* @throws UnsupportedUserException if the account is not supported * @throws Symfony\Component\Security\Core\Exception\UnsupportedUserException if the account is not supported
* @param UserInterface $user * @param UserInterface $user
* *
* @return UserInterface * @return UserInterface