2021-05-09 10:42:12 +00:00
|
|
|
package web
|
2020-12-08 09:04:24 +00:00
|
|
|
|
|
|
|
import (
|
2020-12-08 15:15:32 +00:00
|
|
|
"fmt"
|
2022-04-01 19:51:15 +00:00
|
|
|
"github.com/bouncepaw/mycorrhiza/viewutil"
|
2022-05-18 16:12:00 +00:00
|
|
|
"github.com/gorilla/mux"
|
2020-12-08 09:04:24 +00:00
|
|
|
"log"
|
|
|
|
"net/http"
|
2021-07-15 17:46:35 +00:00
|
|
|
|
2020-12-08 09:04:24 +00:00
|
|
|
"github.com/bouncepaw/mycorrhiza/history"
|
2021-09-06 17:46:34 +00:00
|
|
|
"github.com/bouncepaw/mycorrhiza/l18n"
|
2020-12-08 09:04:24 +00:00
|
|
|
"github.com/bouncepaw/mycorrhiza/util"
|
2021-02-20 16:14:33 +00:00
|
|
|
"github.com/bouncepaw/mycorrhiza/views"
|
2020-12-08 09:04:24 +00:00
|
|
|
)
|
|
|
|
|
2021-07-15 17:46:35 +00:00
|
|
|
func initHistory(r *mux.Router) {
|
|
|
|
r.PathPrefix("/history/").HandlerFunc(handlerHistory)
|
|
|
|
|
|
|
|
r.HandleFunc("/recent-changes-rss", handlerRecentChangesRSS)
|
|
|
|
r.HandleFunc("/recent-changes-atom", handlerRecentChangesAtom)
|
|
|
|
r.HandleFunc("/recent-changes-json", handlerRecentChangesJSON)
|
2020-12-08 09:04:24 +00:00
|
|
|
}
|
|
|
|
|
2021-05-09 11:09:27 +00:00
|
|
|
// handlerHistory lists all revisions of a hypha.
|
2020-12-08 09:04:24 +00:00
|
|
|
func handlerHistory(w http.ResponseWriter, rq *http.Request) {
|
2021-05-09 10:42:12 +00:00
|
|
|
hyphaName := util.HyphaNameFromRq(rq, "history")
|
2020-12-08 09:04:24 +00:00
|
|
|
var list string
|
|
|
|
|
|
|
|
// History can be found for files that do not exist anymore.
|
|
|
|
revs, err := history.Revisions(hyphaName)
|
|
|
|
if err == nil {
|
2021-10-01 17:12:16 +00:00
|
|
|
list = history.WithRevisions(hyphaName, revs)
|
2020-12-08 09:04:24 +00:00
|
|
|
}
|
|
|
|
log.Println("Found", len(revs), "revisions for", hyphaName)
|
|
|
|
|
2021-09-06 17:46:34 +00:00
|
|
|
var lc = l18n.FromRequest(rq)
|
2022-03-20 21:24:40 +00:00
|
|
|
util.HTTP200Page(w, views.Base(
|
2022-04-01 19:51:15 +00:00
|
|
|
viewutil.MetaFrom(w, rq),
|
2021-09-06 17:46:34 +00:00
|
|
|
fmt.Sprintf(lc.Get("ui.history_title"), util.BeautifulName(hyphaName)),
|
2022-03-20 21:24:40 +00:00
|
|
|
views.History(rq, hyphaName, list, lc),
|
2022-04-01 19:51:15 +00:00
|
|
|
))
|
2020-12-08 09:04:24 +00:00
|
|
|
}
|
|
|
|
|
2021-05-09 11:09:27 +00:00
|
|
|
// genericHandlerOfFeeds is a helper function for the web feed handlers.
|
2021-10-25 21:51:36 +00:00
|
|
|
func genericHandlerOfFeeds(w http.ResponseWriter, rq *http.Request, f func(history.FeedOptions) (string, error), name string, contentType string) {
|
|
|
|
opts, err := history.ParseFeedOptions(rq.URL.Query())
|
|
|
|
var content string
|
|
|
|
if err == nil {
|
|
|
|
content, err = f(opts)
|
|
|
|
}
|
|
|
|
|
|
|
|
if err != nil {
|
2020-12-08 15:15:32 +00:00
|
|
|
w.Header().Set("Content-Type", "text/plain;charset=utf-8")
|
|
|
|
w.WriteHeader(http.StatusInternalServerError)
|
|
|
|
fmt.Fprint(w, "An error while generating "+name+": "+err.Error())
|
|
|
|
} else {
|
2021-09-29 15:02:30 +00:00
|
|
|
w.Header().Set("Content-Type", fmt.Sprintf("%s;charset=utf-8", contentType))
|
2020-12-08 15:15:32 +00:00
|
|
|
w.WriteHeader(http.StatusOK)
|
|
|
|
fmt.Fprint(w, content)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func handlerRecentChangesRSS(w http.ResponseWriter, rq *http.Request) {
|
2021-09-29 15:02:30 +00:00
|
|
|
genericHandlerOfFeeds(w, rq, history.RecentChangesRSS, "RSS", "application/rss+xml")
|
2020-12-08 15:15:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func handlerRecentChangesAtom(w http.ResponseWriter, rq *http.Request) {
|
2021-09-29 15:02:30 +00:00
|
|
|
genericHandlerOfFeeds(w, rq, history.RecentChangesAtom, "Atom", "application/atom+xml")
|
2020-12-08 15:15:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func handlerRecentChangesJSON(w http.ResponseWriter, rq *http.Request) {
|
2021-09-29 15:02:30 +00:00
|
|
|
genericHandlerOfFeeds(w, rq, history.RecentChangesJSON, "JSON feed", "application/json")
|
2020-12-08 15:15:32 +00:00
|
|
|
}
|