×
Create a new article
Write your page title here:
We currently have 6 articles on NOISZ Wiki. Type your article name above or click on one of the titles below and start writing!



NOISZ Wiki
6Articles

Module:Bluesky RSS Feed: Difference between revisions

No edit summary
Tag: Manual revert
No edit summary
Line 2: Line 2:
local capiunto = require 'capiunto'
local capiunto = require 'capiunto'
local p = {}
local p = {}
function p.main(frame)
function p.main(frame)


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


Line 13: Line 15:
searchTerms[2] = args.term2
searchTerms[2] = args.term2
searchTerms[3] = args.term3
searchTerms[3] = args.term3
-- If no search terms, then the search terms array is left blank so it'll match everything.
else  
else  
-- If no search terms, then the search terms array is left blank so it'll match everything.
searchTerms = {""}
searchTerms = {""}
end
end
Line 25: Line 27:
}
}


-- We iterate over every post found in the RSS feed, in chronological order - hence ipairs.
-- We iterate over every post found in the RSS feed, in chronological order - hence ipairs. We need description, publish date AND link to know that it's a post. Additionally, k has to be more than 1 as the very first post to pop up in an RSS feed is the user bio which is not an actual post. The "links" array is a directory of links that have been processed; if it's already been processed, then it won't be added again. This helps for if there's more than one search term.
 
for k, v in ipairs(rss) do
for k, v in ipairs(rss) do
if v["description"] and v["pubDate"] and v["link"] then
links[v["link"]] = nil


-- We need description, publish date AND link to know that it's a post. Additionally, k has to be more than 1 as the very first post to pop up in an RSS feed is the user bio which is not an actual post.
-- Search over every search term in the search terms to make sure a post contains that term. If so, 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.


if v["description"] and v["pubDate"] and v["link"] and k > 3 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
for a, b in pairs(searchTerms) do
if string.find(v["description"],b) then
if string.find(v["description"],b) and links[v["link"]] ~= true 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.
links[v["link"]] = true
table.insert(posts, frame:expandTemplate{title = 'Bluesky RSS Feed Row', args = {description = v["description"], pubDate = v["pubDate"], link=v["link"]}})
table.insert(posts, frame:expandTemplate{title = 'Bluesky RSS Feed Row', args = {description = v["description"], pubDate = v["pubDate"], link=v["link"]}})
end
end
Line 40: Line 43:
end
end
end
end


-- Table.concat to move it from Lua table form to a form the wikitext can use.
-- Table.concat to move it from Lua table form to a form the wikitext can use.

Revision as of 18:18, 6 June 2025

Documentation for this module may be created at Module:Bluesky RSS Feed/doc


local capiunto = require 'capiunto'
local p = {}

function p.main(frame)

local args = frame:getParent().args
local posts = {}
local links = {}
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
-- If no search terms, then the search terms array is left blank so it'll match everything.
else 
	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. We need description, publish date AND link to know that it's a post. Additionally, k has to be more than 1 as the very first post to pop up in an RSS feed is the user bio which is not an actual post. The "links" array is a directory of links that have been processed; if it's already been processed, then it won't be added again. This helps for if there's more than one search term.

for k, v in ipairs(rss) do
	if v["description"] and v["pubDate"] and v["link"] then
		links[v["link"]] = nil

-- Search over every search term in the search terms to make sure a post contains that term. If so, 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.

		for a, b in pairs(searchTerms) do
			if string.find(v["description"],b) and links[v["link"]] ~= true then
				links[v["link"]] = true
				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