aboutsummaryrefslogtreecommitdiff
path: root/api/entry.go
diff options
context:
space:
mode:
authorGravatar Frédéric Guillot <fred@miniflux.net> 2018-01-02 22:04:48 -0800
committerGravatar Frédéric Guillot <fred@miniflux.net> 2018-01-02 22:04:48 -0800
commit320d1b016747ba4501da9417d9ce5f99368a5768 (patch)
tree1054d96afde6022951b76cc4a09b78e1e3f05058 /api/entry.go
parentc39f2e1a8d2de6d412bcc673d29eb0f7a2d1f5f7 (diff)
downloadv2-320d1b016747ba4501da9417d9ce5f99368a5768.tar.gz
v2-320d1b016747ba4501da9417d9ce5f99368a5768.tar.zst
v2-320d1b016747ba4501da9417d9ce5f99368a5768.zip
Refactor packages to have more idiomatic code base
Diffstat (limited to 'api/entry.go')
-rw-r--r--api/entry.go223
1 files changed, 223 insertions, 0 deletions
diff --git a/api/entry.go b/api/entry.go
new file mode 100644
index 00000000..4152da88
--- /dev/null
+++ b/api/entry.go
@@ -0,0 +1,223 @@
+// Copyright 2017 Frédéric Guillot. All rights reserved.
+// Use of this source code is governed by the Apache 2.0
+// license that can be found in the LICENSE file.
+
+package api
+
+import (
+ "errors"
+
+ "github.com/miniflux/miniflux/http/handler"
+ "github.com/miniflux/miniflux/model"
+)
+
+// GetFeedEntry is the API handler to get a single feed entry.
+func (c *Controller) GetFeedEntry(ctx *handler.Context, request *handler.Request, response *handler.Response) {
+ userID := ctx.UserID()
+ feedID, err := request.IntegerParam("feedID")
+ if err != nil {
+ response.JSON().BadRequest(err)
+ return
+ }
+
+ entryID, err := request.IntegerParam("entryID")
+ if err != nil {
+ response.JSON().BadRequest(err)
+ return
+ }
+
+ builder := c.store.NewEntryQueryBuilder(userID)
+ builder.WithFeedID(feedID)
+ builder.WithEntryID(entryID)
+
+ entry, err := builder.GetEntry()
+ if err != nil {
+ response.JSON().ServerError(errors.New("Unable to fetch this entry from the database"))
+ return
+ }
+
+ if entry == nil {
+ response.JSON().NotFound(errors.New("Entry not found"))
+ return
+ }
+
+ response.JSON().Standard(entry)
+}
+
+// GetEntry is the API handler to get a single entry.
+func (c *Controller) GetEntry(ctx *handler.Context, request *handler.Request, response *handler.Response) {
+ userID := ctx.UserID()
+ entryID, err := request.IntegerParam("entryID")
+ if err != nil {
+ response.JSON().BadRequest(err)
+ return
+ }
+
+ builder := c.store.NewEntryQueryBuilder(userID)
+ builder.WithEntryID(entryID)
+
+ entry, err := builder.GetEntry()
+ if err != nil {
+ response.JSON().ServerError(errors.New("Unable to fetch this entry from the database"))
+ return
+ }
+
+ if entry == nil {
+ response.JSON().NotFound(errors.New("Entry not found"))
+ return
+ }
+
+ response.JSON().Standard(entry)
+}
+
+// GetFeedEntries is the API handler to get all feed entries.
+func (c *Controller) GetFeedEntries(ctx *handler.Context, request *handler.Request, response *handler.Response) {
+ userID := ctx.UserID()
+ feedID, err := request.IntegerParam("feedID")
+ if err != nil {
+ response.JSON().BadRequest(err)
+ return
+ }
+
+ status := request.QueryStringParam("status", "")
+ if status != "" {
+ if err := model.ValidateEntryStatus(status); err != nil {
+ response.JSON().BadRequest(err)
+ return
+ }
+ }
+
+ order := request.QueryStringParam("order", model.DefaultSortingOrder)
+ if err := model.ValidateEntryOrder(order); err != nil {
+ response.JSON().BadRequest(err)
+ return
+ }
+
+ direction := request.QueryStringParam("direction", model.DefaultSortingDirection)
+ if err := model.ValidateDirection(direction); err != nil {
+ response.JSON().BadRequest(err)
+ return
+ }
+
+ limit := request.QueryIntegerParam("limit", 100)
+ offset := request.QueryIntegerParam("offset", 0)
+ if err := model.ValidateRange(offset, limit); err != nil {
+ response.JSON().BadRequest(err)
+ return
+ }
+
+ builder := c.store.NewEntryQueryBuilder(userID)
+ builder.WithFeedID(feedID)
+ builder.WithStatus(status)
+ builder.WithOrder(order)
+ builder.WithDirection(direction)
+ builder.WithOffset(offset)
+ builder.WithLimit(limit)
+
+ entries, err := builder.GetEntries()
+ if err != nil {
+ response.JSON().ServerError(errors.New("Unable to fetch the list of entries"))
+ return
+ }
+
+ count, err := builder.CountEntries()
+ if err != nil {
+ response.JSON().ServerError(errors.New("Unable to count the number of entries"))
+ return
+ }
+
+ response.JSON().Standard(&entriesResponse{Total: count, Entries: entries})
+}
+
+// GetEntries is the API handler to fetch entries.
+func (c *Controller) GetEntries(ctx *handler.Context, request *handler.Request, response *handler.Response) {
+ userID := ctx.UserID()
+
+ status := request.QueryStringParam("status", "")
+ if status != "" {
+ if err := model.ValidateEntryStatus(status); err != nil {
+ response.JSON().BadRequest(err)
+ return
+ }
+ }
+
+ order := request.QueryStringParam("order", model.DefaultSortingOrder)
+ if err := model.ValidateEntryOrder(order); err != nil {
+ response.JSON().BadRequest(err)
+ return
+ }
+
+ direction := request.QueryStringParam("direction", model.DefaultSortingDirection)
+ if err := model.ValidateDirection(direction); err != nil {
+ response.JSON().BadRequest(err)
+ return
+ }
+
+ limit := request.QueryIntegerParam("limit", 100)
+ offset := request.QueryIntegerParam("offset", 0)
+ if err := model.ValidateRange(offset, limit); err != nil {
+ response.JSON().BadRequest(err)
+ return
+ }
+
+ builder := c.store.NewEntryQueryBuilder(userID)
+ builder.WithStatus(status)
+ builder.WithOrder(order)
+ builder.WithDirection(direction)
+ builder.WithOffset(offset)
+ builder.WithLimit(limit)
+
+ entries, err := builder.GetEntries()
+ if err != nil {
+ response.JSON().ServerError(errors.New("Unable to fetch the list of entries"))
+ return
+ }
+
+ count, err := builder.CountEntries()
+ if err != nil {
+ response.JSON().ServerError(errors.New("Unable to count the number of entries"))
+ return
+ }
+
+ response.JSON().Standard(&entriesResponse{Total: count, Entries: entries})
+}
+
+// SetEntryStatus is the API handler to change the status of entries.
+func (c *Controller) SetEntryStatus(ctx *handler.Context, request *handler.Request, response *handler.Response) {
+ userID := ctx.UserID()
+
+ entryIDs, status, err := decodeEntryStatusPayload(request.Body())
+ if err != nil {
+ response.JSON().BadRequest(errors.New("Invalid JSON payload"))
+ return
+ }
+
+ if err := model.ValidateEntryStatus(status); err != nil {
+ response.JSON().BadRequest(err)
+ return
+ }
+
+ if err := c.store.SetEntriesStatus(userID, entryIDs, status); err != nil {
+ response.JSON().ServerError(errors.New("Unable to change entries status"))
+ return
+ }
+
+ response.JSON().NoContent()
+}
+
+// ToggleBookmark is the API handler to toggle bookmark status.
+func (c *Controller) ToggleBookmark(ctx *handler.Context, request *handler.Request, response *handler.Response) {
+ userID := ctx.UserID()
+ entryID, err := request.IntegerParam("entryID")
+ if err != nil {
+ response.JSON().BadRequest(err)
+ return
+ }
+
+ if err := c.store.ToggleBookmark(userID, entryID); err != nil {
+ response.JSON().ServerError(errors.New("Unable to toggle bookmark value"))
+ return
+ }
+
+ response.JSON().NoContent()
+}
lot-bug-1 Unnamed repository; edit this file 'description' to name the repository.
aboutsummaryrefslogtreecommitdiff
path: root/packages/markdown/component/test/fixtures/astro-markdown-shiki/wrap-true (unfollow)
AgeCommit message (Expand)AuthorFilesLines
2022-09-30[ci] update lockfile (#4927)Gravatar Fred K. Bot 1-280/+280
2022-09-30Move module declarations for Markdown and MDX so they're available everywhere...Gravatar Erika 4-35/+46
2022-09-29[ci] formatGravatar tony-sull 4-17/+29
2022-09-29[@astrojs/image] adding caching support for SSG builds (#4909)Gravatar Tony Sullivan 8-10/+240
2022-09-29[ci] release (#4903)astro@1.4.0@astrojs/vue@1.1.0@astrojs/vercel@2.1.0@astrojs/telemetry@1.0.1@astrojs/tailwind@2.0.2@astrojs/svelte@1.0.1@astrojs/rss@1.0.2@astrojs/preact@1.1.1@astrojs/node@1.1.0@astrojs/netlify@1.1.0@astrojs/mdx@0.11.3@astrojs/markdown-remark@1.1.3@astrojs/image@0.8.1@astrojs/deno@1.1.0@astrojs/cloudflare@2.1.0Gravatar Fred K. Bot 65-235/+512
2022-09-29[ci] update lockfile (#4899)Gravatar Fred K. Bot 1-735/+718
2022-09-29[ci] formatGravatar matthewp 1-1/+3
2022-09-29fix trailing slash mismatch in dev vs build in docs example (#4912)Gravatar Rishi Raj Jain 1-1/+1
2022-09-29[ci] formatGravatar bluwy 1-1/+1
2022-09-29Support Vue JSX (#4897)Gravatar Bjorn Lu 12-5/+329
2022-09-28[ci] formatGravatar matthewp 1-8/+4
2022-09-28Fix CSS ordering between imported and Astro styles (#4907)Gravatar Matthew Phillips 12-7/+218
2022-09-28[ci] formatGravatar matthewp 23-137/+127
2022-09-28Astro.cookies implementation (#4876)Gravatar Matthew Phillips 32-29/+943
2022-09-28Fix: let Squoosh default image quality internally (#4906)Gravatar Tony Sullivan 5-11/+20
2022-09-28Update README.md (#4898)Gravatar stijlmassi 1-2/+3
2022-09-28Fix test (#4904)Gravatar Bjorn Lu 2-1/+7
2022-09-28[ci] formatGravatar FredKSchott 2-4/+4
2022-09-28redesign basics template (#4879)Gravatar Fred K. Schott 3-88/+34
2022-09-28[ci] formatGravatar bluwy 1-2/+2
2022-09-28Remove shamefully-hoist (#4842)Gravatar Bjorn Lu 104-527/+768
2022-09-28[ci] formatGravatar matthewp 4-14/+16
2022-09-28Hoist hydration script out of slot templates (#4891)Gravatar Matthew Phillips 13-43/+165
2022-09-28Ensure head content rendered once with lazy layouts (#4892)Gravatar Matthew Phillips 9-3/+59
2022-09-27fixed typing (#4893)Gravatar tweenietomatoes 1-1/+1
2022-09-27[ci] release (#4846)create-astro@1.1.0astro@1.3.1@astrojs/webapi@1.1.0@astrojs/vercel@2.0.1@astrojs/mdx@0.11.2@astrojs/image@0.8.0Gravatar Fred K. Bot 60-185/+169
2022-09-27fix: post API routes in SSG should warn or error during dev mode (#4878)Gravatar Rishi Raj Jain 3-2/+17
2022-09-27docs: Fix links to Tailwind examples (#4883)Gravatar Deanmv 1-1/+1
2022-09-27Set SSR target webworker for Vercel edge (#4884)Gravatar Bjorn Lu 2-0/+6
2022-09-27[ci] update lockfile (#4885)Gravatar Fred K. Bot 1-86/+79
2022-09-26[ci] formatGravatar bholmesdev 3-23/+19
2022-09-26Fix: correctly transform `import.meta.env.*` in MDX (#4858)Gravatar Ben Holmes 12-233/+454
2022-09-26Change negative lookbehind to lookahead (#4866)Gravatar Rishi Raj Jain 1-1/+1
2022-09-26add double check on astro file return type to display more human readable err...Gravatar Steven Yung 6-2/+61
2022-09-26[ci] update lockfile (#4862)Gravatar Fred K. Bot 1-81/+81
2022-09-26fix: Script with innerHTML not working on Safari (#4861)Gravatar Rishi Raj Jain 3-3/+10
2022-09-26Prevent /undefined catch-all routes in dev (#4873)Gravatar Bjorn Lu 6-9/+66
2022-09-26fix: 🐛 BUG: class:list directive adding class attribute when undefined (#4...Gravatar Rishi Raj Jain 2-2/+9
2022-09-26docs: Standardize common integration READMEs (#4874)Gravatar Jake Strawn 7-6/+66
2022-09-26docs: Update references to support channel in Discord. (#4872)Gravatar Jake Strawn 12-12/+12
2022-09-26[ci] formatGravatar bluwy 1-1/+1
2022-09-26fix: "chunks" directory appears in build output, if custom modules are import...Gravatar Rishi Raj Jain 2-6/+34
2022-09-23[ci] formatGravatar matthewp 1-1/+1
2022-09-23Define toStringTag another way (#4855)Gravatar Matthew Phillips 2-4/+12
2022-09-23update SSR example to match recent change on Astro API Context (#4854)Gravatar Steven Yung 2-4/+6
2022-09-23[ci] update lockfile (#4852)Gravatar Fred K. Bot 1-373/+402