user.js 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. const UserModel = require('../model/user');
  2. const fs = require('fs').promises;
  3. const path = require('path');
  4. const Jimp = require('jimp');
  5. const jwt = require('jsonwebtoken');
  6. const createFolderIsExist = require('../helpers/create-directory');
  7. require('dotenv').config();
  8. const client = require('../helpers/twilio');
  9. const phoneToken = require('generate-sms-verification-code');
  10. const SECRET_KEY = process.env.JWT_SECRET;
  11. const createNewUser = async (req, res, next) => {
  12. try {
  13. const code = phoneToken(4, { type: 'number' });
  14. const color = `#${Math.floor(Math.random() * 16777215).toString(16)}`;
  15. const { number, country } = req.body;
  16. const isExist = await UserModel.findByNumber(number);
  17. if (isExist) {
  18. const id = isExist._id;
  19. await UserModel.updateCode(id, code);
  20. } else {
  21. await UserModel.createUser({ number, country, color, code });
  22. }
  23. client.messages.create({
  24. body: `${code}`,
  25. to: `${number}`,
  26. from: '+18305875860',
  27. });
  28. return res.status(201).json({
  29. status: 'success',
  30. code: 201,
  31. data: String(code),
  32. });
  33. } catch (e) {
  34. next(e);
  35. }
  36. };
  37. const logIn = async (req, res, next) => {
  38. try {
  39. const { number, code } = req.body;
  40. const user = await UserModel.findByNumber(number);
  41. if (!user || user.code !== code)
  42. return res.status(401).json({
  43. status: 'error',
  44. code: 401,
  45. data: 'UNAUTHORIZED',
  46. message: 'Invalid credentials',
  47. });
  48. const id = user._id;
  49. const payload = { id };
  50. const token = jwt.sign(payload, SECRET_KEY, { expiresIn: '24h' });
  51. let registered = true;
  52. if (!user.name || !user.lastName || !user.avatarUrl) registered = false;
  53. await UserModel.updateToken(id, token);
  54. await UserModel.updateCode(id, '');
  55. return res.status(200).json({
  56. status: 'success',
  57. code: 200,
  58. data: {
  59. token,
  60. registered,
  61. },
  62. });
  63. } catch (e) {
  64. next(e);
  65. }
  66. };
  67. const logOut = async (req, res, next) => {
  68. try {
  69. const id = req.user.id;
  70. const user = await UserModel.findById(id);
  71. if (!user)
  72. return res.status(401).json({
  73. status: 'error',
  74. code: 401,
  75. data: 'UNAUTHORIZED',
  76. message: 'Invalid credentials',
  77. });
  78. await UserModel.updateToken(id, null);
  79. return res.status(204).json({});
  80. } catch (e) {
  81. next(e);
  82. }
  83. };
  84. const getCurrent = async (req, res, next) => {
  85. try {
  86. const user = req.user;
  87. if (!user)
  88. return res.status(401).json({
  89. status: 'error',
  90. code: 401,
  91. data: 'UNAUTHORIZED',
  92. message: 'Invalid credentials',
  93. });
  94. return res.status(200).json({
  95. status: 'success',
  96. code: 200,
  97. data: user,
  98. });
  99. } catch (e) {
  100. next(e);
  101. }
  102. };
  103. const updateCredentials = async (req, res, next) => {
  104. try {
  105. const { id, token } = req.user;
  106. await UserModel.updateCredentials(id, req.body);
  107. return res.status(200).json({
  108. data: {
  109. token,
  110. },
  111. });
  112. } catch (e) {
  113. next(e);
  114. }
  115. };
  116. const updateAvatar = async (req, res, next) => {
  117. try {
  118. const userId = req.user.id;
  119. const token = req.user.token;
  120. const DIR_IMAGES = process.env.DIR_IMAGES;
  121. const pathToFile = req.file.path;
  122. const newNameAvatar = req.file.originalname;
  123. const img = await Jimp.read(pathToFile);
  124. await img
  125. .autocrop()
  126. .cover(
  127. 250,
  128. 250,
  129. Jimp.HORIZONTAL_ALIGN_CENTER | Jimp.VERTICAL_ALIGN_MIDDLE
  130. )
  131. .writeAsync(pathToFile);
  132. await createFolderIsExist(path.join(DIR_IMAGES, userId));
  133. await fs.rename(pathToFile, path.join(DIR_IMAGES, userId, newNameAvatar));
  134. const avatarUrl = path.normalize(path.join(userId, newNameAvatar));
  135. await UserModel.updateAvatar(userId, avatarUrl);
  136. return res.status(200).json({
  137. status: 'success',
  138. code: 200,
  139. data: {
  140. token,
  141. },
  142. });
  143. } catch (e) {
  144. next(e);
  145. }
  146. };
  147. module.exports = {
  148. createNewUser,
  149. logIn,
  150. logOut,
  151. getCurrent,
  152. updateCredentials,
  153. updateAvatar,
  154. };