aboutsummaryrefslogtreecommitdiffhomepage
path: root/storage/enclosure.go
diff options
context:
space:
mode:
authorGravatar Frédéric Guillot <fred@miniflux.net>2017-11-21 16:08:43 -0800
committerGravatar Frédéric Guillot <fred@miniflux.net>2017-11-21 16:08:43 -0800
commit9457b3e5d6ed487c48144b1ae0c18ae0ddc20580 (patch)
tree9d0c805c9031d0c402f7f803035613f31f6489a6 /storage/enclosure.go
parent549a4277b0c000d7cf0b2867c895599d283d70a1 (diff)
Add missing attachments while refreshing a feed
Diffstat (limited to 'storage/enclosure.go')
-rw-r--r--storage/enclosure.go31
1 files changed, 28 insertions, 3 deletions
diff --git a/storage/enclosure.go b/storage/enclosure.go
index ac85cb7..7b0acfd 100644
--- a/storage/enclosure.go
+++ b/storage/enclosure.go
@@ -6,9 +6,11 @@ package storage
import (
"fmt"
+
"github.com/miniflux/miniflux2/model"
)
+// GetEnclosures returns all attachments for the given entry.
func (s *Storage) GetEnclosures(entryID int64) (model.EnclosureList, error) {
query := `SELECT
id, user_id, entry_id, url, size, mime_type
@@ -17,7 +19,7 @@ func (s *Storage) GetEnclosures(entryID int64) (model.EnclosureList, error) {
rows, err := s.db.Query(query, entryID)
if err != nil {
- return nil, fmt.Errorf("Unable to get enclosures: %v", err)
+ return nil, fmt.Errorf("unable to get enclosures: %v", err)
}
defer rows.Close()
@@ -34,7 +36,7 @@ func (s *Storage) GetEnclosures(entryID int64) (model.EnclosureList, error) {
)
if err != nil {
- return nil, fmt.Errorf("Unable to fetch enclosure row: %v", err)
+ return nil, fmt.Errorf("unable to fetch enclosure row: %v", err)
}
enclosures = append(enclosures, &enclosure)
@@ -43,6 +45,7 @@ func (s *Storage) GetEnclosures(entryID int64) (model.EnclosureList, error) {
return enclosures, nil
}
+// CreateEnclosure creates a new attachment.
func (s *Storage) CreateEnclosure(enclosure *model.Enclosure) error {
query := `
INSERT INTO enclosures
@@ -61,7 +64,29 @@ func (s *Storage) CreateEnclosure(enclosure *model.Enclosure) error {
).Scan(&enclosure.ID)
if err != nil {
- return fmt.Errorf("Unable to create enclosure: %v", err)
+ return fmt.Errorf("unable to create enclosure: %v", err)
+ }
+
+ return nil
+}
+
+// IsEnclosureExists checks if an attachment exists.
+func (s *Storage) IsEnclosureExists(enclosure *model.Enclosure) bool {
+ var result int
+ query := `SELECT count(*) as c FROM enclosures WHERE user_id=$1 AND entry_id=$2 AND url=$3`
+ s.db.QueryRow(query, enclosure.UserID, enclosure.EntryID, enclosure.URL).Scan(&result)
+ return result >= 1
+}
+
+// UpdateEnclosures add missing attachments while updating a feed.
+func (s *Storage) UpdateEnclosures(enclosures model.EnclosureList) error {
+ for _, enclosure := range enclosures {
+ if !s.IsEnclosureExists(enclosure) {
+ err := s.CreateEnclosure(enclosure)
+ if err != nil {
+ return err
+ }
+ }
}
return nil