RiceEmpress (talk | contribs) No edit summary Tag: Manual revert |
RiceEmpress (talk | contribs) 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 | ||
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 | |||
-- | -- 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 | 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 | ||
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