Module:Effective protection level: Difference between revisions

From Kerbal Powers Wiki
Jump to navigation Jump to search
(bring in changes from sandbox)
m (1 revision imported)
 
Line 13: Line 13:
 
end
 
end
 
pagename = title.prefixedText
 
pagename = title.prefixedText
if action == 'autoreview' then
+
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 )
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
 
end
 
if title.namespace == 8 then -- MediaWiki namespace
 
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
+
if title.contentModel == 'javascript' or title.contentModel == 'css' then -- site JS or CSS page
 
return 'interfaceadmin'
 
return 'interfaceadmin'
 
else -- any non-JS/CSS MediaWiki page
 
else -- any non-JS/CSS MediaWiki page
Line 38: Line 28:
 
return 'sysop'
 
return 'sysop'
 
end
 
end
end
 
if action == 'undelete' then
 
return 'sysop'
 
 
end
 
end
 
local level = title.protectionLevels[action] and title.protectionLevels[action][1]
 
local level = title.protectionLevels[action] and title.protectionLevels[action][1]
Line 47: Line 34:
 
elseif 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
 
return 'templateeditor'
 
 
elseif action == 'move' then
 
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.
 
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 'templateeditor'
+
return 'sysop'
 
elseif title.namespace == 6 then
 
elseif title.namespace == 6 then
return 'filemover'
+
return 'sysop'
elseif level == 'extendedconfirmed' then
 
return 'extendedconfirmed'
 
 
else
 
else
 
return 'autoconfirmed'
 
return 'autoconfirmed'
Line 64: Line 47:
 
if blacklistentry then
 
if blacklistentry then
 
if not blacklistentry.params.autoconfirmed then
 
if not blacklistentry.params.autoconfirmed then
return 'templateeditor'
+
return 'sysop'
elseif level == 'extendedconfirmed' then
 
return 'extendedconfirmed'
 
 
else
 
else
 
return 'autoconfirmed'
 
return 'autoconfirmed'
Line 75: Line 56:
 
return level
 
return level
 
elseif action == 'upload' then
 
elseif action == 'upload' then
return 'autoconfirmed'
+
return 'uploader'
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
 
else
 
return '*'
 
return '*'

Latest revision as of 21:39, 28 February 2021

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 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 ~= '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
		if 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
	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 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 'sysop'
		elseif title.namespace == 6 then
			return 'sysop'
		else
			return 'autoconfirmed'
		end
	end
	local blacklistentry = mw.ext.TitleBlacklist.test(action, pagename)
	if blacklistentry then
		if not blacklistentry.params.autoconfirmed then
			return 'sysop'
		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 'uploader'
	else
		return '*'
	end
end

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

return p