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