本文整理汇总了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.');
}