diff options
Diffstat (limited to 'api/entry.go')
-rw-r--r-- | api/entry.go | 35 |
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") |