Module:Effective protection level
This module issubject to page protection.It is ahighly visible modulein use by a very large number of pages, or issubstitutedvery frequently. Because vandalism or mistakes would affect many pages, and even trivial editing might cause substantial load on the servers, it isprotectedfrom editing. |
This Lua module is used in system messages,and onapproximately 61,000 pages. Changes to it can cause immediate changes to the Wikipedia user interface. To avoid major disruption, any changes should be tested in the module's/sandboxor/testcasessubpages, or in your ownmodule sandbox.The tested changes can be added to this page in a single edit. Please discuss changes on thetalk pagebefore implementing them. |
This module provides a way to retrieve the group required to perform a given action on a page. It currently tests the following criteria:
- The page being pending-changes protected: autoconfirmed
- The page being a JavaScript or CSS subpage in userspace, or in the MediaWiki namespace: interfaceadmin
- The page being in the MediaWiki namespace: sysop
- The page being a JSON subpage in userspace: sysop
- The page being protected: sysop, templateeditor, extendedconfirmed, or autoconfirmed
- The page being used in a cascading-protected page: sysop
- The page's title matching the titleblacklist: templateeditor or autoconfirmed
- A file being moved: filemover
- A page being moved or a file being uploaded: autoconfirmed
- A non-Draft non-talk page being created: user
- Anything else: *
Note that if a template-protected file is moved, both filemover and templateeditor are required, but this will return only templateeditor. This is not likely to be changed any time soon, since template protection currently shouldn't be used on files.
Usage
Warning:This module will use up to 4 expensive parser function calls each time it is ran. It should only be used if the exact effective protection level is necessary. Otherwise, consider using title.protectionLevels instead.
From other modules
To load this module:
localeffectiveProtectionLevel=require('Module:Effective protection level')._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", "undelete", 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.
From wikitext
The parameters are the same as when it is called directly.
{{#invoke:Effective protection level|action|title}}
See also
localp={}
-- 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.
functionp._main(action,pagename)
localtitle
iftype(pagename)=='table'andpagename.prefixedTextthen
title=pagename
elseifpagenamethen
title=mw.title.new(pagename)
else
title=mw.title.getCurrentTitle()
end
pagename=title.prefixedText
ifaction=='autoreview'then
locallevel=mw.ext.FlaggedRevs.getStabilitySettings(title)
level=levelandlevel.autoreview
iflevel=='review'then
return'reviewer'
elseiflevel~=''then
returnlevel
else
returnnil-- not '*'. a page not being PC-protected is distinct from it being PC-protected with anyone able to review. also not '', as that would mean PC-protected but nobody can review
end
elseifaction~='edit'andaction~='move'andaction~='create'andaction~='upload'andaction~='undelete'then
error('First parameter must be one of edit, move, create, upload, undelete, autoreview',2)
end
iftitle.namespace==8then-- MediaWiki namespace
iftitle.text:sub(-3)=='.js'ortitle.text:sub(-4)=='.css'ortitle.contentModel=='javascript'ortitle.contentModel=='css'then-- site JS or CSS page
return'interfaceadmin'
else-- any non-JS/CSS MediaWiki page
return'sysop'
end
elseiftitle.namespace==2andtitle.isSubpagethen
iftitle.contentModel=='javascript'ortitle.contentModel=='css'then-- user JS or CSS page
return'interfaceadmin'
elseiftitle.contentModel=='json'then-- user JSON page
return'sysop'
end
end
ifaction=='undelete'then
return'sysop'
end
locallevel=title.protectionLevels[action]andtitle.protectionLevels[action][1]
iflevel=='sysop'orlevel=='editprotected'then
return'sysop'
elseiftitle.cascadingProtection.restrictions[action]andtitle.cascadingProtection.restrictions[action][1]then-- used by a cascading-protected page
return'sysop'
elseiflevel=='templateeditor'then
return'templateeditor'
elseifaction=='move'then
localblacklistentry=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.
ifblacklistentryandnotblacklistentry.params.autoconfirmedthen
return'templateeditor'
elseiftitle.namespace==6then
return'filemover'
elseiflevel=='extendedconfirmed'then
return'extendedconfirmed'
else
return'autoconfirmed'
end
end
localblacklistentry=mw.ext.TitleBlacklist.test(action,pagename)
ifblacklistentrythen
ifnotblacklistentry.params.autoconfirmedthen
return'templateeditor'
elseiflevel=='extendedconfirmed'then
return'extendedconfirmed'
else
return'autoconfirmed'
end
elseiflevel=='editsemiprotected'then-- create-semiprotected pages return this for some reason
return'autoconfirmed'
elseiflevelthen
returnlevel
elseifaction=='upload'then
return'autoconfirmed'
elseifaction=='create'andtitle.namespace%2==0andtitle.namespace~=118then-- You need to be registered, but not autoconfirmed, to create non-talk pages other than drafts
iftitle.namespace==0then
return'autoconfirmed'-- Per [[WP:ACPERM]], you need to be autoconfirmed to create pages in mainspace
end
return'user'
else
return'*'
end
end
setmetatable(p,{__index=function(t,k)
returnfunction(frame)
returnt._main(k,frame.args[1])
end
end})
returnp