Difference between revisions of "Module:Effective protection expiry"
(don't error if the page isn't under PC) |
m (1 revision imported) |
||
Line 14: | Line 14: | ||
pagename = title.prefixedText | pagename = title.prefixedText | ||
if action == 'autoreview' then | if action == 'autoreview' then | ||
− | + | return 'unknown' | |
− | return | ||
elseif action ~= 'edit' and action ~= 'move' and action ~= 'create' and action ~= 'upload' then | elseif action ~= 'edit' and action ~= 'move' and action ~= 'create' and action ~= 'upload' then | ||
error( 'First parameter must be one of edit, move, create, upload, autoreview', 2 ) | error( 'First parameter must be one of edit, move, create, upload, autoreview', 2 ) | ||
Line 25: | Line 24: | ||
return 'unknown' | return 'unknown' | ||
else | else | ||
− | local year, month, | + | local year = mw.ustring.sub( rawExpiry, 1, 4 ) |
− | + | local month = mw.ustring.sub( rawExpiry, 5, 6 ) | |
− | ) | + | local day = mw.ustring.sub( rawExpiry, 7, 8 ) |
− | + | return year .. '-' .. month .. '-' .. day | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
end | end | ||
end | end |
Revision as of 17:08, 31 January 2018
This module is subject to page protection. It is a highly visible module in use by a very large number of pages, or is substituted very frequently. Because vandalism or mistakes would affect many pages, and even trivial editing might cause substantial load on the servers, it is protected from editing. |
This module provides a way to retrieve the expiry of a restriction over a given action on a page.
Usage
This module will use up to 1 expensive parser function call each time it is ran. It will not use any if Module:Effective protection level was already called.
From other modules
To load this module:
local effectiveProtectionExpiry = require('Module:Effective protection expiry')._main
The function accepts two parameters. The first is a string containing the action to check, which must be one of "edit", "create", "move", "upload", or "autoreview". The second is optional, and can either be the name of the page to check, or a title returned from the mw.title functions. If the second parameter is omitted, the page being displayed is the one checked against. The return value is a string containing the name of the group required to perform the given action.
It is not yet possible to retrieve the expiry for pending changes protection ("autoreview" action), so it returns 'unknown' in that case.
Note that if the page is not protected for the requested action, this will return 'infinity'. You need to check separately with Module:Effective protection level.
From wikitext
The parameters are the same as when it is called directly.
{{#invoke:Effective protection expiry|action|title}}
See also
local p = {} -- Returns the expiry of a restriction of an action on a given title, or unknown if it cannot be known. -- If no title is specified, the title of the page being displayed is used. function p._main(action, pagename) local title if type(pagename) == 'table' and pagename.prefixedText then title = pagename elseif pagename then title = mw.title.new(pagename) else title = mw.title.getCurrentTitle() end pagename = title.prefixedText if action == 'autoreview' then return 'unknown' elseif action ~= 'edit' and action ~= 'move' and action ~= 'create' and action ~= 'upload' then error( 'First parameter must be one of edit, move, create, upload, autoreview', 2 ) end local rawExpiry = mw.getCurrentFrame():callParserFunction('PROTECTIONEXPIRY', action, pagename) if rawExpiry == 'infinity' then return 'infinity' elseif rawExpiry == '' then return 'unknown' else local year = mw.ustring.sub( rawExpiry, 1, 4 ) local month = mw.ustring.sub( rawExpiry, 5, 6 ) local day = mw.ustring.sub( rawExpiry, 7, 8 ) return year .. '-' .. month .. '-' .. day end end setmetatable(p, { __index = function(t, k) return function(frame) return t._main(k, frame.args[1]) end end }) return p