RiceEmpress (talk | contribs) No edit summary |
RiceEmpress (talk | contribs) No edit summary |
||
Line 10: | Line 10: | ||
local searchTerms = {} | local searchTerms = {} | ||
if args. | if args.maxlength then | ||
local maxLength = tonumber(args.maxlength) | local maxLength = tonumber(args.maxlength) | ||
else | else | ||
local maxLength = 30 | local maxLength = 30 | ||
end | end | ||
-- 30 is the default | |||
-- These are the search terms as defined in the template. | -- These are the search terms as defined in the template. | ||
Line 56: | Line 56: | ||
-- 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. | ||
return table.concat(posts,"") | return table.concat(posts,"") | ||
Revision as of 18:58, 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 = {} if args.maxlength then local maxLength = tonumber(args.maxlength) else local maxLength = 30 end -- 30 is the default -- 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. -- It's k - 1 to account for the first post being the bsky profile's about. for k, v in ipairs(rss) do if v["description"] and v["pubDate"] and v["link"] and k - 1 <= maxLength 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 and k > 1 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