diff options
author | 2023-08-10 19:46:45 -0700 | |
---|---|---|
committer | 2023-08-10 20:29:34 -0700 | |
commit | 168a870c025bfef6efdeb46e166e79a16093c157 (patch) | |
tree | 4d8ab69c7e3ef03a7ade06e7b5e5053429a64c3b /internal/ui/feed_edit.go | |
parent | c2349032552891745cbbc3d2a9e772845a0239f4 (diff) | |
download | v2-168a870c025bfef6efdeb46e166e79a16093c157.tar.gz v2-168a870c025bfef6efdeb46e166e79a16093c157.tar.zst v2-168a870c025bfef6efdeb46e166e79a16093c157.zip |
Move internal packages to an internal folder
For reference: https://go.dev/doc/go1.4#internalpackages
Diffstat (limited to 'internal/ui/feed_edit.go')
-rw-r--r-- | internal/ui/feed_edit.go | 79 |
1 files changed, 79 insertions, 0 deletions
diff --git a/internal/ui/feed_edit.go b/internal/ui/feed_edit.go new file mode 100644 index 00000000..a9bb4fe7 --- /dev/null +++ b/internal/ui/feed_edit.go @@ -0,0 +1,79 @@ +// SPDX-FileCopyrightText: Copyright The Miniflux Authors. All rights reserved. +// SPDX-License-Identifier: Apache-2.0 + +package ui // import "miniflux.app/v2/internal/ui" + +import ( + "net/http" + + "miniflux.app/v2/internal/config" + "miniflux.app/v2/internal/http/request" + "miniflux.app/v2/internal/http/response/html" + "miniflux.app/v2/internal/ui/form" + "miniflux.app/v2/internal/ui/session" + "miniflux.app/v2/internal/ui/view" +) + +func (h *handler) showEditFeedPage(w http.ResponseWriter, r *http.Request) { + user, err := h.store.UserByID(request.UserID(r)) + if err != nil { + html.ServerError(w, r, err) + return + } + + feedID := request.RouteInt64Param(r, "feedID") + feed, err := h.store.FeedByID(user.ID, feedID) + if err != nil { + html.ServerError(w, r, err) + return + } + + if feed == nil { + html.NotFound(w, r) + return + } + + categories, err := h.store.Categories(user.ID) + if err != nil { + html.ServerError(w, r, err) + return + } + + feedForm := form.FeedForm{ + SiteURL: feed.SiteURL, + FeedURL: feed.FeedURL, + Title: feed.Title, + ScraperRules: feed.ScraperRules, + RewriteRules: feed.RewriteRules, + BlocklistRules: feed.BlocklistRules, + KeeplistRules: feed.KeeplistRules, + UrlRewriteRules: feed.UrlRewriteRules, + Crawler: feed.Crawler, + UserAgent: feed.UserAgent, + Cookie: feed.Cookie, + CategoryID: feed.Category.ID, + Username: feed.Username, + Password: feed.Password, + IgnoreHTTPCache: feed.IgnoreHTTPCache, + AllowSelfSignedCertificates: feed.AllowSelfSignedCertificates, + FetchViaProxy: feed.FetchViaProxy, + Disabled: feed.Disabled, + NoMediaPlayer: feed.NoMediaPlayer, + HideGlobally: feed.HideGlobally, + CategoryHidden: feed.Category.HideGlobally, + } + + sess := session.New(h.store, request.SessionID(r)) + view := view.New(h.tpl, r, sess) + view.Set("form", feedForm) + view.Set("categories", categories) + view.Set("feed", feed) + view.Set("menu", "feeds") + view.Set("user", user) + view.Set("countUnread", h.store.CountUnreadEntries(user.ID)) + view.Set("countErrorFeeds", h.store.CountUserFeedsWithErrors(user.ID)) + view.Set("defaultUserAgent", config.Opts.HTTPClientUserAgent()) + view.Set("hasProxyConfigured", config.Opts.HasHTTPClientProxyConfigured()) + + html.OK(w, r, view.Render("edit_feed")) +} |