// 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/miniflux2/server/api/payload" "github.com/miniflux/miniflux2/server/core" ) // CreateFeed is the API handler to create a new feed. func (c *Controller) CreateFeed(ctx *core.Context, request *core.Request, response *core.Response) { userID := ctx.UserID() feedURL, categoryID, err := payload.DecodeFeedCreationPayload(request.Body()) if err != nil { response.JSON().BadRequest(err) return } feed, err := c.feedHandler.CreateFeed(userID, categoryID, feedURL) if err != nil { response.JSON().ServerError(errors.New("Unable to create this feed")) return } type result struct { FeedID int64 `json:"feed_id"` } response.JSON().Created(&result{FeedID: feed.ID}) } // RefreshFeed is the API handler to refresh a feed. func (c *Controller) RefreshFeed(ctx *core.Context, request *core.Request, response *core.Response) { userID := ctx.UserID() feedID, err := request.IntegerParam("feedID") if err != nil { response.JSON().BadRequest(err) return } err = c.feedHandler.RefreshFeed(userID, feedID) if err != nil { response.JSON().ServerError(errors.New("Unable to refresh this feed")) return } response.JSON().NoContent() } // UpdateFeed is the API handler that is used to update a feed. func (c *Controller) UpdateFeed(ctx *core.Context, request *core.Request, response *core.Response) { userID := ctx.UserID() feedID, err := request.IntegerParam("feedID") if err != nil { response.JSON().BadRequest(err) return } newFeed, err := payload.DecodeFeedModificationPayload(request.Body()) if err != nil { response.JSON().BadRequest(err) return } originalFeed, err := c.store.GetFeedById(userID, feedID) if err != nil { response.JSON().NotFound(errors.New("Unable to find this feed")) return } if originalFeed == nil { response.JSON().NotFound(errors.New("Feed not found")) return } originalFeed.Merge(newFeed) if err := c.store.UpdateFeed(originalFeed); err != nil { response.JSON().ServerError(errors.New("Unable to update this feed")) return } response.JSON().Created(originalFeed) } // GetFeeds is the API handler that get all feeds that belongs to the given user. func (c *Controller) GetFeeds(ctx *core.Context, request *core.Request, response *core.Response) { feeds, err := c.store.GetFeeds(ctx.UserID()) if err != nil { response.JSON().ServerError(errors.New("Unable to fetch feeds from the database")) return } response.JSON().Standard(feeds) } // GetFeed is the API handler to get a feed. func (c *Controller) GetFeed(ctx *core.Context, request *core.Request, response *core.Response) { userID := ctx.UserID() feedID, err := request.IntegerParam("feedID") if err != nil { response.JSON().BadRequest(err) return } feed, err := c.store.GetFeedById(userID, feedID) if err != nil { response.JSON().ServerError(errors.New("Unable to fetch this feed")) return } if feed == nil { response.JSON().NotFound(errors.New("Feed not found")) return } response.JSON().Standard(feed) } // RemoveFeed is the API handler to remove a feed. func (c *Controller) RemoveFeed(ctx *core.Context, request *core.Request, response *core.Response) { userID := ctx.UserID() feedID, err := request.IntegerParam("feedID") if err != nil { response.JSON().BadRequest(err) return } if !c.store.FeedExists(userID, feedID) { response.JSON().NotFound(errors.New("Feed not found")) return } if err := c.store.RemoveFeed(userID, feedID); err != nil { response.JSON().ServerError(errors.New("Unable to remove this feed")) return } response.JSON().NoContent() }