Skip to content

Commit

Permalink
fixed api
Browse files Browse the repository at this point in the history
  • Loading branch information
Orang-utan committed Dec 26, 2020
1 parent 0c9192b commit 6292d4e
Show file tree
Hide file tree
Showing 2 changed files with 34 additions and 38 deletions.
4 changes: 2 additions & 2 deletions src/client/src/api/auth.js
Original file line number Diff line number Diff line change
Expand Up @@ -18,8 +18,8 @@ class Auth {
}

/** Retrieve JWT from server. */
async login(username, password) {
const resp = await axios.post('/api/users/login', { username, password });
async login(email, password) {
const resp = await axios.post('/api/users/login', { email, password });
const { accessToken, refreshToken } = resp.data;
this.accessToken = accessToken;
localStorage.setItem('authRefreshToken', refreshToken);
Expand Down
68 changes: 32 additions & 36 deletions src/routes/user.api.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,11 +12,12 @@ import {
const router = express.Router();
const saltRounds = 10;

// create new user
/* account signup endpoint */
router.post('/signup', async (req, res) => {
const { firstName } = req.body;
const { lastName } = req.body;
const { email } = req.body;
const { company } = req.body;
const { password } = req.body;

if (await User.findOne({ email })) {
Expand All @@ -33,6 +34,7 @@ router.post('/signup', async (req, res) => {
firstName,
lastName,
email,
institutionName: company,
password: hashedPassword,
});

Expand All @@ -43,43 +45,38 @@ router.post('/signup', async (req, res) => {
});
});

// login user
/* acccount login endpoint */
router.post('/login', async (req, res) => {
const { email } = req.body;
const { password } = req.body;

User.findOne({ email }).then((user):
| express.Response
| Promise<boolean>
| boolean
| PromiseLike<boolean> => {
// user does not exist
if (!user) return errorHandler(res, 'User email or password is incorrect.');

return compare(password, user.password, (err, result) => {
if (err) return errorHandler(res, err.message);

if (result) {
// password matched
const accessToken = generateAccessToken(user);
const refreshToken = generateRefreshToken(user);

return Promise.all([accessToken, refreshToken]).then((tokens) =>
res.status(200).json({
success: true,
accessToken: tokens[0],
refreshToken: tokens[1],
})
);
}
const user = await User.findOne({ email });
// user does not exist
if (!user) return errorHandler(res, 'User does not exist.');

return compare(password, user.password, (err, result) => {
if (err) return errorHandler(res, err.message);

if (result) {
// password matched
const accessToken = generateAccessToken(user);
const refreshToken = generateRefreshToken(user);

return Promise.all([accessToken, refreshToken]).then((tokens) =>
res.status(200).json({
success: true,
accessToken: tokens[0],
refreshToken: tokens[1],
})
);
}

// wrong password
return errorHandler(res, 'User email or password is incorrect.');
});
// wrong password
return errorHandler(res, 'User email or password is incorrect.');
});
});

// refresh token
/* account jwt token refresh */
router.post('/refreshToken', (req, res) => {
const { refreshToken } = req.body;

Expand All @@ -103,8 +100,7 @@ router.post('/refreshToken', (req, res) => {
});
});

// get me
// protected route
/* protected: get my info */
router.get('/me', auth, (req, res) => {
const { userId } = req;

Expand All @@ -118,15 +114,15 @@ router.get('/me', auth, (req, res) => {
.catch((err) => errorHandler(res, err.message));
});

// TESTING ROUTES BELOW
// get all users
router.post('/', (_, res) => {
/* TESTING ENDPOINTS BELOW (DELETE IN PRODUCTION) */
/* fetch all users in database */
router.get('/', (_, res) => {
User.find({})
.then((result) => res.status(200).json({ success: true, result }))
.catch((e) => errorHandler(res, e));
});

// delete all users
/* delete all users in database */
router.delete('/', (_, res) => {
User.deleteMany({})
.then(() => res.status(200).json({ success: true }))
Expand Down

0 comments on commit 6292d4e

Please sign in to comment.