repository with issueSymfony 3, wypełnianie żeton i orzeźwiający użytkownik
Mam formularz dla podmiotów użytkownik z dziedziny e-mail:
->add('email', EmailType::class, [
'constraints' => [
new NotBlank(),
new Email([
'checkMX' => true,
])
],
'required' => true
])
kiedy jestem edycji e-mail do czegoś jak [email protected]
i złożyć formularz pokazuje mnie error "Ta wartość nie jest prawidłowym adresem e-mail." to jest OK, ale po tym symfony zapełnić zły e-mail do tokena, a kiedy idę do jakiejkolwiek innej strony lub po prostu przeładować stronę, ja dostaję to:
UWAGA bezpieczeństwa Nazwa użytkownika nie została znaleziona w wybranym użytkownik dostawca.
Myślę, że pytanie brzmi: dlaczego symfony zapełniają błędnie E-mail, który nie przeszedł sprawdzenia poprawności na token i jak mógłbym mu zapobiec?
kontroler:
public function meSettingsAction(Request $request)
{
$user = $this->getUser();
$userUnSubscribed = $this->getDoctrine()->getRepository('AppBundle:UserUnsubs')->findOneBy(
[
'email' => $user->getEmail(),
]
);
$form = $this->createForm(UserSettingsType::class, $user);
$form->get('subscribed')->setData(!(bool)$userUnSubscribed);
$form->handleRequest($request);
if ($form->isSubmitted() && $form->isValid()) {
/**
* @var $user User
*/
$user = $form->getData();
/** @var UploadedFile $avatar */
$avatar = $request->files->get('user_settings')['photo'];
$em = $this->getDoctrine()->getManager();
if ($avatar) {
$avatar_content = file_get_contents($avatar->getRealPath());
$avatarName = uniqid().'.jpg';
$oldAvatar = $user->getPhoto();
$user
->setState(User::PHOTO_STATE_UNCHECKED)
->setPhoto($avatarName);
$gearmanClient = $this->get('gearman.client');
$gearmanClient->doBackgroundDependsOnEnv(
'avatar_content_upload',
serialize(['content' => $avatar_content, 'avatarName' => $avatarName, 'oldAvatar' => $oldAvatar])
);
}
$subscribed = $form->get('subscribed')->getData();
if ((bool)$userUnSubscribed && $subscribed) {
$em->remove($userUnSubscribed);
} elseif (!(bool)$userUnSubscribed && !$subscribed) {
$userUnSubscribed = new UserUnsubs();
$userUnSubscribed->setEmail($form->get('email')->getData())->setTs(time());
$em->persist($userUnSubscribed);
}
$user->setLastTs(time());
$em = $this->getDoctrine()->getManager();
$em->persist($user);
$em->flush();
$this->get('user.manager')->refresh($user);
return $this->redirectToRoute('me');
}
return $this->render(
':user:settings.html.twig',
[
'form' => $form->createView(),
]
);
}
UPD: to działa dobrze w przypadku zmiany w OAuthProvider:
/**
* @param \Symfony\Component\Security\Core\User\UserInterface $user
*
* @return \Symfony\Component\Security\Core\User\UserInterface
*/
public function refreshUser(UserInterface $user)
{
return $this->loadUserByUsername($user->getName());
}
do:
/**
* @param \Symfony\Component\Security\Core\User\UserInterface $user
*
* @return \Symfony\Component\Security\Core\User\UserInterface
*/
public function refreshUser(UserInterface $user)
{
return $this->userManager($user->getId());
}
ale wydaje się być brudne Hack .
Dzięki.
czy możesz pokazać kontroler? –
@AlessandroMinoccheri Dodałem kod kontrolera do pytania. – kRicha
Dlaczego funkcja "refreshUser()" jest wywoływana, nawet jeśli adres e-mail jest nieprawidłowy? Dodaj więcej informacji o konfiguracji serurity.yml. – lordrhodos