被永久保护的模块

“Module:Effective protection level”的版本间的差异

维基百科,自由的百科全书
跳到导航 跳到搜索
(https://en.wikipedia.org/w/index.php?title=Module:Effective_protection_level&oldid=641310538)
 
第14行: 第14行:
 
pagename = title.prefixedText
 
pagename = title.prefixedText
 
if action == 'autoreview' then
 
if action == 'autoreview' then
  +
local level = mw.ext.FlaggedRevs.getStabilitySettings(title)
local level = mw.getCurrentFrame():callParserFunction('PENDINGCHANGELEVEL', pagename)
 
  +
level = level and level.autoreview
 
if level == 'review' then
 
if level == 'review' then
 
return 'reviewer'
 
return 'reviewer'
第43行: 第44行:
 
elseif title.namespace == 6 then
 
elseif title.namespace == 6 then
 
return 'filemover'
 
return 'filemover'
  +
elseif level == 'extendedconfirmed' then
  +
return 'extendedconfirmed'
 
else
 
else
 
return 'autoconfirmed'
 
return 'autoconfirmed'
第49行: 第52行:
 
local blacklistentry = mw.ext.TitleBlacklist.test(action, pagename)
 
local blacklistentry = mw.ext.TitleBlacklist.test(action, pagename)
 
if blacklistentry then
 
if blacklistentry then
return blacklistentry.params.autoconfirmed and 'autoconfirmed' or 'templateeditor'
+
if not blacklistentry.params.autoconfirmed then
  +
return 'templateeditor'
  +
elseif level == 'extendedconfirmed' then
  +
return 'extendedconfirmed'
  +
else
  +
return 'autoconfirmed'
  +
end
 
elseif level == 'editsemiprotected' then -- create-semiprotected pages return this for some reason
 
elseif level == 'editsemiprotected' then -- create-semiprotected pages return this for some reason
 
return 'autoconfirmed'
 
return 'autoconfirmed'

2017年1月19日 (四) 06:46的版本

文档图示 模块文档[查看] [编辑] [历史] [清除缓存]

This module provides a way to retrieve the group required to perform a given action on a page. It currently tests the following criteria:

  • 在MediaWiki命名空間:sysop
  • 全站/使用者的JavaScript/CSS頁:interfaceadmin
  • 全站/使用者的JSON頁:sysop
  • 被保護頁面:sysop、templateeditor或autoconfirmed
  • 被連鎖保護頁面:sysop
  • 符合標題黑名單:sysop或autoconfirmed
  • 移動檔案:filemover
  • 移動頁面或上傳檔案:autoconfirmed
  • 其餘:*

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:

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.

From wikitext

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

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

See also

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 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
		local level = mw.ext.FlaggedRevs.getStabilitySettings(title)
		level = level and level.autoreview
		if level == 'review' then
			return 'reviewer'
		elseif level ~= '' then
			return level
		else
			return 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 review
		end
	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
	if title.namespace == 8 then -- MediaWiki namespace
		return 'sysop'
	elseif title.namespace == 2 and title.isSubpage and ( title.contentModel == 'javascript' or title.contentModel == 'css' ) then -- user JS or CSS page
		return 'sysop'
	end
	local level = title.protectionLevels[action] and title.protectionLevels[action][1]
	if level == 'sysop' or level == 'editprotected' then
		return 'sysop'
	elseif title.cascadingProtection.restrictions[action] and title.cascadingProtection.restrictions[action][1] 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 'templateeditor'
		elseif title.namespace == 6 then
			return 'filemover'
		elseif level == 'extendedconfirmed' then
			return 'extendedconfirmed'
		else
			return 'autoconfirmed'
		end
	end
	local blacklistentry = mw.ext.TitleBlacklist.test(action, pagename)
	if blacklistentry then
		if not blacklistentry.params.autoconfirmed then
			return 'templateeditor'
		elseif level == 'extendedconfirmed' then
			return 'extendedconfirmed'
		else
			return 'autoconfirmed'
		end
	elseif level == 'editsemiprotected' then -- create-semiprotected pages return this for some reason
		return 'autoconfirmed'
	elseif 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

setmetatable(p, { __index = function(t, k)
	return function(frame)
		return t._main(k, frame.args[1])
	end
end })

return p