user_handler.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. package api
  2. import (
  3. "encoding/json"
  4. "net/http"
  5. "strconv"
  6. "github.com/go-chi/chi"
  7. "github.com/porter-dev/porter/internal/forms"
  8. "github.com/porter-dev/porter/internal/models"
  9. "github.com/porter-dev/porter/internal/queries"
  10. "gorm.io/gorm"
  11. )
  12. // HandleCreateUser validates a user form entry, converts the user to a gorm
  13. // model, and saves the user to the database
  14. func (app *App) HandleCreateUser(w http.ResponseWriter, r *http.Request) {
  15. form := &forms.CreateUserForm{}
  16. user, err := app.writeUser(form, queries.CreateUser, w, r)
  17. if err == nil {
  18. app.logger.Info().Msgf("New user created: %d", user.ID)
  19. w.WriteHeader(http.StatusCreated)
  20. }
  21. }
  22. // HandleReadUser is majestic
  23. func (app *App) HandleReadUser(w http.ResponseWriter, r *http.Request) {
  24. w.WriteHeader(http.StatusOK)
  25. w.Write([]byte("{}"))
  26. }
  27. // HandleUpdateUser validates an update user form entry, updates the user
  28. // in the database, and writes status accepted
  29. func (app *App) HandleUpdateUser(w http.ResponseWriter, r *http.Request) {
  30. id, err := strconv.ParseUint(chi.URLParam(r, "id"), 0, 64)
  31. if err != nil || id == 0 {
  32. app.handleErrorFormDecoding(err, ErrUserDecode, w)
  33. return
  34. }
  35. form := &forms.UpdateUserForm{
  36. ID: id,
  37. }
  38. user, err := app.writeUser(form, queries.UpdateUser, w, r)
  39. if err == nil {
  40. app.logger.Info().Msgf("User updated: %d", user.ID)
  41. w.WriteHeader(http.StatusAccepted)
  42. }
  43. }
  44. // HandleDeleteUser is majestic
  45. func (app *App) HandleDeleteUser(w http.ResponseWriter, r *http.Request) {
  46. w.WriteHeader(http.StatusAccepted)
  47. }
  48. // ------------------------ User handler helper functions ------------------------ //
  49. // writeUser will take a POST or PUT request to the /api/users endpoint and decode
  50. // the request into a forms.WriteUserForm model, convert it to a models.User, and
  51. // write to the database.
  52. func (app *App) writeUser(
  53. form forms.WriteUserForm,
  54. dbWrite func(db *gorm.DB, user *models.User) (*models.User, error),
  55. w http.ResponseWriter,
  56. r *http.Request,
  57. ) (*models.User, error) {
  58. // decode from JSON to form value
  59. if err := json.NewDecoder(r.Body).Decode(form); err != nil {
  60. app.handleErrorFormDecoding(err, ErrUserDecode, w)
  61. return nil, err
  62. }
  63. // validate the form
  64. if err := app.validator.Struct(form); err != nil {
  65. app.handleErrorFormValidation(err, ErrUserValidateFields, w)
  66. return nil, err
  67. }
  68. // convert the form to a user model -- WriteUserForm must implement ToUser
  69. userModel, err := form.ToUser()
  70. if err != nil {
  71. app.handleErrorFormDecoding(err, ErrUserDecode, w)
  72. return nil, err
  73. }
  74. // handle write to the database
  75. user, err := dbWrite(app.db, userModel)
  76. if err != nil {
  77. app.handleErrorDataWrite(err, ErrUserDataWrite, w)
  78. return nil, err
  79. }
  80. return user, nil
  81. }