Module:Bluesky RSS Feed

From NOISZ Wiki
Revision as of 16:34, 6 June 2025 by RiceEmpress (talk | contribs) (Undo revision 4214 by RiceEmpress (talk))

This module is a custom-designed RSS feed, designed to process a Bluesky RSS feed and output it as a template. Up to three search keywords can be input - OR rather than AND - to find posts that mention any of the keywords. A Bluesky RSS feed can be found by going to any user's page, and typing /rss at the end of the URL before hitting enter.

Usage

{{Template:Bluesky RSS Feed
|url= Bluesky RSS feed URL
|term1= Optional search term
|term2= Optional search term
|term3= Optional search term
}}

Example

{{Template:Bluesky RSS Feed
|url=https://bsky.app/profile/did:plc:ve2p3lz33ivtyikqztvsgtx3/rss
|term1=#NOISZ
}}

Will yield:

22 Dec 2025 04:55 +0000
An update has been released for NOISZ reV (Steam) and reCG (Switch). After completing NOISZ FINAL pt. 1, a new option will become available under Story on the title screen.

This code can't be used yet, but the time is approaching... #NOISZ

20 Dec 2025 05:02 +0000
Every part of the original NOISZ story is on sale at its lowest price yet! The base game is now a whopping 55% off??

Get ready for NOISZ FINAL pt.2 by playing through Ignition and re:||VERSE now! #NOISZ steam.noiszgame.com https://steam.noiszgame.com/

21 Nov 2025 20:00 +0000
game of the day in BRITAIN (also a lot of other places but it's the first time for the UK) #NOISZ_SL https://apps.apple.com/gb/story/id1610061994




local capiunto = require 'capiunto'
local p = {}
function p.main(frame)

local args = frame:getParent().args
local posts = {}
local searchTerms = {}

-- These are the search terms as defined in the template.
if args.term1 or args.term2 or args.term3 then
	searchTerms[1] = args.term1
	searchTerms[2] = args.term2
	searchTerms[3] = args.term3
else 
-- If no search terms, then the search terms array is left blank so it'll match everything.
	searchTerms = {""}
end

-- We use externaldata.getWebDate to obtain XML format data from the RSS feed at the URL defined by the user.
local rss = mw.ext.externaldata.getWebData {
    url = args.url
  , data = {pubDate = 'pubDate', description = 'description', link= 'link'}
  , format = 'xml'
}

-- We iterate over every post found in the RSS feed, in chronological order - hence ipairs.
for k, v in ipairs(rss) do
-- We need description, publish date AND link to know that it's a post. Additionally, k has to be more than one as the very first post to pop up in an RSS feed is the user bio which is not an actual post.
	if v["description"] and v["pubDate"] and v["link"] and k > 1 then
-- Search over every search term in the search terms to make sure a post contains that term.
		for a, b in pairs(searchTerms) do
			if string.find(v["description"],b) then
-- We bundle up the information into template form via the frame:expandTemplate method - the "Bluesky RSS Feed Row" template, to be precise - and put it into an incremental table which will later be expanded in full.
				table.insert(posts, frame:expandTemplate{title = 'Bluesky RSS Feed Row', args = {description = v["description"], pubDate = v["pubDate"], link=v["link"]}})
			end	
		end
	end
end

-- Table.concat to move it from Lua table form to a form the wikitext can use.
return table.concat(posts,"")


end

return p