Support max_position for RSS feeds
This commit is contained in:
		
							parent
							
								
									9f491eee70
								
							
						
					
					
						commit
						f3aa28709a
					
				|  | @ -8,15 +8,19 @@ import ../views/general | |||
| 
 | ||||
| include "../views/rss.nimf" | ||||
| 
 | ||||
| proc showRss*(name, hostname: string; query: Query): Future[string] {.async.} = | ||||
| proc showRss*(req: Request; hostname: string; query: Query): Future[(string, string)] {.async.} = | ||||
|   var profile: Profile | ||||
|   var timeline: Timeline | ||||
|   let names = getNames(name) | ||||
|   let | ||||
|     name = req.params.getOrDefault("name") | ||||
|     after = req.params.getOrDefault("max_position") | ||||
|     names = getNames(name) | ||||
| 
 | ||||
|   if names.len == 1: | ||||
|     (profile, timeline) = | ||||
|       await fetchSingleTimeline(names[0], "", getAgent(), query, media=false) | ||||
|       await fetchSingleTimeline(names[0], after, getAgent(), query, media=false) | ||||
|   else: | ||||
|     timeline = await fetchMultiTimeline(names, "", getAgent(), query, media=false) | ||||
|     timeline = await fetchMultiTimeline(names, after, getAgent(), query, media=false) | ||||
|     # this is kinda dumb | ||||
|     profile = Profile( | ||||
|       username: name, | ||||
|  | @ -25,12 +29,14 @@ proc showRss*(name, hostname: string; query: Query): Future[string] {.async.} = | |||
|     ) | ||||
| 
 | ||||
|   if timeline != nil: | ||||
|     return renderTimelineRss(timeline, profile, hostname, multi=(names.len > 1)) | ||||
|     let rss = renderTimelineRss(timeline, profile, hostname, multi=(names.len > 1)) | ||||
|     return (rss, timeline.minId) | ||||
| 
 | ||||
| template respRss*(rss: typed) = | ||||
| template respRss*(rss, minId) = | ||||
|   if rss.len == 0: | ||||
|     resp Http404, showError("User \"" & @"name" & "\" not found", cfg) | ||||
|   resp rss, "application/rss+xml;charset=utf-8" | ||||
|   let headers = {"Content-Type": "application/rss+xml;charset=utf-8", "Min-Id": minId} | ||||
|   resp Http200, headers, rss | ||||
| 
 | ||||
| proc createRssRouter*(cfg: Config) = | ||||
|   router rss: | ||||
|  | @ -42,26 +48,29 @@ proc createRssRouter*(cfg: Config) = | |||
|       if query.kind != tweets: | ||||
|         resp Http400, showError("Only Tweet searches are allowed for RSS feeds.", cfg) | ||||
| 
 | ||||
|       let tweets = await getSearch[Tweet](query, "", getAgent(), media=false) | ||||
|       respRss(renderSearchRss(tweets.content, query.text, genQueryUrl(query), cfg.hostname)) | ||||
|       let tweets = await getSearch[Tweet](query, @"max_position", getAgent(), media=false) | ||||
|       let rss = renderSearchRss(tweets.content, query.text, genQueryUrl(query), cfg.hostname) | ||||
|       respRss(rss, tweets.minId) | ||||
| 
 | ||||
|     get "/@name/rss": | ||||
|       cond '.' notin @"name" | ||||
|       respRss(await showRss(@"name", cfg.hostname, Query())) | ||||
|       let (rss, minId) = await showRss(request, cfg.hostname, Query()) | ||||
|       respRss(rss, minId) | ||||
| 
 | ||||
|     get "/@name/with_replies/rss": | ||||
|     get "/@name/@tab/rss": | ||||
|       cond '.' notin @"name" | ||||
|       respRss(await showRss(@"name", cfg.hostname, getReplyQuery(@"name"))) | ||||
|       let query = | ||||
|         case @"tab" | ||||
|         of "with_replies": getReplyQuery(@"name") | ||||
|         of "media": getMediaQuery(@"name") | ||||
|         of "search": initQuery(params(request), name=(@"name")) | ||||
|         else: Query() | ||||
| 
 | ||||
|     get "/@name/media/rss": | ||||
|       cond '.' notin @"name" | ||||
|       respRss(await showRss(@"name", cfg.hostname, getMediaQuery(@"name"))) | ||||
| 
 | ||||
|     get "/@name/search/rss": | ||||
|       cond '.' notin @"name" | ||||
|       respRss(await showRss(@"name", cfg.hostname, initQuery(params(request), name=(@"name")))) | ||||
|       let (rss, minId) = await showRss(request, cfg.hostname, query) | ||||
|       respRss(rss, minId) | ||||
| 
 | ||||
|     get "/@name/lists/@list/rss": | ||||
|       cond '.' notin @"name" | ||||
|       let list = await getListTimeline(@"name", @"list", "", getAgent(), media=false) | ||||
|       respRss(renderListRss(list.content, @"name", @"list", cfg.hostname)) | ||||
|       let list = await getListTimeline(@"name", @"list", @"max_position", getAgent(), media=false) | ||||
|       let rss = renderListRss(list.content, @"name", @"list", cfg.hostname) | ||||
|       respRss(rss, list.minId) | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue