Module:Effective protection level: Difference between revisions
Jump to navigation
Jump to search
Sync from sandbox |
Use new protection retrieval, and prepare for when titleblacklist works here |
||
Line 20: | Line 20: | ||
return 'sysop' | return 'sysop' | ||
else | else | ||
local level = | local level = title.protectionLevels[action] and title.protectionLevels[action][1] | ||
if level == 'sysop' then | if level == 'sysop' then | ||
return 'sysop' | return 'sysop' | ||
elseif frame:callParserFunction('CASCADINGSOURCES', pagename) ~= '' then -- used by a cascading-protected page | elseif frame:callParserFunction('CASCADINGSOURCES', pagename) ~= '' then -- used by a cascading-protected page | ||
return 'sysop' | return 'sysop' | ||
elseif | elseif level == 'templateeditor' then | ||
return ' | return 'templateeditor' | ||
elseif | elseif action == 'move' then | ||
--[[local blacklistentry = mw.ext.TitleBlacklist.test('edit', pagename) -- Testing action edit is correct, since this is for the source page. The target page name gets tested with action move. | |||
if blacklistentry and not blacklistentry.params.autoconfirmed then | |||
return 'accountcreator' | |||
else]]if title.namespace == 6 then | |||
return 'filemover' | |||
return ' | else | ||
return 'autoconfirmed' | |||
end | |||
else | else | ||
return '*' | --[[local blacklistentry = mw.ext.TitleBlacklist.test(action, pagename) | ||
if blacklistentry then | |||
return blacklistentry.params.autoconfirmed and 'autoconfirmed' or 'accountcreator' | |||
else]]if level then | |||
return level | |||
elseif action == 'upload' then | |||
return 'autoconfirmed' | |||
elseif action == 'create' and title.namespace % 2 == 0 and title.namespace ~= 118 then -- You need to be registered, but not autoconfirmed, to create non-talk pages other than drafts | |||
return 'user' | |||
else | |||
return '*' | |||
end | |||
end | end | ||
end | end |
Revision as of 19:43, 30 January 2014
Documentation for this module may be created at Module:Effective protection level/doc
local p = {}
-- Returns the permission required to perform a given action on a given title.
-- If no title is specified, the title of the page being displayed is used.
function p.main(action, pagename)
local frame = mw.getCurrentFrame()
local title
if type(pagename) == 'table' then
title = pagename
pagename = title.prefixedText
else
title = mw.title.new(pagename) or mw.title.getCurrentTitle()
end
if action ~= 'edit' and action ~= 'move' and action ~= 'create' and action ~= 'upload' then
error( 'First parameter must be one of edit, move, create, upload', 2 )
end
if title.namespace == 8 then -- MediaWiki namespace
return 'sysop'
elseif title.namespace == 2 and ( mw.ustring.find( pagename, '/.*%.js$') or mw.ustring.find( pagename, '/.*%.css$') ) then -- user .js or .css page
return 'sysop'
else
local level = title.protectionLevels[action] and title.protectionLevels[action][1]
if level == 'sysop' then
return 'sysop'
elseif frame:callParserFunction('CASCADINGSOURCES', pagename) ~= '' then -- used by a cascading-protected page
return 'sysop'
elseif level == 'templateeditor' then
return 'templateeditor'
elseif action == 'move' then
--[[local blacklistentry = mw.ext.TitleBlacklist.test('edit', pagename) -- Testing action edit is correct, since this is for the source page. The target page name gets tested with action move.
if blacklistentry and not blacklistentry.params.autoconfirmed then
return 'accountcreator'
else]]if title.namespace == 6 then
return 'filemover'
else
return 'autoconfirmed'
end
else
--[[local blacklistentry = mw.ext.TitleBlacklist.test(action, pagename)
if blacklistentry then
return blacklistentry.params.autoconfirmed and 'autoconfirmed' or 'accountcreator'
else]]if level then
return level
elseif action == 'upload' then
return 'autoconfirmed'
elseif action == 'create' and title.namespace % 2 == 0 and title.namespace ~= 118 then -- You need to be registered, but not autoconfirmed, to create non-talk pages other than drafts
return 'user'
else
return '*'
end
end
end
end
-- Make this usable from wikitext rather than just other lua modules
function p.p(frame)
local parent = frame:getParent()
return p.main(parent.args.action or parent.args[1], parent.args.title or parent.args[2])
end
return p