×
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 Test: Difference between revisions

No edit summary
No edit summary
 
(51 intermediate revisions by the same user not shown)
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 posts = {}
local posts = {}
posts["description"] = {}
local links = {}
posts["pubDate"] = {}
local searchTerms = {}
posts["link"] = {}
local maxLength = tonumber(args.maxlength)
local rss_table = {}


-- 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 {
local rss = mw.ext.externaldata.getWebData {
     url = 'https://bsky.app/profile/did:plc:ve2p3lz33ivtyikqztvsgtx3/rss'
     url = args.url
   , data = {pubDate = 'pubDate', description = 'description', link= 'link'}
   , data = {pubDate = 'pubDate', description = 'description', link= 'link'}
   , format = 'xml'
   , 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
for k, v in ipairs(rss) do
if string.find(v["description"],"NOISZ") and v["description"] and v["pubDate"] and v["link"] then
if v["description"] and v["pubDate"] and v["link"] and k - 1 <= maxLength then
local new_post = {}
links[v["link"]] = nil
new_post["description"] = v["description"]
 
new_post["pubDate"] = v["pubDate"]
-- 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.
new_post["link"] = v["link"]
 
table.insert(posts,new_post)
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
end
end


for k, v in ipairs(posts) do
 
frame:expandTemplate{title = 'Bluesky RSS Feed Row', args = {description = v["description"], pubDate = v["pubDate"], link=v["link"]}}
-- Table.concat to move it from Lua table form to a form the wikitext can use.
end
return table.concat(posts,""), #rss, maxLength
 


end
end


return p
return p

Latest revision as of 18:52, 6 June 2025

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


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

function p.main(frame)

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

-- 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,""), #rss, maxLength


end

return p