View text source at Wikipedia
PermClerk
Bot clerking at requests for permissions.
To disable, set /Run to anything other than true
(link)
Errors are logged at /Error log
No errors! Report generated at 17:00, 23 January 2025 (UTC)
All requests are archived at Wikipedia:Requests for permissions/Archive as approved or denied. This is done as a historical reference, namely so that admins can review previously declined requests.
N hours after the last comment was made on a request (as specified in the config), the discussion is removed from that page and an entry containing a PermaLink to the discussion is added to the archives, noting the user and the permission.
{{User:MusikBot/override}} can be used to override any other {{done}} or {{not done}} templates, and make the bot ignore the user's rights. For example, you may use {{done}}{{User:MusikBot/override|d}}
when a user has requested revocation of a user right (marking as done and forcing to archive as done).
You can also force immediate archiving of a request with {{User:MusikBot/archivenow}} ~~~~
Removes extraneous headers and repairs malformed requests. This functionality is not configurable, but it can be turned off entirely.
Updates {{WP:PERM/Backlog}} based on configurable conditions. At the time of writing, this is set to 3+ requests or any request over 7 days old.
Marks requests as {{already done}} if the user already has the permission they are requesting. Only runs on WP:PERM/C and WP:PERM/AWB. For other PERM pages, the bot will wait N hours after the request (see config) has been made before concluding the admin forgot to mark the request as {{done}}.
Searches the declined archives and comments if the user has had any relevant requests recently declined, with permalinks to the relevant page. Does not run on WP:PERM/C. The number of days back the bot should search is configurable.
Comments if the user does not meet the configurable qualifications for that permission. The data is kept up-to-date until the request is responded to.
If the user does not meet one of the prerequisites, the bot will comment with the relevant data. For instance, if 200 mainspace edits are required, the bot will comment "this user has made X edits to the mainspace". If multiple requirements are not met, a single humanized sentence is constructed, as opposed to making multiple comments.
These prerequisites do not necessarily represent a hard requirement, and the comments made by the bot are purely for convenience.
Comments if the user has had the requested permission revoked in the past N days, as specified in the config.
Functionality can be tweaked at /config. Configuration data is in the form of JSON.
IMPORTANT:
"option": true
instead of option: true
."option"
instead of 'option'
.true
or false
with no quotations around it.pages
hash add a new key/value pair for the new permission. The key is the subpage at WP:PERM and the value is the name of the user group as specified in the Wikipedia config.prerequisites_config
hash (see below).The bot should now process the new page as configured. For reference, see this example of adding the New page reviewer permission.
The documentation for each configuration hash is as follows:
Specifies which PermClerk tasks the bot should run
Name | Description |
---|---|
admin_backlog | Updates {{WP:PERM/Backlog}} based on configurable conditions (3+ requests or any request over 7 days old) |
archive | Archives requests that have been responded to and where the discussion is over N hours old, as specified by the offset parameter in archive_config |
autoformat | Removes extraneous headers and repairs malformed requests. |
autorespond | Marks requests as {{already done}} if the user already has the permission they are requesting. Only runs on WP:PERM/C and WP:PERM/AWB |
fetch_declined | Searches the declined archives and comments if the user has had any relevant requests recently declined, with permalinks to the relevant page. Does not run on WP:PERM/C |
prerequisites | Comments if the user does not meet the configurable qualifications for that permission. The data is kept up-to-date until the request is responded to. |
checkrevoked | Comments if the user has had the requested permission revoked in the past N days, as specified in the config |
Specifies which pages the bot should process, and the regular expression the bot should use in detecting if a user has that right.
The keys should be the name of the subpage of Wikipedia:Requests for permissions. The values are the name of the user group as specified by the wiki configuration (e.g. rollbacker
, not rollback
). A full list of the user groups can be found here, where the value for name
is what should be used. The value for "confirmed" is actually a regular expression, since both confirmed
and autoconfirmed
are considered to be the same permission at WP:PERM.
Define what the bot should consider a backlog.
These prerequisites do not necessarily represent consensus. Any changes should first be discussed at WT:PERM or another appropriate venue.
All values are integers, representing a minimum threshold the user should meet.
If a new permission has been created, it will need to be specified here. If there are no requirements for a particular permission, simply leave an empty object as with {}
Available parameters | ||
---|---|---|
Parameter | Description | |
accountAge | Number of days since account registration | |
articleCount | Number of articles created by the user | |
editCount | Number of edits | |
mainSpaceCount | Number of edits to the mainspace | |
manualMainSpaceCount | Number of edits to the mainspace without the assistance of automated tools. This count is retrieved via the API provided by non-automated edit tool | |
moduleSpaceCount | Number of edits to the module namespace | |
templateSpaceCount | Number of edits to the template namespace | |
templateAndModuleSpaceCount | Just as it sounds; combined edits to template and module namespaces |