mirror of
https://github.com/miniflux/v2.git
synced 2025-08-16 18:01:37 +00:00
API: Add the possibility to filter entries by a list of statuses
This commit is contained in:
parent
1c103337fe
commit
04c4890124
3 changed files with 36 additions and 9 deletions
|
@ -78,14 +78,14 @@ func (e *EntryQueryBuilder) AfterEntryID(entryID int64) *EntryQueryBuilder {
|
|||
return e
|
||||
}
|
||||
|
||||
// WithEntryIDs adds a condition to fetch only the given entry IDs.
|
||||
// WithEntryIDs filter by entry IDs.
|
||||
func (e *EntryQueryBuilder) WithEntryIDs(entryIDs []int64) *EntryQueryBuilder {
|
||||
e.conditions = append(e.conditions, fmt.Sprintf("e.id = ANY($%d)", len(e.args)+1))
|
||||
e.args = append(e.args, pq.Array(entryIDs))
|
||||
e.args = append(e.args, pq.Int64Array(entryIDs))
|
||||
return e
|
||||
}
|
||||
|
||||
// WithEntryID set the entryID.
|
||||
// WithEntryID filter by entry ID.
|
||||
func (e *EntryQueryBuilder) WithEntryID(entryID int64) *EntryQueryBuilder {
|
||||
if entryID != 0 {
|
||||
e.conditions = append(e.conditions, fmt.Sprintf("e.id = $%d", len(e.args)+1))
|
||||
|
@ -94,7 +94,7 @@ func (e *EntryQueryBuilder) WithEntryID(entryID int64) *EntryQueryBuilder {
|
|||
return e
|
||||
}
|
||||
|
||||
// WithFeedID set the feedID.
|
||||
// WithFeedID filter by feed ID.
|
||||
func (e *EntryQueryBuilder) WithFeedID(feedID int64) *EntryQueryBuilder {
|
||||
if feedID != 0 {
|
||||
e.conditions = append(e.conditions, fmt.Sprintf("e.feed_id = $%d", len(e.args)+1))
|
||||
|
@ -103,7 +103,7 @@ func (e *EntryQueryBuilder) WithFeedID(feedID int64) *EntryQueryBuilder {
|
|||
return e
|
||||
}
|
||||
|
||||
// WithCategoryID set the categoryID.
|
||||
// WithCategoryID filter by category ID.
|
||||
func (e *EntryQueryBuilder) WithCategoryID(categoryID int64) *EntryQueryBuilder {
|
||||
if categoryID > 0 {
|
||||
e.conditions = append(e.conditions, fmt.Sprintf("f.category_id = $%d", len(e.args)+1))
|
||||
|
@ -112,7 +112,7 @@ func (e *EntryQueryBuilder) WithCategoryID(categoryID int64) *EntryQueryBuilder
|
|||
return e
|
||||
}
|
||||
|
||||
// WithStatus set the entry status.
|
||||
// WithStatus filter by entry status.
|
||||
func (e *EntryQueryBuilder) WithStatus(status string) *EntryQueryBuilder {
|
||||
if status != "" {
|
||||
e.conditions = append(e.conditions, fmt.Sprintf("e.status = $%d", len(e.args)+1))
|
||||
|
@ -121,6 +121,15 @@ func (e *EntryQueryBuilder) WithStatus(status string) *EntryQueryBuilder {
|
|||
return e
|
||||
}
|
||||
|
||||
// WithStatuses filter by a list of entry statuses.
|
||||
func (e *EntryQueryBuilder) WithStatuses(statuses []string) *EntryQueryBuilder {
|
||||
if len(statuses) > 0 {
|
||||
e.conditions = append(e.conditions, fmt.Sprintf("e.status = ANY($%d)", len(e.args)+1))
|
||||
e.args = append(e.args, pq.StringArray(statuses))
|
||||
}
|
||||
return e
|
||||
}
|
||||
|
||||
// WithoutStatus set the entry status that should not be returned.
|
||||
func (e *EntryQueryBuilder) WithoutStatus(status string) *EntryQueryBuilder {
|
||||
if status != "" {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue