authController.ts 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. import {
  2. Response,
  3. Request
  4. } from "express";
  5. import {
  6. register as _register
  7. } from "../actions/auth/register";
  8. import {
  9. login as _login
  10. } from "../actions/auth/login";
  11. import {
  12. logout as _logout
  13. } from "../actions/auth/logout";
  14. import {
  15. AuthRequest
  16. } from "../middlewares/authMiddleware";
  17. export const register = async (req: Request, res: Response): Promise<void> => {
  18. try {
  19. const {
  20. phoneNumber,
  21. companyName,
  22. firstName,
  23. lastName,
  24. password,
  25. mail
  26. } = req.body;
  27. const result = await _register({
  28. phoneNumber,
  29. companyName,
  30. firstName,
  31. lastName,
  32. password,
  33. mail
  34. });
  35. res.status(result.code).json({
  36. message: result.message,
  37. code: result.code
  38. });
  39. } catch (error) {
  40. console.error("Register error:", error);
  41. res.status(500).json({
  42. message: "Internal server error",
  43. code: 500,
  44. });
  45. }
  46. };
  47. export const login = async (req: Request, res: Response): Promise<void> => {
  48. try {
  49. const {
  50. password,
  51. mail
  52. } = req.body;
  53. const result = await _login({
  54. password,
  55. mail
  56. });
  57. res.status(result.code).json({
  58. message: result.message,
  59. code: result.code,
  60. ...(result.payload && {
  61. payload: result.payload
  62. }),
  63. });
  64. } catch (error) {
  65. console.error("Login error:", error);
  66. res.status(500)
  67. .json({
  68. message: "Server error",
  69. code: 500,
  70. });
  71. }
  72. };
  73. export const logout = async (req: AuthRequest, res: Response): Promise<void> => {
  74. try {
  75. const context = req.context;
  76. if (!context) {
  77. res.status(401).json({
  78. message: "Unauthorized: Missing context",
  79. code: 401
  80. });
  81. return;
  82. }
  83. const {
  84. userId,
  85. token
  86. } = context;
  87. if (!userId || !token) {
  88. res.status(401).json({
  89. message: "Unauthorized: Missing user information",
  90. code: 401
  91. });
  92. return;
  93. }
  94. const result = await _logout(userId, token);
  95. res.status(result.code).json({
  96. message: result.message,
  97. code: result.code,
  98. });
  99. } catch (error) {
  100. console.error("Logout controller error:", error);
  101. res.status(500).json({
  102. message: "Server error",
  103. code: 500,
  104. });
  105. }
  106. };