Modul:Effective protection level: Unterschied zwischen den Versionen

Permanently protected module
ZIM HilfeWiki - das Wiki
 
imported>Oetterer
 
(Eine dazwischenliegende Version von einem anderen Benutzer wird nicht angezeigt)
Zeile 1: Zeile 1:
 
local p = {}
 
local p = {}
local blacklistentry = nil
 
  
 
-- Returns the permission required to perform a given action on a given title.
 
-- Returns the permission required to perform a given action on a given title.
Zeile 15: Zeile 14:
 
pagename = title.prefixedText
 
pagename = title.prefixedText
 
if action == 'autoreview' then
 
if action == 'autoreview' then
local level = mw.getCurrentFrame():callParserFunction('PENDINGCHANGELEVEL', pagename)
+
local level = mw.ext.FlaggedRevs.getStabilitySettings(title)
 +
level = level and level.autoreview
 
if level == 'review' then
 
if level == 'review' then
 
return 'reviewer'
 
return 'reviewer'
Zeile 23: Zeile 23:
 
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
 
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
 
end
elseif action ~= 'edit' and action ~= 'move' and action ~= 'create' and action ~= 'upload' then
+
elseif action ~= 'edit' and action ~= 'move' and action ~= 'create' and action ~= 'upload' and action ~= 'undelete' then
error( 'First parameter must be one of edit, move, create, upload, autoreview', 2 )
+
error( 'First parameter must be one of edit, move, create, upload, undelete, autoreview', 2 )
 
end
 
end
 
if title.namespace == 8 then -- MediaWiki namespace
 
if title.namespace == 8 then -- MediaWiki namespace
return 'sysop'
+
if title.text:sub(-3) == '.js' or title.text:sub(-4) == '.css' or title.contentModel == 'javascript' or title.contentModel == 'css' then -- site JS or CSS page
elseif title.namespace == 2 and title.isSubpage and ( title.contentModel == 'javascript' or title.contentModel == 'css' ) then -- user JS or CSS page
+
return 'interfaceadmin'
 +
else -- any non-JS/CSS MediaWiki page
 +
return 'sysop'
 +
end
 +
elseif title.namespace == 2 and title.isSubpage then
 +
if title.contentModel == 'javascript' or title.contentModel == 'css' then -- user JS or CSS page
 +
return 'interfaceadmin'
 +
elseif title.contentModel == 'json' then -- user JSON page
 +
return 'sysop'
 +
end
 +
end
 +
if action == 'undelete' then
 
return 'sysop'
 
return 'sysop'
 
end
 
end
 
local level = title.protectionLevels[action] and title.protectionLevels[action][1]
 
local level = title.protectionLevels[action] and title.protectionLevels[action][1]
if level == 'sysop' then
+
local blacklistentry = { params = {} } -- this is a workaround, since Extension:TitleBlacklist is not installed
 +
if level == 'sysop' or level == 'editprotected' then
 
return 'sysop'
 
return 'sysop'
elseif title.cascadingProtection and title.cascadingProtection.restrictions[action] and title.cascadingProtection.restrictions[action][1] then -- used by a cascading-protected page
+
elseif title.cascadingProtection.restrictions[action] and title.cascadingProtection.restrictions[action][1] then -- used by a cascading-protected page
 
return 'sysop'
 
return 'sysop'
 
elseif level == 'templateeditor' then
 
elseif level == 'templateeditor' then
 
return 'templateeditor'
 
return 'templateeditor'
 
elseif action == 'move' then
 
elseif action == 'move' then
-- no TitleBlacklist extension, so comment out
+
--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.
-- 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
 
if blacklistentry and not blacklistentry.params.autoconfirmed then
return 'accountcreator'
+
return 'templateeditor'
 
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'
 
end
 
end
 
end
 
end
-- no TitleBlacklist extension, so comment out
+
--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 'accountcreator'
+
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
 
elseif level then
 
return level
 
return level
Zeile 64: Zeile 84:
 
end
 
end
  
-- unfortunately with REL1_23 setting of metatable doesn't seem to work.
 
-- more precisely: setting metatables works, but Scribunto strips them when the module is returned to the mw environment
 
-- you can thereby use metatables as long as you are within your module. but it gets lost at the final return :(
 
--[[
 
 
setmetatable(p, { __index = function(t, k)
 
setmetatable(p, { __index = function(t, k)
 
return function(frame)
 
return function(frame)
Zeile 73: Zeile 89:
 
end
 
end
 
end })
 
end })
--]]
 
 
-- we have to declare a function for each action manually. reason see line 65ff
 
function p.edit(frame)
 
return p._main('edit', frame.args[1])
 
end
 
 
function p.create(frame)
 
return p._main('create', frame.args[1])
 
end
 
 
function p.move(frame)
 
return p._main('move', frame.args[1])
 
end
 
 
function p.upload(frame)
 
return p._main('upload', frame.args[1])
 
end
 
 
function p.autoreview(frame)
 
return p._main('autoreview', frame.args[1])
 
end
 
  
 
return p
 
return p

Aktuelle Version vom 8. Oktober 2022, 08:48 Uhr

Documentation icon Module documentation

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: accountcreator 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[Quelltext bearbeiten]

From other modules[Quelltext bearbeiten]

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[Quelltext bearbeiten]

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 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' and action ~= 'undelete' then
		error( 'First parameter must be one of edit, move, create, upload, undelete, autoreview', 2 )
	end
	if title.namespace == 8 then -- MediaWiki namespace
		if title.text:sub(-3) == '.js' or title.text:sub(-4) == '.css' or title.contentModel == 'javascript' or title.contentModel == 'css' then -- site JS or CSS page
			return 'interfaceadmin'
		else -- any non-JS/CSS MediaWiki page
			return 'sysop'
		end
	elseif title.namespace == 2 and title.isSubpage then
		if title.contentModel == 'javascript' or title.contentModel == 'css' then -- user JS or CSS page
			return 'interfaceadmin'
		elseif title.contentModel == 'json' then -- user JSON page
			return 'sysop'
		end
	end
	if action == 'undelete' then
		return 'sysop'
	end
	local level = title.protectionLevels[action] and title.protectionLevels[action][1]
	local blacklistentry = { params = {} }	-- this is a workaround, since Extension:TitleBlacklist is not installed
	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
Cookies helfen uns bei der Bereitstellung des ZIM HilfeWikis. Bei der Nutzung vom ZIM HilfeWiki werden die in der Datenschutzerklärung beschriebenen Cookies gespeichert.