user.go 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. // Copyright 2021 Frédéric Guillot. All rights reserved.
  2. // Use of this source code is governed by the Apache 2.0
  3. // license that can be found in the LICENSE file.
  4. package validator // import "miniflux.app/validator"
  5. import (
  6. "miniflux.app/locale"
  7. "miniflux.app/model"
  8. "miniflux.app/storage"
  9. )
  10. // ValidateUserCreationWithPassword validates user creation with a password.
  11. func ValidateUserCreationWithPassword(store *storage.Storage, request *model.UserCreationRequest) *ValidationError {
  12. if request.Username == "" {
  13. return NewValidationError("error.user_mandatory_fields")
  14. }
  15. if store.UserExists(request.Username) {
  16. return NewValidationError("error.user_already_exists")
  17. }
  18. if err := validatePassword(request.Password); err != nil {
  19. return err
  20. }
  21. return nil
  22. }
  23. // ValidateUserModification validates user modifications.
  24. func ValidateUserModification(store *storage.Storage, userID int64, changes *model.UserModificationRequest) *ValidationError {
  25. if changes.Username != nil {
  26. if *changes.Username == "" {
  27. return NewValidationError("error.user_mandatory_fields")
  28. } else if store.AnotherUserExists(userID, *changes.Username) {
  29. return NewValidationError("error.user_already_exists")
  30. }
  31. }
  32. if changes.Password != nil {
  33. if err := validatePassword(*changes.Password); err != nil {
  34. return err
  35. }
  36. }
  37. if changes.Theme != nil {
  38. if err := validateTheme(*changes.Theme); err != nil {
  39. return err
  40. }
  41. }
  42. if changes.Language != nil {
  43. if err := validateLanguage(*changes.Language); err != nil {
  44. return err
  45. }
  46. }
  47. if changes.Timezone != nil {
  48. if err := validateTimezone(store, *changes.Timezone); err != nil {
  49. return err
  50. }
  51. }
  52. if changes.EntryDirection != nil {
  53. if err := validateEntryDirection(*changes.EntryDirection); err != nil {
  54. return err
  55. }
  56. }
  57. if changes.EntriesPerPage != nil {
  58. if err := validateEntriesPerPage(*changes.EntriesPerPage); err != nil {
  59. return err
  60. }
  61. }
  62. if changes.DisplayMode != nil {
  63. if err := validateDisplayMode(*changes.DisplayMode); err != nil {
  64. return err
  65. }
  66. }
  67. if changes.GestureNav != nil {
  68. if err := validateGestureNav(*changes.GestureNav); err != nil {
  69. return err
  70. }
  71. }
  72. if changes.DefaultReadingSpeed != nil {
  73. if err := validateReadingSpeed(*changes.DefaultReadingSpeed); err != nil {
  74. return err
  75. }
  76. }
  77. if changes.CJKReadingSpeed != nil {
  78. if err := validateReadingSpeed(*changes.CJKReadingSpeed); err != nil {
  79. return err
  80. }
  81. }
  82. if changes.DefaultHomePage != nil {
  83. if err := validateDefaultHomePage(*changes.DefaultHomePage); err != nil {
  84. return err
  85. }
  86. }
  87. return nil
  88. }
  89. func validateReadingSpeed(readingSpeed int) *ValidationError {
  90. if readingSpeed <= 0 {
  91. return NewValidationError("error.settings_reading_speed_is_positive")
  92. }
  93. return nil
  94. }
  95. func validatePassword(password string) *ValidationError {
  96. if len(password) < 6 {
  97. return NewValidationError("error.password_min_length")
  98. }
  99. return nil
  100. }
  101. func validateTheme(theme string) *ValidationError {
  102. themes := model.Themes()
  103. if _, found := themes[theme]; !found {
  104. return NewValidationError("error.invalid_theme")
  105. }
  106. return nil
  107. }
  108. func validateLanguage(language string) *ValidationError {
  109. languages := locale.AvailableLanguages()
  110. if _, found := languages[language]; !found {
  111. return NewValidationError("error.invalid_language")
  112. }
  113. return nil
  114. }
  115. func validateTimezone(store *storage.Storage, timezone string) *ValidationError {
  116. timezones, err := store.Timezones()
  117. if err != nil {
  118. return NewValidationError(err.Error())
  119. }
  120. if _, found := timezones[timezone]; !found {
  121. return NewValidationError("error.invalid_timezone")
  122. }
  123. return nil
  124. }
  125. func validateEntryDirection(direction string) *ValidationError {
  126. if direction != "asc" && direction != "desc" {
  127. return NewValidationError("error.invalid_entry_direction")
  128. }
  129. return nil
  130. }
  131. func validateEntriesPerPage(entriesPerPage int) *ValidationError {
  132. if entriesPerPage < 1 {
  133. return NewValidationError("error.entries_per_page_invalid")
  134. }
  135. return nil
  136. }
  137. func validateDisplayMode(displayMode string) *ValidationError {
  138. if displayMode != "fullscreen" && displayMode != "standalone" && displayMode != "minimal-ui" && displayMode != "browser" {
  139. return NewValidationError("error.invalid_display_mode")
  140. }
  141. return nil
  142. }
  143. func validateGestureNav(gestureNav string) *ValidationError {
  144. if gestureNav != "none" && gestureNav != "tap" && gestureNav != "swipe" {
  145. return NewValidationError("error.invalid_gesture_nav")
  146. }
  147. return nil
  148. }
  149. func validateDefaultHomePage(defaultHomePage string) *ValidationError {
  150. defaultHomePages := model.HomePages()
  151. if _, found := defaultHomePages[defaultHomePage]; !found {
  152. return NewValidationError("error.invalid_default_home_page")
  153. }
  154. return nil
  155. }