Modul:Effective protection level

Documentation icon Moduldokumentation

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: reviewer or autoconfirmed
  • The page being in the MediaWiki namespace: sysop
  • The page being a JavaScript or CSS subpage in userspace: sysop
  • The page being protected: sysop, templateeditor, 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.

Brug

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:

local effectiveProtectionLevel = 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", 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.

Fra wikitekst

The parameters are the same as when it is called directly.

{{#invoke:Effective protection level|action|title}}

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 titleif type(pagename) == 'table' and pagename.prefixedText thentitle = pagenameelseif pagename thentitle = mw.title.new(pagename)elsetitle = mw.title.getCurrentTitle()endpagename = title.prefixedTextif action == 'autoreview' thenlocal level = mw.ext.FlaggedRevs.getStabilitySettings(title)level = level and level.autoreviewif level == 'review' thenreturn 'reviewer'elseif level ~= '' thenreturn levelelsereturn nil -- 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 reviewendelseif action ~= 'edit' and action ~= 'move' and action ~= 'create' and action ~= 'upload' and action ~= 'undelete' thenerror( 'First parameter must be one of edit, move, create, upload, undelete, autoreview', 2 )endif title.namespace == 8 then -- MediaWiki namespaceif title.text:sub(-3) == '.js' or title.text:sub(-4) == '.css' or title.contentModel == 'javascript' or title.contentModel == 'css' then -- site JS or CSS pagereturn 'interfaceadmin'else -- any non-JS/CSS MediaWiki pagereturn 'sysop'endelseif title.namespace == 2 and title.isSubpage thenif title.contentModel == 'javascript' or title.contentModel == 'css' then -- user JS or CSS pagereturn 'interfaceadmin'elseif title.contentModel == 'json' then -- user JSON pagereturn 'sysop'endendif action == 'undelete' thenreturn 'sysop'endlocal level = title.protectionLevels[action] and title.protectionLevels[action][1]if level == 'sysop' or level == 'editprotected' thenreturn 'sysop'elseif title.cascadingProtection.restrictions[action] and title.cascadingProtection.restrictions[action][1] then -- used by a cascading-protected pagereturn 'sysop'elseif level == 'templateeditor' thenreturn 'templateeditor'elseif action == 'move' thenlocal 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 thenreturn 'templateeditor'elseif title.namespace == 6 thenreturn 'filemover'elseif level == 'extendedconfirmed' thenreturn 'extendedconfirmed'elsereturn 'autoconfirmed'endendlocal blacklistentry = mw.ext.TitleBlacklist.test(action, pagename)if blacklistentry thenif not blacklistentry.params.autoconfirmed thenreturn 'templateeditor'elseif level == 'extendedconfirmed' thenreturn 'extendedconfirmed'elsereturn 'autoconfirmed'endelseif level == 'editsemiprotected' then -- create-semiprotected pages return this for some reasonreturn 'autoconfirmed'elseif level thenreturn levelelseif action == 'upload' thenreturn '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 draftsif title.namespace == 0 thenreturn 'autoconfirmed' -- Per [[WP:ACPERM]], you need to be autoconfirmed to create pages in mainspaceendreturn 'user'elsereturn '*'endendsetmetatable(p, { __index = function(t, k)return function(frame)return t._main(k, frame.args[1])endend })return p