Ви не можете вибрати більше 25 тем Теми мають розпочинатися з літери або цифри, можуть містити дефіси (-) і не повинні перевищувати 35 символів.

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. const bcrypt = require("bcryptjs/dist/bcrypt")
  2. const { Router } = require("express")
  3. const User = require("../database/models/user")
  4. const {getUserValidator} = require("../validators/users")
  5. const getUsers = async (req, res, next) => {
  6. const allUsers = await User.find({})
  7. return res.status(200).send(allUsers)
  8. }
  9. const getUser = async (req, res, next) => {
  10. const result = getUserValidator.validate(req.body)
  11. console.log(result)
  12. try {
  13. const id = req.params.id
  14. if (!id) {
  15. return res.status(400).send('Bad request')
  16. }
  17. const user = await User.findById(id)
  18. if (!user) {
  19. return res.status(404).send("User with the id of: " + id + " doesnt exist")
  20. }
  21. return res.json(user)
  22. } catch (e) {
  23. next(e)
  24. }
  25. }
  26. const createUser = async (req, res, next) => {
  27. try {
  28. const userModel = req.body
  29. if (Object.entries(userModel).length === 0) {
  30. return res.status(400).send('Object cant be empty')
  31. }
  32. const err = getUserValidator.validate(userModel).error
  33. if (err) {
  34. return res.status(400).send(err.message)
  35. }
  36. const newUser = new User(userModel)
  37. newUser.password = await bcrypt.hash(newUser.password, 8)
  38. await newUser.save()
  39. return res.status(201).json(newUser)
  40. } catch (e) {
  41. next(e)
  42. }
  43. }
  44. const updateUser = async (req, res, next) => {
  45. try {
  46. const id = req.params.id
  47. const objBody = req.body
  48. if (Object.entries(objBody).length == 0) {
  49. return res.status(400).send('Invalid input parameters')
  50. }
  51. const err = getUserValidator.validate(objBody).error
  52. if (err) {
  53. return res.status(400).send(err.message)
  54. }
  55. let user = await User.findById(id);
  56. if (!user) {
  57. return res.status(404).send("User with the id of: " + id + " doesnt exist")
  58. }
  59. user.name = objBody.name
  60. user.password = objBody.password
  61. user.email = objBody.email
  62. await User.updateOne(user)
  63. return res.status(200).send('User updated successfully')
  64. } catch (e) {
  65. next(e)
  66. }
  67. }
  68. const updateUserContacts = async (req, res, next) => {
  69. try {
  70. userFound = true
  71. if (!userFound) {
  72. return res.status(404).send('user not found')
  73. }
  74. if (Object.entries(req.body).length == 0) {
  75. return res.status(400).send('invalid input parameters')
  76. }
  77. return res.status(200).send('user contacts updated successfully')
  78. } catch (e) {
  79. next(e)
  80. }
  81. }
  82. const deleteUser = async (req, res, next) => {
  83. try {
  84. const id = req.params.id
  85. if (!id) {
  86. return res.status(400).send('You need to provide valid Id')
  87. }
  88. const user = await User.findById(id)
  89. if (!user) {
  90. return res.status(404).send("User with the id of: " + id + " doesnt exist")
  91. }
  92. await User.deleteOne(user)
  93. return res.status(204).send('Deleting user with id of ' + id)
  94. } catch (e) {
  95. next(e)
  96. }
  97. }
  98. module.exports = { getUsers, getUser, createUser, updateUser, updateUserContacts, deleteUser }