本文整理匯總了PHP中Symfony\Component\Security\Core\Authentication\Token\TokenInterface::getLDAPUserCredentials方法的典型用法代碼示例。如果您正苦於以下問題:PHP TokenInterface::getLDAPUserCredentials方法的具體用法?PHP TokenInterface::getLDAPUserCredentials怎麽用?PHP TokenInterface::getLDAPUserCredentials使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類Symfony\Component\Security\Core\Authentication\Token\TokenInterface
的用法示例。
在下文中一共展示了TokenInterface::getLDAPUserCredentials方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: authenticate
public function authenticate(TokenInterface $token)
{
$ldapUserCredentials = $token->getLDAPUserCredentials();
$ldapConnection = $this->ldapService->getConnection();
if ($ldapConnection) {
$ldapBind = $this->ldapService->bind($ldapConnection, $ldapUserCredentials['username'], $ldapUserCredentials['password']);
if (true === $ldapBind) {
$ldapEntry = $this->ldapService->read($ldapConnection, "uid=" . $ldapUserCredentials['username'] . "," . $this->ldapService->getDn(), "(objectclass=*)", array('ou', 'sn', 'cn', 'mail'));
if (is_array($ldapEntry) && isset($ldapEntry['count']) && $ldapEntry['count']) {
$ldapUserObject = $ldapEntry[0];
$user = $this->entityLibrary->get('User')->findOneByUsername($ldapUserCredentials['username']);
if (!$user) {
$roleGeneral = $this->entityLibrary->get('Role')->findOneByName('ROLE_GENERAL');
$groupGeneral = $this->entityLibrary->get('UserGroup')->findOneByName('General');
$user = new User();
$user->setName($ldapUserObject['cn'][0] . ' ' . $ldapUserObject['sn'][0]);
$user->setEmail($ldapUserObject['mail'][0]);
$user->setUsername($ldapUserCredentials['username']);
$user->setSalt(uniqid());
$user->addRole($roleGeneral);
$user->addUserGroup($groupGeneral);
$this->entityLibrary->get('User')->save($user);
}
$authenticatedToken = new LDAPToken($user->getRoles());
$authenticatedToken->setUser($user);
$authenticatedToken->setLDAPUserCredentials($ldapUserCredentials);
return $authenticatedToken;
}
}
throw new AuthenticationException('The LDAP credentials are not found.');
}
throw new AuthenticationException('The LDAP authentication failed.');
}