|
|
(21 intermediate revisions by the same user not shown) |
Line 9: |
Line 9: |
| local links = {} | | local links = {} |
| local searchTerms = {} | | local searchTerms = {} |
| local maxLength = 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. | | -- We use externaldata.getWebDate to obtain XML format data from the RSS feed at the URL defined by the user. |
Line 28: |
Line 17: |
| } | | } |
|
| |
|
| -- 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.
| | return mw.dumpObject(rss) |
| | |
| for k, v in ipairs(rss) do
| |
| if v["description"] and v["pubDate"] and v["link"] and maxLength < #rss - 1 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
| |
|
| |
|
|
| |
|
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 = {}
-- 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'
}
return mw.dumpObject(rss)
end
return p