I wonder what is the best practice to ask the user for more information to complete registration after social login with Passport. I am currently able to successfully sign in a user through Twitter, and my callback route '/auth/twitter/callback' is successfully called. However, at this point I'm presenting a form to ask them for a few more pieces of information. My problem is that at this point the req.IsAuthenticated() returns true already, while I'd rather set IsAuthenticated manually only after they complete the registration, not just as soon as the twitter callback is called. Any suggestions?
Ask user to complete registration after social login through Passport
483 Views Asked by Damiano Fusco At
1
There are 1 best solutions below
Related Questions in NODE.JS
- Initialize matrix
- Why is my program adding int as string (4+7 = 47)?
- How to save gensim LDA topics output to csv along with the scores?
- Update a text file with ( new words+ \n ) after the words is appended into a list
- Removing URL features from tokens in NLTK
- python, global name not defined
- Why does collections.OrderedDict use try and except to initialize variables?
- Invalid URL: No host supplied : error while using Request.get(url) in Python
- Python GUI application to copy files one location to another location
- Why I receive CERTIFICATE_VERIFY_FAILED from google adwords api?
Related Questions in SINGLE-SIGN-ON
- Initialize matrix
- Why is my program adding int as string (4+7 = 47)?
- How to save gensim LDA topics output to csv along with the scores?
- Update a text file with ( new words+ \n ) after the words is appended into a list
- Removing URL features from tokens in NLTK
- python, global name not defined
- Why does collections.OrderedDict use try and except to initialize variables?
- Invalid URL: No host supplied : error while using Request.get(url) in Python
- Python GUI application to copy files one location to another location
- Why I receive CERTIFICATE_VERIFY_FAILED from google adwords api?
Related Questions in PASSPORT.JS
- Initialize matrix
- Why is my program adding int as string (4+7 = 47)?
- How to save gensim LDA topics output to csv along with the scores?
- Update a text file with ( new words+ \n ) after the words is appended into a list
- Removing URL features from tokens in NLTK
- python, global name not defined
- Why does collections.OrderedDict use try and except to initialize variables?
- Invalid URL: No host supplied : error while using Request.get(url) in Python
- Python GUI application to copy files one location to another location
- Why I receive CERTIFICATE_VERIFY_FAILED from google adwords api?
Related Questions in PASSPORT-TWITTER
- Initialize matrix
- Why is my program adding int as string (4+7 = 47)?
- How to save gensim LDA topics output to csv along with the scores?
- Update a text file with ( new words+ \n ) after the words is appended into a list
- Removing URL features from tokens in NLTK
- python, global name not defined
- Why does collections.OrderedDict use try and except to initialize variables?
- Invalid URL: No host supplied : error while using Request.get(url) in Python
- Python GUI application to copy files one location to another location
- Why I receive CERTIFICATE_VERIFY_FAILED from google adwords api?
Trending Questions
- UIImageView Frame Doesn't Reflect Constraints
- Is it possible to use adb commands to click on a view by finding its ID?
- How to create a new web character symbol recognizable by html/javascript?
- Why isn't my CSS3 animation smooth in Google Chrome (but very smooth on other browsers)?
- Heap Gives Page Fault
- Connect ffmpeg to Visual Studio 2008
- Both Object- and ValueAnimator jumps when Duration is set above API LvL 24
- How to avoid default initialization of objects in std::vector?
- second argument of the command line arguments in a format other than char** argv or char* argv[]
- How to improve efficiency of algorithm which generates next lexicographic permutation?
- Navigating to the another actvity app getting crash in android
- How to read the particular message format in android and store in sqlite database?
- Resetting inventory status after order is cancelled
- Efficiently compute powers of X in SSE/AVX
- Insert into an external database using ajax and php : POST 500 (Internal Server Error)
Popular # Hahtags
Popular Questions
- How do I undo the most recent local commits in Git?
- How can I remove a specific item from an array in JavaScript?
- How do I delete a Git branch locally and remotely?
- Find all files containing a specific text (string) on Linux?
- How do I revert a Git repository to a previous commit?
- How do I create an HTML button that acts like a link?
- How do I check out a remote Git branch?
- How do I force "git pull" to overwrite local files?
- How do I list all files of a directory?
- How to check whether a string contains a substring in JavaScript?
- How do I redirect to another webpage?
- How can I iterate over rows in a Pandas DataFrame?
- How do I convert a String to an int in Java?
- Does Python have a string 'contains' substring method?
- How do I check if a string contains a specific word?
There are a few ways you can achieve what you want to do and from my point of view fiddling around with
req.isAuthenticated()
is not the best. I recommend the following approaches.Method 1
In addition to
req.isAuthenticated()
put a new condition to check whether the user completed registration or not i.e.user.completedRegistration()
wherecompletedRegistration()
is a function that checks either mongodb or some other logic to decide yes or not. Sample as follow:You obviously will use the isAuthenticated in your routes, as follow:
user.completedRegistration()
could be a function that queries, the mongodb for the logged in user using the logged in user id (twitter id) and check if a particular field is set. You set this field when the user register otherwise by default it can be false.Method 2
Depending on ordering of your configs in the app.js every request runs the deserializeUser as shown below:
Which takes the id of the logged in user from req object and retrieves the user from mongodb and populate more information about user in the req object. You can tweak this method to
User.find
using not only id of the user but, a field that shows whether the user is registered or not. Obviously you need to set the field in the mongodb user object and theUser
model.Method 3
Leave alone the passport related configs, write your own checks in the router level to check whether the logged in user is registered or not. You can do this using the following steps:
To obtain the id of the logged in user, you can check the
req.user
field. As shown in the following function, I have implementedtwitter
,facebook
andlocal
and hence all my checks.There are many other ways to achieve what you have asked for in here but, you need to do some reading on the express app combined with passport work and then you will get an understanding of where to intercept the user requests and which approach suits you best.