integration_update.go 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. // SPDX-FileCopyrightText: Copyright The Miniflux Authors. All rights reserved.
  2. // SPDX-License-Identifier: Apache-2.0
  3. package ui // import "miniflux.app/v2/internal/ui"
  4. import (
  5. "crypto/md5"
  6. "fmt"
  7. "net/http"
  8. "miniflux.app/v2/internal/crypto"
  9. "miniflux.app/v2/internal/http/request"
  10. "miniflux.app/v2/internal/http/response/html"
  11. "miniflux.app/v2/internal/http/route"
  12. "miniflux.app/v2/internal/locale"
  13. "miniflux.app/v2/internal/ui/form"
  14. "miniflux.app/v2/internal/ui/session"
  15. )
  16. func (h *handler) updateIntegration(w http.ResponseWriter, r *http.Request) {
  17. printer := locale.NewPrinter(request.UserLanguage(r))
  18. sess := session.New(h.store, request.SessionID(r))
  19. user, err := h.store.UserByID(request.UserID(r))
  20. if err != nil {
  21. html.ServerError(w, r, err)
  22. return
  23. }
  24. integration, err := h.store.Integration(user.ID)
  25. if err != nil {
  26. html.ServerError(w, r, err)
  27. return
  28. }
  29. integrationForm := form.NewIntegrationForm(r)
  30. integrationForm.Merge(integration)
  31. if integration.FeverUsername != "" && h.store.HasDuplicateFeverUsername(user.ID, integration.FeverUsername) {
  32. sess.NewFlashErrorMessage(printer.Print("error.duplicate_fever_username"))
  33. html.Redirect(w, r, route.Path(h.router, "integrations"))
  34. return
  35. }
  36. if integration.FeverEnabled {
  37. if integrationForm.FeverPassword != "" {
  38. integration.FeverToken = fmt.Sprintf("%x", md5.Sum([]byte(integration.FeverUsername+":"+integrationForm.FeverPassword)))
  39. }
  40. } else {
  41. integration.FeverToken = ""
  42. }
  43. if integration.GoogleReaderUsername != "" && h.store.HasDuplicateGoogleReaderUsername(user.ID, integration.GoogleReaderUsername) {
  44. sess.NewFlashErrorMessage(printer.Print("error.duplicate_googlereader_username"))
  45. html.Redirect(w, r, route.Path(h.router, "integrations"))
  46. return
  47. }
  48. if integration.GoogleReaderEnabled {
  49. if integrationForm.GoogleReaderPassword != "" {
  50. integration.GoogleReaderPassword, err = crypto.HashPassword(integrationForm.GoogleReaderPassword)
  51. if err != nil {
  52. html.ServerError(w, r, err)
  53. return
  54. }
  55. }
  56. } else {
  57. integration.GoogleReaderPassword = ""
  58. }
  59. if integrationForm.WebhookEnabled {
  60. if integrationForm.WebhookURL == "" {
  61. integration.WebhookEnabled = false
  62. integration.WebhookSecret = ""
  63. } else if integration.WebhookSecret == "" {
  64. integration.WebhookSecret = crypto.GenerateRandomStringHex(32)
  65. }
  66. } else {
  67. integration.WebhookURL = ""
  68. integration.WebhookSecret = ""
  69. }
  70. err = h.store.UpdateIntegration(integration)
  71. if err != nil {
  72. html.ServerError(w, r, err)
  73. return
  74. }
  75. sess.NewFlashMessage(printer.Print("alert.prefs_saved"))
  76. html.Redirect(w, r, route.Path(h.router, "integrations"))
  77. }