Sto utilizzando HWIOAuthBundle per consentire a un utente di accedere con Oauth, ho creato un fornitore utente personalizzato che crea un utente nel caso non esista:Symfony2: consente agli utenti di completare la registrazione dopo l'accesso se mancano alcuni campi
public function loadUserByOAuthUserResponse(UserResponseInterface $response)
{
$attr = $response->getResponse();
switch($response->getResourceOwner()->getName()) {
case 'google':
if(!$user = $this->userRepository->findOneByGoogleId($attr['id'])) {
if(($user = $this->userRepository->findOneByEmail($attr['email'])) && $attr['verified_email']) {
$user->setGoogleId($attr['id']);
if(!$user->getFirstname()) {
$user->setFirstname($attr['given_name']);
}
if(!$user->getLastname()) {
$user->setLastname($attr['family_name']);
}
$user->setGoogleName($attr['name']);
}else{
$user = new User();
$user->setUsername($this->userRepository->createUsernameByEmail($attr['email']));
$user->setEmail($attr['email']);
$user->setFirstname($attr['given_name']);
$user->setLastname($attr['family_name']);
$user->setPassword('');
$user->setIsActive(true);
$user->setGoogleId($attr['id']);
$user->setGoogleName($attr['name']);
$user->addGroup($this->groupRepository->findOneByRole('ROLE_USER'));
$this->entityManager->persist($user);
}
}
break;
case 'facebook':
if(!$user = $this->userRepository->findOneByFacebookId($attr['id'])) {
if(($user = $this->userRepository->findOneByEmail($attr['email'])) && $attr['verified']) {
$user->setFacebookId($attr['id']);
if(!$user->getFirstname()) {
$user->setFirstname($attr['first_name']);
}
if(!$user->getLastname()) {
$user->setLastname($attr['last_name']);
}
$user->setFacebookUsername($attr['username']);
}else{
$user = new User();
$user->setUsername($this->userRepository->createUsernameByEmail($attr['email']));
$user->setEmail($attr['email']);
$user->setFirstname($attr['first_name']);
$user->setLastname($attr['last_name']);
$user->setPassword('');
$user->setIsActive(true);
$user->setFacebookId($attr['id']);
$user->setFacebookUsername($attr['username']);
$user->addGroup($this->groupRepository->findOneByRole('ROLE_USER'));
$this->entityManager->persist($user);
}
}
break;
}
$this->entityManager->flush();
if (null === $user) {
throw new AccountNotLinkedException(sprintf("User '%s' not found.", $attr['email']));
}
return $user;
}
il problema è che Twitter per esempio non dà la e-mail o voglio alcuni campi aggiuntivi da inserire prima di creare un nuovo utente. C'è un modo per reindirizzare un utente a un modulo di "registrazione completa" prima di crearlo?
ho cercato di aggiungere una richiesta di ascoltatore, che su ogni richiesta, se l'utente è connesso, controlla se l'email è lì e se non lo fa reindirizza alla pagina complete_registration, ma sarà reindirizzare anche se l'utente va alla homepage, per uscire o qualsiasi altra cosa, lo voglio reindirizzare solo se tenta di accedere ad alcune pagine riservate dell'utente.
O meglio, non crearlo finché non fornisce tutte le informazioni richieste.
@elnur cosa hai modificato? solo per sapere se c'era qualcosa di sbagliato – alex88
Fai clic sull'ultimo timestamp di modifica e guarda tu stesso. –
Che risposta scortese, cattivo umore oggi eh? – alex88