Skip to content

Commit

Permalink
RSS: Fix URLs to point to the correct feed and page
Browse files Browse the repository at this point in the history
  • Loading branch information
the-blank-x committed Dec 22, 2023
1 parent 583c858 commit 75316a5
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 11 deletions.
12 changes: 7 additions & 5 deletions src/routes/rss.nim
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ proc redisKey*(page, name, cursor: string): string =
if cursor.len > 0:
result &= ":" & cursor

proc timelineRss*(req: Request; cfg: Config; query: Query): Future[Rss] {.async.} =
proc timelineRss*(req: Request; cfg: Config; query: Query; tab, param: string): Future[Rss] {.async.} =
var profile: Profile
let
name = req.params.getOrDefault("name")
Expand All @@ -39,7 +39,7 @@ proc timelineRss*(req: Request; cfg: Config; query: Query): Future[Rss] {.async.
return Rss(feed: profile.user.username, cursor: "suspended")

if profile.user.fullname.len > 0:
let rss = renderTimelineRss(profile, cfg, multi=(names.len > 1))
let rss = renderTimelineRss(profile, cfg, tab, param, multi=(names.len > 1))
return Rss(feed: rss, cursor: profile.tweets.bottom)

template respRss*(rss, page) =
Expand Down Expand Up @@ -94,7 +94,7 @@ proc createRssRouter*(cfg: Config) =
if rss.cursor.len > 0:
respRss(rss, "User")

rss = await timelineRss(request, cfg, Query(fromUser: @[name]))
rss = await timelineRss(request, cfg, Query(fromUser: @[name]), "", "")

await cacheRss(key, rss)
respRss(rss, "User")
Expand All @@ -113,16 +113,18 @@ proc createRssRouter*(cfg: Config) =
of "search": initQuery(params(request), name=name)
else: Query(fromUser: @[name])

let param = if tab != "search": ""
else: genQueryUrl(query)
let searchKey = if tab != "search": ""
else: ":" & $hash(genQueryUrl(query))
else: ":" & $hash(param)

let key = redisKey(tab, name & searchKey, getCursor())

var rss = await getCachedRss(key)
if rss.cursor.len > 0:
respRss(rss, "User")

rss = await timelineRss(request, cfg, query)
rss = await timelineRss(request, cfg, query, tab, param)

await cacheRss(key, rss)
respRss(rss, "User")
Expand Down
25 changes: 19 additions & 6 deletions src/views/rss.nimf
Original file line number Diff line number Diff line change
Expand Up @@ -82,8 +82,20 @@ Twitter feed for: ${desc}. Generated by ${cfg.hostname}
#end for
#end proc
#
#proc renderTimelineRss*(profile: Profile; cfg: Config; multi=false): string =
#proc renderTimelineRss*(profile: Profile; cfg: Config; tab, param: string; multi=false): string =
#let urlPrefix = getUrlPrefix(cfg)
#var atomLink = &"{urlPrefix}/{profile.user.username}"
#var link = &"{urlPrefix}/{profile.user.username}"
#if tab != "":
# atomLink &= "/" & tab
# link &= "/" & tab
#end if
#atomLink &= "/rss"
#if param != "":
# let escParam = xmltree.escape(param)
# atomLink &= "?" & escParam
# link &= "?" & escParam
#end if
#result = ""
#let handle = (if multi: "" else: "@") & profile.user.username
#var title = profile.user.fullname
Expand All @@ -93,9 +105,9 @@ Twitter feed for: ${desc}. Generated by ${cfg.hostname}
<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/" version="2.0">
<channel>
<atom:link href="${urlPrefix}/${profile.user.username}/rss" rel="self" type="application/rss+xml" />
<atom:link href="${atomLink}" rel="self" type="application/rss+xml" />
<title>${title}</title>
<link>${urlPrefix}/${profile.user.username}</link>
<link>${link}</link>
<description>${getDescription(handle, cfg)}</description>
<language>en-us</language>
<ttl>40</ttl>
Expand Down Expand Up @@ -131,15 +143,16 @@ ${renderRssTweets(tweets, cfg)}
#end proc
#
#proc renderSearchRss*(tweets: seq[Tweets]; name, param: string; cfg: Config): string =
#let link = &"{getUrlPrefix(cfg)}/search"
#let urlPrefix = getUrlPrefix(cfg)
#let escName = xmltree.escape(name)
#let escParam = xmltree.escape(param)
#result = ""
<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/" version="2.0">
<channel>
<atom:link href="${link}" rel="self" type="application/rss+xml" />
<atom:link href="${urlPrefix}/search/rss?${escParam}" rel="self" type="application/rss+xml" />
<title>Search results for "${escName}"</title>
<link>${link}</link>
<link>${urlPrefix}/search?${escParam}</link>
<description>${getDescription(&"Search \"{escName}\"", cfg)}</description>
<language>en-us</language>
<ttl>40</ttl>
Expand Down

0 comments on commit 75316a5

Please sign in to comment.