mikenicholson/passport-jwt

Any route with passport.authenticate & JWT Authorization header not being called

fromage9747 opened this issue · 4 comments

I was able to troubleshoot this issue with the help of the below issue:
#89

Using an old user account I am not able to access any route with passport.authenticate. If I log in with a newly created account, everything works fine.

I just encountered this issue with the project I am working on. It was with a user account that I created when I first built the app however the JWT expiry has been the same since the start. Not sure what caused it. I too would be interested in how it happened. Spent two days with troubleshooting ruling out other possibilities. I was able to successfully login with a newer user account.

I can confirm that a new token is created each time I login with the old account:
1st Login
JWT eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.{"online_status":{"is_online":false,"socket_id":"","online_status_string":"offline","last_seen_date":"2019-10-18T07:20:32.355Z"},"timestamps":{"verified_date":"2018-07-29T08:31:51.922Z","modified_date":"2019-10-19T07:34:36.991Z","created_date":"2018-07-29T08:30:40.064Z","last_login_date":"2019-10-19T07:34:36.991Z"},"sidebar_status":true,"roles":[],"isVerified":true,"public_search":false,"payment_instructions":"Congratulations on winning my auction!\n\nPlease make payment via the payment option you selected in my listing.\n\nOnce payment has been made your item will be shipped out using the chosen shipping method.\n\nIf you wish to get in touch with me please navigate to your messages and you will find that my contact regarding this sale has been added as a conversation.\n\nI look forward to receiving payment, completing the sale and making you happy.\n\nMjölnir is the best and safest place to trade online in Russia.","feedback_percent":100,"_id":"5b5d7b306ca7874ee1d064ef","full_name":"Jared Merson","email_address":"jnm9747@gmail.com","username":"fromage9747","password":"$2a$10$IX6TrZLiJ9M2UhgJgREzWOq3D1Ftb7ObRpKmcF0HVWGjIv./dIbJS","terms_and_conditions":true,"activationToken":"fb1e6cdc880bf834c205553d7c5fd8eac6ae356b","__v":0,"profile_picture_main":"84590bb103a1d671b6e131574ebc8a8e.jpg","date_of_birth":"1988-09-01T00:00:00.000Z","description":"Congratulations on winning my auction!\n\nPlease make payment via the payment option you selected in my listing.\n\nOnce payment has been made your item will be shipped out using the chosen shipping method.\n\nIf you wish to get in touch with me please navigate to your messages and you will find that my contact regarding this sales has been added as a conversation.\n\nI look forward to receiving payment, completing the sale and making you happy.\n\nMjölnir is the best and safest place to trade online in Russia.","first_name":"Jared","gender":"male","last_name":"Merson","logged_locations":[{"device_data":{"browser":"chrome","browser_version":"71.0.3578.98","device":"unknown","os":"windows","os_version":"windows-10","userAgent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/71.0.3578.98 Safari/537.36"},"location_data":{"business_website":"","city":"Novosibirsk","continent":"Europe","country_code":"RU","internet_provider_name":"l37-192-166-42.novotelecom.ru","internet_provider_type":"Residential","internet_service_provider":"Novotelecom Ltd","latitude":"55.0411","longitude":"82.9344","organization":"Novotelecom Ltd","ip_address":"37.192.166.42","region":"Novosibirsk","status":"success"},"timestamps":{"created_date":"2019-01-25T17:04:11.932Z"},"_id":"5c4b418bf061e30e33bc9df0"},{"device_data":{"browser":"chrome","browser_version":"71.0.3578.99","device":"android","os":"android","os_version":"unknown","userAgent":"Mozilla/5.0 (Linux; Android 8.0.0; SM-N950F) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/71.0.3578.99 Mobile Safari/537.36"},"location_data":{"business_website":"","city":"Novosibirsk","continent":"Europe","country_code":"RU","internet_provider_name":"l37-192-166-42.novotelecom.ru","internet_provider_type":"Residential","internet_service_provider":"Novotelecom Ltd","latitude":"55.0411","longitude":"82.9344","organization":"Novotelecom Ltd","ip_address":"37.192.166.42","region":"Novosibirsk","status":"success"},"timestamps":{"created_date":"2019-01-27T03:33:45.288Z"},"_id":"5c4d2699b7d9df3016c3fcd5"},{"device_data":{"browser":"Chrome","browser_version":"75.0.3770.142","device":"Unknown","os":"Windows","os_version":"windows-10","userAgent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/75.0.3770.142 Safari/537.36"},"location_data":{"business_website":"","city":"Iskitim","continent":"Europe","country_code":"RU","internet_provider_name":"l37-192-166-42.novotelecom.ru","internet_provider_type":"Residential","internet_service_provider":"Novotelecom Ltd","latitude":"54.6366","longitude":"83.3045","organization":"Novotelecom Ltd","ip_address":"37.192.166.42","region":"Novosibirsk Oblast","status":"success"},"timestamps":{"created_date":"2019-07-23T06:01:53.242Z"},"_id":"5d36a2d132ce8d044d2ef637"},{"device_data":{"browser":"Chrome","browser_version":"76.0.3809.111","device":"Unknown","os":"Android","os_version":"unknown","userAgent":"Mozilla/5.0 (Linux; Android 9; SM-G950F) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/76.0.3809.111 Mobile Safari/537.36"},"location_data":{"business_website":"","city":"Iskitim","continent":"Europe","country_code":"RU","internet_provider_name":"l37-192-166-42.novotelecom.ru","internet_provider_type":"Residential","internet_service_provider":"Novotelecom Ltd","latitude":"54.6366","longitude":"83.3045","organization":"Novotelecom Ltd","ip_address":"37.192.166.42","region":"Novosibirsk Oblast","status":"success"},"timestamps":{"created_date":"2019-08-26T09:10:51.298Z"},"_id":"5d63a21babee6303bce4c61a"},{"device_data":{"browser":"Chrome","browser_version":"76.0.3809.111","device":"Unknown","os":"Android","os_version":"unknown","userAgent":"Mozilla/5.0 (Linux; Android 9; SM-N950F) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/76.0.3809.111 Mobile Safari/537.36"},"location_data":{"business_website":"","city":"Novosibirsk","continent":"Europe","country_code":"RU","internet_provider_name":"81.mtsnet.ru","internet_provider_type":"Residential","internet_service_provider":"MR Sibir","latitude":"55.0415","longitude":"82.9346","organization":"MR Sibir","ip_address":"213.87.224.81","region":"Novosibirsk Oblast","status":"success"},"timestamps":{"created_date":"2019-10-01T12:11:23.185Z"},"_id":"5d93426be6f8250345823a76"},{"device_data":{"browser":"Firefox","browser_version":"69.0","device":"Unknown","os":"Windows","os_version":"windows-10","userAgent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:69.0) Gecko/20100101 Firefox/69.0"},"location_data":{"business_website":"","city":"Iskitim","continent":"Europe","country_code":"RU","internet_provider_name":"l37-192-166-42.novotelecom.ru","internet_provider_type":"Residential","internet_service_provider":"Novotelecom Ltd","latitude":"54.6366","longitude":"83.3045","organization":"Novotelecom Ltd","ip_address":"37.192.166.42","region":"Novosibirsk Oblast","status":"success"},"timestamps":{"created_date":"2019-10-18T07:15:25.665Z"},"_id":"5da9668df01fc98c8df3edc8"}],"listing_watchlist":[],"iat":1571478540,"exp":1572083340}._q2h_xBslt0tHGVjabOfk2bNWQh0N6ZnDwxp-YYbYrc
2nd login
JWT eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.{"online_status":{"is_online":false,"socket_id":"","online_status_string":"offline","last_seen_date":"2019-10-18T07:20:32.355Z"},"timestamps":{"verified_date":"2018-07-29T08:31:51.922Z","modified_date":"2019-10-19T09:49:00.025Z","created_date":"2018-07-29T08:30:40.064Z","last_login_date":"2019-10-19T09:49:00.025Z"},"sidebar_status":true,"roles":[],"isVerified":true,"public_search":false,"payment_instructions":"Congratulations on winning my auction!\n\nPlease make payment via the payment option you selected in my listing.\n\nOnce payment has been made your item will be shipped out using the chosen shipping method.\n\nIf you wish to get in touch with me please navigate to your messages and you will find that my contact regarding this sale has been added as a conversation.\n\nI look forward to receiving payment, completing the sale and making you happy.\n\nMjölnir is the best and safest place to trade online in Russia.","feedback_percent":100,"_id":"5b5d7b306ca7874ee1d064ef","full_name":"Jared Merson","email_address":"jnm9747@gmail.com","username":"fromage9747","password":"$2a$10$IX6TrZLiJ9M2UhgJgREzWOq3D1Ftb7ObRpKmcF0HVWGjIv./dIbJS","terms_and_conditions":true,"activationToken":"fb1e6cdc880bf834c205553d7c5fd8eac6ae356b","__v":0,"profile_picture_main":"84590bb103a1d671b6e131574ebc8a8e.jpg","date_of_birth":"1988-09-01T00:00:00.000Z","description":"Congratulations on winning my auction!\n\nPlease make payment via the payment option you selected in my listing.\n\nOnce payment has been made your item will be shipped out using the chosen shipping method.\n\nIf you wish to get in touch with me please navigate to your messages and you will find that my contact regarding this sales has been added as a conversation.\n\nI look forward to receiving payment, completing the sale and making you happy.\n\nMjölnir is the best and safest place to trade online in Russia.","first_name":"Jared","gender":"male","last_name":"Merson","logged_locations":[{"device_data":{"browser":"chrome","browser_version":"71.0.3578.98","device":"unknown","os":"windows","os_version":"windows-10","userAgent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/71.0.3578.98 Safari/537.36"},"location_data":{"business_website":"","city":"Novosibirsk","continent":"Europe","country_code":"RU","internet_provider_name":"l37-192-166-42.novotelecom.ru","internet_provider_type":"Residential","internet_service_provider":"Novotelecom Ltd","latitude":"55.0411","longitude":"82.9344","organization":"Novotelecom Ltd","ip_address":"37.192.166.42","region":"Novosibirsk","status":"success"},"timestamps":{"created_date":"2019-01-25T17:04:11.932Z"},"_id":"5c4b418bf061e30e33bc9df0"},{"device_data":{"browser":"chrome","browser_version":"71.0.3578.99","device":"android","os":"android","os_version":"unknown","userAgent":"Mozilla/5.0 (Linux; Android 8.0.0; SM-N950F) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/71.0.3578.99 Mobile Safari/537.36"},"location_data":{"business_website":"","city":"Novosibirsk","continent":"Europe","country_code":"RU","internet_provider_name":"l37-192-166-42.novotelecom.ru","internet_provider_type":"Residential","internet_service_provider":"Novotelecom Ltd","latitude":"55.0411","longitude":"82.9344","organization":"Novotelecom Ltd","ip_address":"37.192.166.42","region":"Novosibirsk","status":"success"},"timestamps":{"created_date":"2019-01-27T03:33:45.288Z"},"_id":"5c4d2699b7d9df3016c3fcd5"},{"device_data":{"browser":"Chrome","browser_version":"75.0.3770.142","device":"Unknown","os":"Windows","os_version":"windows-10","userAgent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/75.0.3770.142 Safari/537.36"},"location_data":{"business_website":"","city":"Iskitim","continent":"Europe","country_code":"RU","internet_provider_name":"l37-192-166-42.novotelecom.ru","internet_provider_type":"Residential","internet_service_provider":"Novotelecom Ltd","latitude":"54.6366","longitude":"83.3045","organization":"Novotelecom Ltd","ip_address":"37.192.166.42","region":"Novosibirsk Oblast","status":"success"},"timestamps":{"created_date":"2019-07-23T06:01:53.242Z"},"_id":"5d36a2d132ce8d044d2ef637"},{"device_data":{"browser":"Chrome","browser_version":"76.0.3809.111","device":"Unknown","os":"Android","os_version":"unknown","userAgent":"Mozilla/5.0 (Linux; Android 9; SM-G950F) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/76.0.3809.111 Mobile Safari/537.36"},"location_data":{"business_website":"","city":"Iskitim","continent":"Europe","country_code":"RU","internet_provider_name":"l37-192-166-42.novotelecom.ru","internet_provider_type":"Residential","internet_service_provider":"Novotelecom Ltd","latitude":"54.6366","longitude":"83.3045","organization":"Novotelecom Ltd","ip_address":"37.192.166.42","region":"Novosibirsk Oblast","status":"success"},"timestamps":{"created_date":"2019-08-26T09:10:51.298Z"},"_id":"5d63a21babee6303bce4c61a"},{"device_data":{"browser":"Chrome","browser_version":"76.0.3809.111","device":"Unknown","os":"Android","os_version":"unknown","userAgent":"Mozilla/5.0 (Linux; Android 9; SM-N950F) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/76.0.3809.111 Mobile Safari/537.36"},"location_data":{"business_website":"","city":"Novosibirsk","continent":"Europe","country_code":"RU","internet_provider_name":"81.mtsnet.ru","internet_provider_type":"Residential","internet_service_provider":"MR Sibir","latitude":"55.0415","longitude":"82.9346","organization":"MR Sibir","ip_address":"213.87.224.81","region":"Novosibirsk Oblast","status":"success"},"timestamps":{"created_date":"2019-10-01T12:11:23.185Z"},"_id":"5d93426be6f8250345823a76"},{"device_data":{"browser":"Firefox","browser_version":"69.0","device":"Unknown","os":"Windows","os_version":"windows-10","userAgent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:69.0) Gecko/20100101 Firefox/69.0"},"location_data":{"business_website":"","city":"Iskitim","continent":"Europe","country_code":"RU","internet_provider_name":"l37-192-166-42.novotelecom.ru","internet_provider_type":"Residential","internet_service_provider":"Novotelecom Ltd","latitude":"54.6366","longitude":"83.3045","organization":"Novotelecom Ltd","ip_address":"37.192.166.42","region":"Novosibirsk Oblast","status":"success"},"timestamps":{"created_date":"2019-10-18T07:15:25.665Z"},"_id":"5da9668df01fc98c8df3edc8"}],"listing_watchlist":[],"iat":1571478571,"exp":1572083371}.LEK4Sj5HlkGjHgvMj7gNHtqGuZD0ZelE_Y5VAalpoiA

I am not storing these in the DB. They only get stored in the user's local storage of the browser and are sent up to the API by Angular when a route requires authentication.

As previously stated, this issue is only occurring with the old user that I originally created with the app. Not sure why this is happening. Perhaps @mikenicholson can shed some light? I haven't deleted the old user account so I can run some tests if need be.

Update. I had an idea that maybe resetting the password for the user account that is encountering the issue might resolve the issue but it has not.

My passport code is pretty much standard. nothing special here:

`const JwtStrategy = require('passport-jwt').Strategy;
const ExtractJwt = require('passport-jwt').ExtractJwt;
const User = require('../models/user');
const config = require('../config/database');

module.exports = function(passport) {
console.log('Passport is being called');
let opts = {};
opts.jwtFromRequest = ExtractJwt.fromAuthHeaderWithScheme('JWT');
opts.secretOrKey = config.secret;
passport.use(new JwtStrategy(opts, (jwt_payload, done) => {
User.getUserById(jwt_payload._id, (err, user) => {
if (err) {
// console.log(err);
return done(err, false);
}
if (user) {
// console.log(user);
return done(null, user);
} else {
// console.log('no user found');
return done(null, false);
}
});
}));
};`

Not sure why its not being correctly formatted. I am using the <> code formatter

I don't understand this issue but I have a feeling it is exactly like what I'm going through right now.

I discovered while testing my auth API with postman that, no matter which user I use for authentication, I keep getting the first user in my DB returned to me.

@mikenicholson Could you shed some light on this? I would hate for my app to go into production only to find all the user accounts be botched after a year of use.

Ran into this issue again onto a newer account which has directed me to too much data being the issue or rather passport is not waiting long enough to get the data from the database or something,