auth.js 963 B

12345678910111213141516171819202122232425262728293031323334353637383940
  1. import express from 'express';
  2. import {
  3. authCookieName,
  4. clearCookieOptions,
  5. cookieOptions,
  6. createSession,
  7. validateCredentials,
  8. verifySession,
  9. } from '../libs/auth.js';
  10. const router = express.Router();
  11. router.post('/login', (req, res) => {
  12. const { username = '', password = '' } = req.body ?? {};
  13. if (!validateCredentials(String(username), String(password))) {
  14. return res.unauthorized('用户名或密码错误');
  15. }
  16. const token = createSession(username);
  17. res.cookie(authCookieName, token, cookieOptions());
  18. return res.sendSuccess({ username });
  19. });
  20. router.post('/logout', (req, res) => {
  21. res.clearCookie(authCookieName, clearCookieOptions());
  22. return res.sendSuccess();
  23. });
  24. router.get('/me', (req, res) => {
  25. const session = verifySession(req.cookies?.[authCookieName]);
  26. if (!session) {
  27. return res.unauthorized('请先登录');
  28. }
  29. return res.sendSuccess({ username: session.username });
  30. });
  31. export default router;