aboutsummaryrefslogtreecommitdiff
path: root/api/entry.go
diff options
context:
space:
mode:
Diffstat (limited to 'api/entry.go')
-rw-r--r--api/entry.go35
1 files changed, 35 insertions, 0 deletions
diff --git a/api/entry.go b/api/entry.go
index 26c306c6..9b911b44 100644
--- a/api/entry.go
+++ b/api/entry.go
@@ -14,6 +14,7 @@ import (
"miniflux.app/config"
"miniflux.app/http/request"
"miniflux.app/http/response/json"
+ "miniflux.app/integration"
"miniflux.app/model"
"miniflux.app/proxy"
"miniflux.app/reader/processor"
@@ -197,6 +198,40 @@ func (h *handler) toggleBookmark(w http.ResponseWriter, r *http.Request) {
json.NoContent(w, r)
}
+func (h *handler) saveEntry(w http.ResponseWriter, r *http.Request) {
+ entryID := request.RouteInt64Param(r, "entryID")
+ builder := h.store.NewEntryQueryBuilder(request.UserID(r))
+ builder.WithEntryID(entryID)
+ builder.WithoutStatus(model.EntryStatusRemoved)
+ // check if user has save entry enabled
+ if !h.store.HasSaveEntry(request.UserID(r)) {
+ json.BadRequest(w, r, errors.New("at least one enabled integration is required"))
+ return
+ }
+ entry, err := builder.GetEntry()
+ if err != nil {
+ json.ServerError(w, r, err)
+ return
+ }
+
+ if entry == nil {
+ json.NotFound(w, r)
+ return
+ }
+
+ settings, err := h.store.Integration(request.UserID(r))
+ if err != nil {
+ json.ServerError(w, r, err)
+ return
+ }
+
+ go func() {
+ integration.SendEntry(entry, settings)
+ }()
+
+ json.NoContent(w, r)
+}
+
func (h *handler) fetchContent(w http.ResponseWriter, r *http.Request) {
loggedUserID := request.UserID(r)
entryID := request.RouteInt64Param(r, "entryID")