integration_update.go 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  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"
  11. "miniflux.app/v2/internal/locale"
  12. "miniflux.app/v2/internal/ui/form"
  13. "miniflux.app/v2/internal/ui/session"
  14. )
  15. func (h *handler) updateIntegration(w http.ResponseWriter, r *http.Request) {
  16. printer := locale.NewPrinter(request.UserLanguage(r))
  17. sess := session.New(h.store, request.SessionID(r))
  18. userID := request.UserID(r)
  19. integration, err := h.store.Integration(userID)
  20. if err != nil {
  21. response.HTMLServerError(w, r, err)
  22. return
  23. }
  24. integrationForm := form.NewIntegrationForm(r)
  25. integrationForm.Merge(integration)
  26. if integration.FeverUsername != "" && h.store.HasDuplicateFeverUsername(userID, integration.FeverUsername) {
  27. sess.NewFlashErrorMessage(printer.Print("error.duplicate_fever_username"))
  28. response.HTMLRedirect(w, r, h.routePath("/integrations"))
  29. return
  30. }
  31. if integration.FeverEnabled {
  32. if integrationForm.FeverPassword != "" {
  33. integration.FeverToken = fmt.Sprintf("%x", md5.Sum([]byte(integration.FeverUsername+":"+integrationForm.FeverPassword)))
  34. }
  35. } else {
  36. integration.FeverToken = ""
  37. }
  38. if integration.GoogleReaderUsername != "" && h.store.HasDuplicateGoogleReaderUsername(userID, integration.GoogleReaderUsername) {
  39. sess.NewFlashErrorMessage(printer.Print("error.duplicate_googlereader_username"))
  40. response.HTMLRedirect(w, r, h.routePath("/integrations"))
  41. return
  42. }
  43. if integration.GoogleReaderEnabled {
  44. if integrationForm.GoogleReaderPassword != "" {
  45. integration.GoogleReaderPassword, err = crypto.HashPassword(integrationForm.GoogleReaderPassword)
  46. if err != nil {
  47. response.HTMLServerError(w, r, err)
  48. return
  49. }
  50. }
  51. } else {
  52. integration.GoogleReaderPassword = ""
  53. }
  54. if integrationForm.WebhookEnabled {
  55. if integrationForm.WebhookURL == "" {
  56. integration.WebhookEnabled = false
  57. integration.WebhookSecret = ""
  58. } else if integration.WebhookSecret == "" {
  59. integration.WebhookSecret = crypto.GenerateRandomStringHex(32)
  60. }
  61. } else {
  62. integration.WebhookURL = ""
  63. integration.WebhookSecret = ""
  64. }
  65. if integrationForm.LinktacoEnabled {
  66. if integrationForm.LinktacoAPIToken == "" || integrationForm.LinktacoOrgSlug == "" {
  67. sess.NewFlashErrorMessage(printer.Print("error.linktaco_missing_required_fields"))
  68. response.HTMLRedirect(w, r, h.routePath("/integrations"))
  69. return
  70. }
  71. if integration.LinktacoVisibility == "" {
  72. integration.LinktacoVisibility = "PUBLIC"
  73. }
  74. }
  75. err = h.store.UpdateIntegration(integration)
  76. if err != nil {
  77. response.HTMLServerError(w, r, err)
  78. return
  79. }
  80. sess.NewFlashMessage(printer.Print("alert.prefs_saved"))
  81. response.HTMLRedirect(w, r, h.routePath("/integrations"))
  82. }