Module:Bluesky RSS Feed: Difference between revisions
From NOISZ Wiki
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 17: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