user.js 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250
  1. const UserModel = require('../model/user');
  2. const ChatModel = require('../model/chat');
  3. const MessageModel = require('../model/message');
  4. const fs = require('fs').promises;
  5. const path = require('path');
  6. const Jimp = require('jimp');
  7. const jwt = require('jsonwebtoken');
  8. const createFolderIsExist = require('../helpers/create-directory');
  9. require('dotenv').config();
  10. const client = require('../helpers/twilio');
  11. const phoneToken = require('generate-sms-verification-code');
  12. const SECRET_KEY = process.env.JWT_SECRET;
  13. const createNewUser = async (req, res, next) => {
  14. try {
  15. const code = phoneToken(4, { type: 'number' });
  16. const color = `#${Math.floor(Math.random() * 16777215).toString(16)}`;
  17. const { number, country } = req.body;
  18. const isExist = await UserModel.findByNumber(number);
  19. if (isExist) {
  20. await UserModel.updateUser(isExist._id, { code });
  21. } else {
  22. await UserModel.createUser({ number, country, color, code });
  23. }
  24. client.messages.create({
  25. body: `${code}`,
  26. to: `${number}`,
  27. from: '+18305875860',
  28. });
  29. return res.status(201).json({
  30. status: 'success',
  31. code: 201,
  32. data: String(code),
  33. });
  34. } catch (e) {
  35. next(e);
  36. }
  37. };
  38. const logIn = async (req, res, next) => {
  39. try {
  40. const { number, code } = req.body;
  41. const user = await UserModel.findByNumber(number);
  42. if (!user || user.code !== code)
  43. return res.status(401).json({
  44. status: 'error',
  45. code: 401,
  46. data: 'UNAUTHORIZED',
  47. message: 'Invalid credentials',
  48. });
  49. const id = user._id;
  50. const payload = { id };
  51. const token = jwt.sign(payload, SECRET_KEY, { expiresIn: '24h' });
  52. let registered = true;
  53. if (!user.name || !user.lastName || !user.avatarUrl) registered = false;
  54. const online = true;
  55. await UserModel.updateUser(id, { token, code: '', online });
  56. await ChatModel.updateCompanionsChat(id, { online });
  57. return res.status(200).json({
  58. status: 'success',
  59. code: 200,
  60. data: {
  61. token,
  62. registered,
  63. },
  64. });
  65. } catch (e) {
  66. next(e);
  67. }
  68. };
  69. const logOut = async (req, res, next) => {
  70. try {
  71. const id = req.user.id;
  72. const user = await UserModel.findById(id);
  73. const online = new Date();
  74. if (!user)
  75. return res.status(401).json({
  76. status: 'error',
  77. code: 401,
  78. data: 'UNAUTHORIZED',
  79. message: 'Invalid credentials',
  80. });
  81. await UserModel.updateUser(id, { token: null, online });
  82. await ChatModel.updateCompanionsChat(id, { online });
  83. return res.status(204).json({});
  84. } catch (e) {
  85. next(e);
  86. }
  87. };
  88. const online = async (req, res, next) => {
  89. try {
  90. const id = req.user.id;
  91. const user = await UserModel.findById(id);
  92. const online = new Date();
  93. if (!user)
  94. return res.status(401).json({
  95. status: 'error',
  96. code: 401,
  97. data: 'UNAUTHORIZED',
  98. message: 'Invalid credentials',
  99. });
  100. await ChatModel.updateCompanionsChat(id, { online });
  101. await UserModel.updateUser(id, { online });
  102. return res.status(204).json({});
  103. } catch (e) {
  104. next(e);
  105. }
  106. };
  107. const getCurrent = async (req, res, next) => {
  108. try {
  109. const user = req.user;
  110. if (!user)
  111. return res.status(401).json({
  112. status: 'error',
  113. code: 401,
  114. data: 'UNAUTHORIZED',
  115. message: 'Invalid credentials',
  116. });
  117. const id = req.user.id;
  118. const online = true;
  119. await UserModel.updateUser(id, { online });
  120. await ChatModel.updateCompanionsChat(id, { online });
  121. const updatedUser = await UserModel.findById(id);
  122. return res.status(200).json({
  123. status: 'success',
  124. code: 200,
  125. data: updatedUser,
  126. });
  127. } catch (e) {
  128. next(e);
  129. }
  130. };
  131. const updateCredentials = async (req, res, next) => {
  132. try {
  133. const { id } = req.user;
  134. const { name, lastName, originalName, originalLastName } = req.body;
  135. await UserModel.updateUser(id, req.body);
  136. await ChatModel.updateCompanionsChat(id, {
  137. originalName,
  138. originalLastName,
  139. });
  140. await MessageModel.updateOwnerMessages(
  141. { companionIdFlow: { $eq: id }, owner: id },
  142. { name, lastName }
  143. );
  144. return res.status(200).json({
  145. data: {},
  146. });
  147. } catch (e) {
  148. next(e);
  149. }
  150. };
  151. const updateUser = async (req, res, next) => {
  152. try {
  153. const { id } = req.user;
  154. await UserModel.updateUser(id, req.body);
  155. return res.status(200).json({
  156. data: {},
  157. });
  158. } catch (e) {
  159. next(e);
  160. }
  161. };
  162. const removeAvatar = async (req, res, next) => {
  163. try {
  164. const { id, avatarsArr } = req.user;
  165. const index = req.params.index;
  166. const toDelete = avatarsArr[index];
  167. const filteredAvatars = [...avatarsArr].filter(
  168. ({ avatarUrl }) => avatarUrl !== toDelete.avatarUrl
  169. );
  170. const DIR_IMAGES = process.env.DIR_IMAGES;
  171. await fs.unlink(path.join(DIR_IMAGES, toDelete.avatarUrl));
  172. const avatarUrl = filteredAvatars[0].avatarUrl;
  173. await UserModel.updateUser(id, { avatarUrl, avatarsArr: filteredAvatars });
  174. await ChatModel.updateCompanionsChat(id, {
  175. avatarUrl,
  176. avatarsArr: filteredAvatars,
  177. });
  178. await MessageModel.updateOwnerMessages(
  179. { companionIdFlow: { $eq: id } },
  180. { avatarUrl }
  181. );
  182. return res.status(200).json({
  183. data: {},
  184. });
  185. } catch (e) {
  186. next(e);
  187. }
  188. };
  189. const updateAvatar = async (req, res, next) => {
  190. try {
  191. const userId = req.user.id;
  192. const token = req.user.token;
  193. const DIR_IMAGES = process.env.DIR_IMAGES;
  194. const pathToFile = req.file.path;
  195. const originalName = req.file.originalname;
  196. const newNameAvatar = `${Math.round(Date.now() / 1000)}${originalName}`;
  197. const img = await Jimp.read(pathToFile);
  198. await img
  199. .autocrop()
  200. .cover(
  201. 250,
  202. 250,
  203. Jimp.HORIZONTAL_ALIGN_CENTER | Jimp.VERTICAL_ALIGN_MIDDLE
  204. )
  205. .writeAsync(pathToFile);
  206. await createFolderIsExist(path.join(DIR_IMAGES, userId));
  207. await fs.rename(pathToFile, path.join(DIR_IMAGES, userId, newNameAvatar));
  208. const avatarUrl = path.normalize(path.join(userId, newNameAvatar));
  209. const avatarsArr = [
  210. { avatarUrl, updatedAt: new Date() },
  211. ...req.user.avatarsArr,
  212. ];
  213. await UserModel.updateUser(userId, { avatarUrl, avatarsArr });
  214. await ChatModel.updateCompanionsChat(userId, { avatarUrl, avatarsArr });
  215. await MessageModel.updateOwnerMessages(
  216. { companionIdFlow: { $eq: userId } },
  217. { avatarUrl }
  218. );
  219. return res.status(200).json({
  220. status: 'success',
  221. code: 200,
  222. data: {
  223. token,
  224. },
  225. });
  226. } catch (e) {
  227. next(e);
  228. }
  229. };
  230. module.exports = {
  231. createNewUser,
  232. logIn,
  233. logOut,
  234. online,
  235. getCurrent,
  236. updateCredentials,
  237. updateUser,
  238. removeAvatar,
  239. updateAvatar,
  240. };