diff --git a/api/api.go b/api/api.go index 48eefcca..d512bace 100644 --- a/api/api.go +++ b/api/api.go @@ -5,6 +5,8 @@ package api // import "miniflux.app/api" import ( + "net/http" + "miniflux.app/reader/feed" "miniflux.app/storage" "miniflux.app/worker" @@ -21,33 +23,33 @@ func Serve(router *mux.Router, store *storage.Storage, pool *worker.Pool, feedHa sr.Use(middleware.handleCORS) sr.Use(middleware.apiKeyAuth) sr.Use(middleware.basicAuth) - sr.Methods("OPTIONS") - sr.HandleFunc("/users", handler.createUser).Methods("POST") - sr.HandleFunc("/users", handler.users).Methods("GET") - sr.HandleFunc("/users/{userID:[0-9]+}", handler.userByID).Methods("GET") - sr.HandleFunc("/users/{userID:[0-9]+}", handler.updateUser).Methods("PUT") - sr.HandleFunc("/users/{userID:[0-9]+}", handler.removeUser).Methods("DELETE") - sr.HandleFunc("/users/{username}", handler.userByUsername).Methods("GET") - sr.HandleFunc("/me", handler.currentUser).Methods("GET") - sr.HandleFunc("/categories", handler.createCategory).Methods("POST") - sr.HandleFunc("/categories", handler.getCategories).Methods("GET") - sr.HandleFunc("/categories/{categoryID}", handler.updateCategory).Methods("PUT") - sr.HandleFunc("/categories/{categoryID}", handler.removeCategory).Methods("DELETE") - sr.HandleFunc("/discover", handler.getSubscriptions).Methods("POST") - sr.HandleFunc("/feeds", handler.createFeed).Methods("POST") - sr.HandleFunc("/feeds", handler.getFeeds).Methods("GET") - sr.HandleFunc("/feeds/refresh", handler.refreshAllFeeds).Methods("PUT") - sr.HandleFunc("/feeds/{feedID}/refresh", handler.refreshFeed).Methods("PUT") - sr.HandleFunc("/feeds/{feedID}", handler.getFeed).Methods("GET") - sr.HandleFunc("/feeds/{feedID}", handler.updateFeed).Methods("PUT") - sr.HandleFunc("/feeds/{feedID}", handler.removeFeed).Methods("DELETE") - sr.HandleFunc("/feeds/{feedID}/icon", handler.feedIcon).Methods("GET") - sr.HandleFunc("/export", handler.exportFeeds).Methods("GET") - sr.HandleFunc("/import", handler.importFeeds).Methods("POST") - sr.HandleFunc("/feeds/{feedID}/entries", handler.getFeedEntries).Methods("GET") - sr.HandleFunc("/feeds/{feedID}/entries/{entryID}", handler.getFeedEntry).Methods("GET") - sr.HandleFunc("/entries", handler.getEntries).Methods("GET") - sr.HandleFunc("/entries", handler.setEntryStatus).Methods("PUT") - sr.HandleFunc("/entries/{entryID}", handler.getEntry).Methods("GET") - sr.HandleFunc("/entries/{entryID}/bookmark", handler.toggleBookmark).Methods("PUT") + sr.Methods(http.MethodOptions) + sr.HandleFunc("/users", handler.createUser).Methods(http.MethodPost) + sr.HandleFunc("/users", handler.users).Methods(http.MethodGet) + sr.HandleFunc("/users/{userID:[0-9]+}", handler.userByID).Methods(http.MethodGet) + sr.HandleFunc("/users/{userID:[0-9]+}", handler.updateUser).Methods(http.MethodPut) + sr.HandleFunc("/users/{userID:[0-9]+}", handler.removeUser).Methods(http.MethodDelete) + sr.HandleFunc("/users/{username}", handler.userByUsername).Methods(http.MethodGet) + sr.HandleFunc("/me", handler.currentUser).Methods(http.MethodGet) + sr.HandleFunc("/categories", handler.createCategory).Methods(http.MethodPost) + sr.HandleFunc("/categories", handler.getCategories).Methods(http.MethodGet) + sr.HandleFunc("/categories/{categoryID}", handler.updateCategory).Methods(http.MethodPut) + sr.HandleFunc("/categories/{categoryID}", handler.removeCategory).Methods(http.MethodDelete) + sr.HandleFunc("/discover", handler.getSubscriptions).Methods(http.MethodPost) + sr.HandleFunc("/feeds", handler.createFeed).Methods(http.MethodPost) + sr.HandleFunc("/feeds", handler.getFeeds).Methods(http.MethodGet) + sr.HandleFunc("/feeds/refresh", handler.refreshAllFeeds).Methods(http.MethodPut) + sr.HandleFunc("/feeds/{feedID}/refresh", handler.refreshFeed).Methods(http.MethodPut) + sr.HandleFunc("/feeds/{feedID}", handler.getFeed).Methods(http.MethodGet) + sr.HandleFunc("/feeds/{feedID}", handler.updateFeed).Methods(http.MethodPut) + sr.HandleFunc("/feeds/{feedID}", handler.removeFeed).Methods(http.MethodDelete) + sr.HandleFunc("/feeds/{feedID}/icon", handler.feedIcon).Methods(http.MethodGet) + sr.HandleFunc("/export", handler.exportFeeds).Methods(http.MethodGet) + sr.HandleFunc("/import", handler.importFeeds).Methods(http.MethodPost) + sr.HandleFunc("/feeds/{feedID}/entries", handler.getFeedEntries).Methods(http.MethodGet) + sr.HandleFunc("/feeds/{feedID}/entries/{entryID}", handler.getFeedEntry).Methods(http.MethodGet) + sr.HandleFunc("/entries", handler.getEntries).Methods(http.MethodGet) + sr.HandleFunc("/entries", handler.setEntryStatus).Methods(http.MethodPut) + sr.HandleFunc("/entries/{entryID}", handler.getEntry).Methods(http.MethodGet) + sr.HandleFunc("/entries/{entryID}/bookmark", handler.toggleBookmark).Methods(http.MethodPut) } diff --git a/ui/middleware.go b/ui/middleware.go index e008e541..a7707ae1 100644 --- a/ui/middleware.go +++ b/ui/middleware.go @@ -83,7 +83,7 @@ func (m *middleware) handleAppSession(next http.Handler) http.Handler { logger.Debug("[UI:AppSession] %s", session) } - if r.Method == "POST" { + if r.Method == http.MethodPost { formValue := r.FormValue("csrf") headerValue := r.Header.Get("X-Csrf-Token") diff --git a/ui/ui.go b/ui/ui.go index c66130c9..36c9fd7c 100644 --- a/ui/ui.go +++ b/ui/ui.go @@ -25,117 +25,117 @@ func Serve(router *mux.Router, store *storage.Storage, pool *worker.Pool, feedHa uiRouter.Use(middleware.handleAppSession) // Static assets. - uiRouter.HandleFunc("/stylesheets/{name}.css", handler.showStylesheet).Name("stylesheet").Methods("GET") - uiRouter.HandleFunc("/{name}.js", handler.showJavascript).Name("javascript").Methods("GET") - uiRouter.HandleFunc("/favicon.ico", handler.showFavicon).Name("favicon").Methods("GET") - uiRouter.HandleFunc("/icon/{filename}", handler.showAppIcon).Name("appIcon").Methods("GET") - uiRouter.HandleFunc("/manifest.json", handler.showWebManifest).Name("webManifest").Methods("GET") + uiRouter.HandleFunc("/stylesheets/{name}.css", handler.showStylesheet).Name("stylesheet").Methods(http.MethodGet) + uiRouter.HandleFunc("/{name}.js", handler.showJavascript).Name("javascript").Methods(http.MethodGet) + uiRouter.HandleFunc("/favicon.ico", handler.showFavicon).Name("favicon").Methods(http.MethodGet) + uiRouter.HandleFunc("/icon/{filename}", handler.showAppIcon).Name("appIcon").Methods(http.MethodGet) + uiRouter.HandleFunc("/manifest.json", handler.showWebManifest).Name("webManifest").Methods(http.MethodGet) // New subscription pages. - uiRouter.HandleFunc("/subscribe", handler.showAddSubscriptionPage).Name("addSubscription").Methods("GET") - uiRouter.HandleFunc("/subscribe", handler.submitSubscription).Name("submitSubscription").Methods("POST") - uiRouter.HandleFunc("/subscriptions", handler.showChooseSubscriptionPage).Name("chooseSubscription").Methods("POST") - uiRouter.HandleFunc("/bookmarklet", handler.bookmarklet).Name("bookmarklet").Methods("GET") + uiRouter.HandleFunc("/subscribe", handler.showAddSubscriptionPage).Name("addSubscription").Methods(http.MethodGet) + uiRouter.HandleFunc("/subscribe", handler.submitSubscription).Name("submitSubscription").Methods(http.MethodPost) + uiRouter.HandleFunc("/subscriptions", handler.showChooseSubscriptionPage).Name("chooseSubscription").Methods(http.MethodPost) + uiRouter.HandleFunc("/bookmarklet", handler.bookmarklet).Name("bookmarklet").Methods(http.MethodGet) // Unread page. - uiRouter.HandleFunc("/mark-all-as-read", handler.markAllAsRead).Name("markAllAsRead").Methods("POST") - uiRouter.HandleFunc("/unread", handler.showUnreadPage).Name("unread").Methods("GET") - uiRouter.HandleFunc("/unread/entry/{entryID}", handler.showUnreadEntryPage).Name("unreadEntry").Methods("GET") + uiRouter.HandleFunc("/mark-all-as-read", handler.markAllAsRead).Name("markAllAsRead").Methods(http.MethodPost) + uiRouter.HandleFunc("/unread", handler.showUnreadPage).Name("unread").Methods(http.MethodGet) + uiRouter.HandleFunc("/unread/entry/{entryID}", handler.showUnreadEntryPage).Name("unreadEntry").Methods(http.MethodGet) // History pages. - uiRouter.HandleFunc("/history", handler.showHistoryPage).Name("history").Methods("GET") - uiRouter.HandleFunc("/history/entry/{entryID}", handler.showReadEntryPage).Name("readEntry").Methods("GET") - uiRouter.HandleFunc("/history/flush", handler.flushHistory).Name("flushHistory").Methods("POST") + uiRouter.HandleFunc("/history", handler.showHistoryPage).Name("history").Methods(http.MethodGet) + uiRouter.HandleFunc("/history/entry/{entryID}", handler.showReadEntryPage).Name("readEntry").Methods(http.MethodGet) + uiRouter.HandleFunc("/history/flush", handler.flushHistory).Name("flushHistory").Methods(http.MethodPost) // Bookmark pages. - uiRouter.HandleFunc("/starred", handler.showStarredPage).Name("starred").Methods("GET") - uiRouter.HandleFunc("/starred/entry/{entryID}", handler.showStarredEntryPage).Name("starredEntry").Methods("GET") + uiRouter.HandleFunc("/starred", handler.showStarredPage).Name("starred").Methods(http.MethodGet) + uiRouter.HandleFunc("/starred/entry/{entryID}", handler.showStarredEntryPage).Name("starredEntry").Methods(http.MethodGet) // Search pages. - uiRouter.HandleFunc("/search", handler.showSearchEntriesPage).Name("searchEntries").Methods("GET") - uiRouter.HandleFunc("/search/entry/{entryID}", handler.showSearchEntryPage).Name("searchEntry").Methods("GET") + uiRouter.HandleFunc("/search", handler.showSearchEntriesPage).Name("searchEntries").Methods(http.MethodGet) + uiRouter.HandleFunc("/search/entry/{entryID}", handler.showSearchEntryPage).Name("searchEntry").Methods(http.MethodGet) // Feed listing pages. - uiRouter.HandleFunc("/feeds", handler.showFeedsPage).Name("feeds").Methods("GET") - uiRouter.HandleFunc("/feeds/refresh", handler.refreshAllFeeds).Name("refreshAllFeeds").Methods("GET") + uiRouter.HandleFunc("/feeds", handler.showFeedsPage).Name("feeds").Methods(http.MethodGet) + uiRouter.HandleFunc("/feeds/refresh", handler.refreshAllFeeds).Name("refreshAllFeeds").Methods(http.MethodGet) // Individual feed pages. - uiRouter.HandleFunc("/feed/{feedID}/refresh", handler.refreshFeed).Name("refreshFeed").Methods("GET") - uiRouter.HandleFunc("/feed/{feedID}/edit", handler.showEditFeedPage).Name("editFeed").Methods("GET") - uiRouter.HandleFunc("/feed/{feedID}/remove", handler.removeFeed).Name("removeFeed").Methods("POST") - uiRouter.HandleFunc("/feed/{feedID}/update", handler.updateFeed).Name("updateFeed").Methods("POST") - uiRouter.HandleFunc("/feed/{feedID}/entries", handler.showFeedEntriesPage).Name("feedEntries").Methods("GET") - uiRouter.HandleFunc("/feed/{feedID}/entries/all", handler.showFeedEntriesAllPage).Name("feedEntriesAll").Methods("GET") - uiRouter.HandleFunc("/feed/{feedID}/entry/{entryID}", handler.showFeedEntryPage).Name("feedEntry").Methods("GET") - uiRouter.HandleFunc("/feed/icon/{iconID}", handler.showIcon).Name("icon").Methods("GET") + uiRouter.HandleFunc("/feed/{feedID}/refresh", handler.refreshFeed).Name("refreshFeed").Methods(http.MethodGet) + uiRouter.HandleFunc("/feed/{feedID}/edit", handler.showEditFeedPage).Name("editFeed").Methods(http.MethodGet) + uiRouter.HandleFunc("/feed/{feedID}/remove", handler.removeFeed).Name("removeFeed").Methods(http.MethodPost) + uiRouter.HandleFunc("/feed/{feedID}/update", handler.updateFeed).Name("updateFeed").Methods(http.MethodPost) + uiRouter.HandleFunc("/feed/{feedID}/entries", handler.showFeedEntriesPage).Name("feedEntries").Methods(http.MethodGet) + uiRouter.HandleFunc("/feed/{feedID}/entries/all", handler.showFeedEntriesAllPage).Name("feedEntriesAll").Methods(http.MethodGet) + uiRouter.HandleFunc("/feed/{feedID}/entry/{entryID}", handler.showFeedEntryPage).Name("feedEntry").Methods(http.MethodGet) + uiRouter.HandleFunc("/feed/icon/{iconID}", handler.showIcon).Name("icon").Methods(http.MethodGet) // Category pages. - uiRouter.HandleFunc("/category/{categoryID}/entry/{entryID}", handler.showCategoryEntryPage).Name("categoryEntry").Methods("GET") - uiRouter.HandleFunc("/categories", handler.showCategoryListPage).Name("categories").Methods("GET") - uiRouter.HandleFunc("/category/create", handler.showCreateCategoryPage).Name("createCategory").Methods("GET") - uiRouter.HandleFunc("/category/save", handler.saveCategory).Name("saveCategory").Methods("POST") - uiRouter.HandleFunc("/category/{categoryID}/feeds", handler.showCategoryFeedsPage).Name("categoryFeeds").Methods("GET") - uiRouter.HandleFunc("/category/{categoryID}/entries", handler.showCategoryEntriesPage).Name("categoryEntries").Methods("GET") - uiRouter.HandleFunc("/category/{categoryID}/entries/all", handler.showCategoryEntriesAllPage).Name("categoryEntriesAll").Methods("GET") - uiRouter.HandleFunc("/category/{categoryID}/edit", handler.showEditCategoryPage).Name("editCategory").Methods("GET") - uiRouter.HandleFunc("/category/{categoryID}/update", handler.updateCategory).Name("updateCategory").Methods("POST") - uiRouter.HandleFunc("/category/{categoryID}/remove", handler.removeCategory).Name("removeCategory").Methods("POST") + uiRouter.HandleFunc("/category/{categoryID}/entry/{entryID}", handler.showCategoryEntryPage).Name("categoryEntry").Methods(http.MethodGet) + uiRouter.HandleFunc("/categories", handler.showCategoryListPage).Name("categories").Methods(http.MethodGet) + uiRouter.HandleFunc("/category/create", handler.showCreateCategoryPage).Name("createCategory").Methods(http.MethodGet) + uiRouter.HandleFunc("/category/save", handler.saveCategory).Name("saveCategory").Methods(http.MethodPost) + uiRouter.HandleFunc("/category/{categoryID}/feeds", handler.showCategoryFeedsPage).Name("categoryFeeds").Methods(http.MethodGet) + uiRouter.HandleFunc("/category/{categoryID}/entries", handler.showCategoryEntriesPage).Name("categoryEntries").Methods(http.MethodGet) + uiRouter.HandleFunc("/category/{categoryID}/entries/all", handler.showCategoryEntriesAllPage).Name("categoryEntriesAll").Methods(http.MethodGet) + uiRouter.HandleFunc("/category/{categoryID}/edit", handler.showEditCategoryPage).Name("editCategory").Methods(http.MethodGet) + uiRouter.HandleFunc("/category/{categoryID}/update", handler.updateCategory).Name("updateCategory").Methods(http.MethodPost) + uiRouter.HandleFunc("/category/{categoryID}/remove", handler.removeCategory).Name("removeCategory").Methods(http.MethodPost) // Entry pages. - uiRouter.HandleFunc("/entry/status", handler.updateEntriesStatus).Name("updateEntriesStatus").Methods("POST") - uiRouter.HandleFunc("/entry/save/{entryID}", handler.saveEntry).Name("saveEntry").Methods("POST") - uiRouter.HandleFunc("/entry/download/{entryID}", handler.fetchContent).Name("fetchContent").Methods("POST") - uiRouter.HandleFunc("/proxy/{encodedURL}", handler.imageProxy).Name("proxy").Methods("GET") - uiRouter.HandleFunc("/entry/bookmark/{entryID}", handler.toggleBookmark).Name("toggleBookmark").Methods("POST") + uiRouter.HandleFunc("/entry/status", handler.updateEntriesStatus).Name("updateEntriesStatus").Methods(http.MethodPost) + uiRouter.HandleFunc("/entry/save/{entryID}", handler.saveEntry).Name("saveEntry").Methods(http.MethodPost) + uiRouter.HandleFunc("/entry/download/{entryID}", handler.fetchContent).Name("fetchContent").Methods(http.MethodPost) + uiRouter.HandleFunc("/proxy/{encodedURL}", handler.imageProxy).Name("proxy").Methods(http.MethodGet) + uiRouter.HandleFunc("/entry/bookmark/{entryID}", handler.toggleBookmark).Name("toggleBookmark").Methods(http.MethodPost) // Share pages. - uiRouter.HandleFunc("/entry/share/{entryID}", handler.createSharedEntry).Name("shareEntry").Methods("GET") - uiRouter.HandleFunc("/entry/unshare/{entryID}", handler.unshareEntry).Name("unshareEntry").Methods("POST") - uiRouter.HandleFunc("/share/{shareCode}", handler.sharedEntry).Name("sharedEntry").Methods("GET") - uiRouter.HandleFunc("/shares", handler.sharedEntries).Name("sharedEntries").Methods("GET") + uiRouter.HandleFunc("/entry/share/{entryID}", handler.createSharedEntry).Name("shareEntry").Methods(http.MethodGet) + uiRouter.HandleFunc("/entry/unshare/{entryID}", handler.unshareEntry).Name("unshareEntry").Methods(http.MethodPost) + uiRouter.HandleFunc("/share/{shareCode}", handler.sharedEntry).Name("sharedEntry").Methods(http.MethodGet) + uiRouter.HandleFunc("/shares", handler.sharedEntries).Name("sharedEntries").Methods(http.MethodGet) // User pages. - uiRouter.HandleFunc("/users", handler.showUsersPage).Name("users").Methods("GET") - uiRouter.HandleFunc("/user/create", handler.showCreateUserPage).Name("createUser").Methods("GET") - uiRouter.HandleFunc("/user/save", handler.saveUser).Name("saveUser").Methods("POST") - uiRouter.HandleFunc("/users/{userID}/edit", handler.showEditUserPage).Name("editUser").Methods("GET") - uiRouter.HandleFunc("/users/{userID}/update", handler.updateUser).Name("updateUser").Methods("POST") - uiRouter.HandleFunc("/users/{userID}/remove", handler.removeUser).Name("removeUser").Methods("POST") + uiRouter.HandleFunc("/users", handler.showUsersPage).Name("users").Methods(http.MethodGet) + uiRouter.HandleFunc("/user/create", handler.showCreateUserPage).Name("createUser").Methods(http.MethodGet) + uiRouter.HandleFunc("/user/save", handler.saveUser).Name("saveUser").Methods(http.MethodPost) + uiRouter.HandleFunc("/users/{userID}/edit", handler.showEditUserPage).Name("editUser").Methods(http.MethodGet) + uiRouter.HandleFunc("/users/{userID}/update", handler.updateUser).Name("updateUser").Methods(http.MethodPost) + uiRouter.HandleFunc("/users/{userID}/remove", handler.removeUser).Name("removeUser").Methods(http.MethodPost) // Settings pages. - uiRouter.HandleFunc("/settings", handler.showSettingsPage).Name("settings").Methods("GET") - uiRouter.HandleFunc("/settings", handler.updateSettings).Name("updateSettings").Methods("POST") - uiRouter.HandleFunc("/integrations", handler.showIntegrationPage).Name("integrations").Methods("GET") - uiRouter.HandleFunc("/integration", handler.updateIntegration).Name("updateIntegration").Methods("POST") - uiRouter.HandleFunc("/integration/pocket/authorize", handler.pocketAuthorize).Name("pocketAuthorize").Methods("GET") - uiRouter.HandleFunc("/integration/pocket/callback", handler.pocketCallback).Name("pocketCallback").Methods("GET") - uiRouter.HandleFunc("/about", handler.showAboutPage).Name("about").Methods("GET") + uiRouter.HandleFunc("/settings", handler.showSettingsPage).Name("settings").Methods(http.MethodGet) + uiRouter.HandleFunc("/settings", handler.updateSettings).Name("updateSettings").Methods(http.MethodPost) + uiRouter.HandleFunc("/integrations", handler.showIntegrationPage).Name("integrations").Methods(http.MethodGet) + uiRouter.HandleFunc("/integration", handler.updateIntegration).Name("updateIntegration").Methods(http.MethodPost) + uiRouter.HandleFunc("/integration/pocket/authorize", handler.pocketAuthorize).Name("pocketAuthorize").Methods(http.MethodGet) + uiRouter.HandleFunc("/integration/pocket/callback", handler.pocketCallback).Name("pocketCallback").Methods(http.MethodGet) + uiRouter.HandleFunc("/about", handler.showAboutPage).Name("about").Methods(http.MethodGet) // Session pages. - uiRouter.HandleFunc("/sessions", handler.showSessionsPage).Name("sessions").Methods("GET") - uiRouter.HandleFunc("/sessions/{sessionID}/remove", handler.removeSession).Name("removeSession").Methods("POST") + uiRouter.HandleFunc("/sessions", handler.showSessionsPage).Name("sessions").Methods(http.MethodGet) + uiRouter.HandleFunc("/sessions/{sessionID}/remove", handler.removeSession).Name("removeSession").Methods(http.MethodPost) // API Keys pages. - uiRouter.HandleFunc("/keys", handler.showAPIKeysPage).Name("apiKeys").Methods("GET") - uiRouter.HandleFunc("/keys/{keyID}/remove", handler.removeAPIKey).Name("removeAPIKey").Methods("POST") - uiRouter.HandleFunc("/keys/create", handler.showCreateAPIKeyPage).Name("createAPIKey").Methods("GET") - uiRouter.HandleFunc("/keys/save", handler.saveAPIKey).Name("saveAPIKey").Methods("POST") + uiRouter.HandleFunc("/keys", handler.showAPIKeysPage).Name("apiKeys").Methods(http.MethodGet) + uiRouter.HandleFunc("/keys/{keyID}/remove", handler.removeAPIKey).Name("removeAPIKey").Methods(http.MethodPost) + uiRouter.HandleFunc("/keys/create", handler.showCreateAPIKeyPage).Name("createAPIKey").Methods(http.MethodGet) + uiRouter.HandleFunc("/keys/save", handler.saveAPIKey).Name("saveAPIKey").Methods(http.MethodPost) // OPML pages. - uiRouter.HandleFunc("/export", handler.exportFeeds).Name("export").Methods("GET") - uiRouter.HandleFunc("/import", handler.showImportPage).Name("import").Methods("GET") - uiRouter.HandleFunc("/upload", handler.uploadOPML).Name("uploadOPML").Methods("POST") - uiRouter.HandleFunc("/fetch", handler.fetchOPML).Name("fetchOPML").Methods("POST") + uiRouter.HandleFunc("/export", handler.exportFeeds).Name("export").Methods(http.MethodGet) + uiRouter.HandleFunc("/import", handler.showImportPage).Name("import").Methods(http.MethodGet) + uiRouter.HandleFunc("/upload", handler.uploadOPML).Name("uploadOPML").Methods(http.MethodPost) + uiRouter.HandleFunc("/fetch", handler.fetchOPML).Name("fetchOPML").Methods(http.MethodPost) // OAuth2 flow. - uiRouter.HandleFunc("/oauth2/{provider}/unlink", handler.oauth2Unlink).Name("oauth2Unlink").Methods("GET") - uiRouter.HandleFunc("/oauth2/{provider}/redirect", handler.oauth2Redirect).Name("oauth2Redirect").Methods("GET") - uiRouter.HandleFunc("/oauth2/{provider}/callback", handler.oauth2Callback).Name("oauth2Callback").Methods("GET") + uiRouter.HandleFunc("/oauth2/{provider}/unlink", handler.oauth2Unlink).Name("oauth2Unlink").Methods(http.MethodGet) + uiRouter.HandleFunc("/oauth2/{provider}/redirect", handler.oauth2Redirect).Name("oauth2Redirect").Methods(http.MethodGet) + uiRouter.HandleFunc("/oauth2/{provider}/callback", handler.oauth2Callback).Name("oauth2Callback").Methods(http.MethodGet) // Authentication pages. - uiRouter.HandleFunc("/login", handler.checkLogin).Name("checkLogin").Methods("POST") - uiRouter.HandleFunc("/logout", handler.logout).Name("logout").Methods("GET") - uiRouter.Handle("/", middleware.handleAuthProxy(http.HandlerFunc(handler.showLoginPage))).Name("login").Methods("GET") + uiRouter.HandleFunc("/login", handler.checkLogin).Name("checkLogin").Methods(http.MethodPost) + uiRouter.HandleFunc("/logout", handler.logout).Name("logout").Methods(http.MethodGet) + uiRouter.Handle("/", middleware.handleAuthProxy(http.HandlerFunc(handler.showLoginPage))).Name("login").Methods(http.MethodGet) router.HandleFunc("/robots.txt", func(w http.ResponseWriter, r *http.Request) { w.Header().Set("Content-Type", "text/plain")