MediaWiki:Gadget-userRightsManager.js: Difference between revisions
From Test Wiki
Content deleted Content added
update the gadget to allow selecting which rights to grant + changing the target user |
m Undo edit before the rename; the changes made to the template links aren't applying to the gadget for some reason Tag: Manual revert |
||
| (30 intermediate revisions by 8 users not shown) | |||
| Line 1: | Line 1: | ||
// <nowiki> |
// <nowiki> |
||
// Adapted from [[mhtest:MediaWiki:Gadget-userRightsManagerTW.js]], itself adapted from [[w:User:MusikAnimal/userRightsManager.js]] |
// Adapted from [[mhtest:MediaWiki:Gadget-userRightsManagerTW.js]], itself adapted from [[w:User:MusikAnimal/userRightsManager.js]], this code is therefore licensed under CC-BY-SA 4.0 |
||
(function() { |
(function() { |
||
if (mw.config.get('wgPageName') != 'Test_Wiki: |
if (mw.config.get('wgPageName') != 'Test_Wiki:Request_for_permissions' && !mw.config.get('wgPageName').includes('URMTW-TESTPAGE-RFP')) { |
||
return; |
return; |
||
} |
} |
||
| Line 9: | Line 9: | ||
'sysop': 'Administrator', |
'sysop': 'Administrator', |
||
'bureaucrat': 'Bureaucrat', |
'bureaucrat': 'Bureaucrat', |
||
'interface-admin': 'Interface |
'interface-admin': 'Interface administrator', |
||
'abusefilter-admin': 'Abuse filter administrator', |
|||
} |
} |
||
var cannedResponses = { |
var cannedResponses = { |
||
'sysop': '{{ |
'sysop': '{{administrator granted}} ~~~~', |
||
'bureaucrat': '{{ |
'bureaucrat': '{{bureaucrat granted}} ~~~~', |
||
'interface-admin': '{{ |
'interface-admin': '{{interface administrator granted}} ~~~~', |
||
'abusefilter-admin': '{{done}}. ~~~~', |
|||
}; |
}; |
||
var listKeys = { |
|||
'sysop': 'A', |
|||
'bureaucrat': 'B', |
|||
'interface-admin': 'F' |
|||
} |
|||
var api, |
var api, |
||
| Line 75: | Line 71: | ||
this.groupsInterfaceAdminInput = new OO.ui.CheckboxInputWidget({ |
this.groupsInterfaceAdminInput = new OO.ui.CheckboxInputWidget({ |
||
selected: permissionText.includes('interface') && mw.config.get('wgUserGroups').includes('steward'), |
selected: permissionText.includes('interface') && mw.config.get('wgUserGroups').includes('steward'), |
||
disabled: !mw.config.get('wgUserGroups').includes('steward') |
|||
| ⚫ | |||
this.groupsAbuseFilterInput = new OO.ui.CheckboxInputWidget({ |
|||
selected: permissionText.includes('abusefilter-admin') && mw.config.get('wgUserGroups').includes('steward'), |
|||
disabled: !mw.config.get('wgUserGroups').includes('steward') |
disabled: !mw.config.get('wgUserGroups').includes('steward') |
||
}); |
}); |
||
| Line 92: | Line 92: | ||
new OO.ui.FieldLayout(this.groupsBureaucratInput, {label: 'Bureaucrat', align: 'inline'}), |
new OO.ui.FieldLayout(this.groupsBureaucratInput, {label: 'Bureaucrat', align: 'inline'}), |
||
new OO.ui.FieldLayout(this.groupsInterfaceAdminInput, {label: 'Interface administrator', align: 'inline'}), |
new OO.ui.FieldLayout(this.groupsInterfaceAdminInput, {label: 'Interface administrator', align: 'inline'}), |
||
new OO.ui.FieldLayout(this.groupsAbuseFilterInput, {label: 'Abuse filter administrator', align: 'inline'}), |
|||
] |
] |
||
}) |
}) |
||
| Line 97: | Line 98: | ||
}), { |
}), { |
||
label: 'Rights', |
label: 'Rights', |
||
| ⚫ | |||
new OO.ui.FieldLayout(this.userNameInput, { |
|||
label: 'Target user', |
|||
}), |
}), |
||
new OO.ui.FieldLayout(this.closingRemarksInput, { |
new OO.ui.FieldLayout(this.closingRemarksInput, { |
||
| Line 113: | Line 117: | ||
this.changeRightsProgressLabel = new OO.ui.LabelWidget(); |
this.changeRightsProgressLabel = new OO.ui.LabelWidget(); |
||
this.changeRightsProgressField = new OO.ui.FieldLayout( this.changeRightsProgressLabel ); |
this.changeRightsProgressField = new OO.ui.FieldLayout( this.changeRightsProgressLabel ); |
||
this.updateJsonProgressLabel = new OO.ui.LabelWidget(); |
|||
this.updateJsonProgressField = new OO.ui.FieldLayout( this.updateJsonProgressLabel ); |
|||
this.markAsDoneProgressLabel = new OO.ui.LabelWidget(); |
this.markAsDoneProgressLabel = new OO.ui.LabelWidget(); |
||
this.markAsDoneProgressField = new OO.ui.FieldLayout( this.markAsDoneProgressLabel ); |
this.markAsDoneProgressField = new OO.ui.FieldLayout( this.markAsDoneProgressLabel ); |
||
| Line 130: | Line 132: | ||
if(this.groupsBureaucratInput.isSelected()) perms.push('bureaucrat'); |
if(this.groupsBureaucratInput.isSelected()) perms.push('bureaucrat'); |
||
if(this.groupsInterfaceAdminInput.isSelected()) perms.push('interface-admin'); |
if(this.groupsInterfaceAdminInput.isSelected()) perms.push('interface-admin'); |
||
if(this.groupsAbuseFilterInput.isSelected()) perms.push('abusefilter-admin'); |
|||
var self = this, promiseCount = |
var self = this, promiseCount = 2; |
||
self.actions.setAbilities( { submit: false } ); |
self.actions.setAbilities( { submit: false } ); |
||
| Line 170: | Line 173: | ||
self.markAsDoneProgressField.setLabel( 'Marking request as done...' ); |
self.markAsDoneProgressField.setLabel( 'Marking request as done...' ); |
||
self.submitFieldset.addItems( [self.markAsDoneProgressField] ); |
self.submitFieldset.addItems( [self.markAsDoneProgressField] ); |
||
self.updateJsonProgressField.setLabel( 'Updating markadmins.json' ); |
|||
self.submitFieldset.addItems( [self.updateJsonProgressField] ); |
|||
self.changeRightsProgressField.setLabel( 'Assigning rights...' ); |
self.changeRightsProgressField.setLabel( 'Assigning rights...' ); |
||
self.submitFieldset.addItems( [self.changeRightsProgressField] ); |
self.submitFieldset.addItems( [self.changeRightsProgressField] ); |
||
| Line 179: | Line 180: | ||
markAsDone('\n:' + this.closingRemarksInput.getValue()) |
markAsDone('\n:' + this.closingRemarksInput.getValue()) |
||
).then(function(data) { |
).then(function(data) { |
||
addPromise( |
|||
self.updateJsonProgressField, |
|||
updateJson(data.edit.newrevid) |
|||
| ⚫ | |||
addPromise( |
addPromise( |
||
self.changeRightsProgressField, |
self.changeRightsProgressField, |
||
| Line 219: | Line 216: | ||
user: userName.replace(/ /g, '_'), |
user: userName.replace(/ /g, '_'), |
||
add: perms.join('|'), |
add: perms.join('|'), |
||
reason: '+' + perms.join(', +') + '; ' + permaLink + ' at [[TW: |
reason: '+' + perms.join(', +') + '; ' + permaLink + ' at [[TW:RfP]]', |
||
expiry: 'infinity', |
expiry: 'infinity', |
||
tags: ' |
tags: 'userRightsManager' |
||
}); |
|||
} |
|||
function updateJson(revId) { |
|||
return api.get({ |
|||
'action': 'query', |
|||
'titles': 'MediaWiki:Gadget-markadmins.json', |
|||
'prop': 'revisions', |
|||
'rvslots': '*', |
|||
'rvlimit': 1, |
|||
'rvprop': 'content' |
|||
}).then(function(data){ |
|||
var newContent = JSON.parse(data['query']['pages'][Object.keys(data['query']['pages'])[0]]['revisions'][0]['slots']['main']['*']); |
|||
for(perm in perms){ |
|||
if(!newContent['userSet'][listKeys[perm]].includes(userName.replace(/_/g, ' '))){ |
|||
newContent['userSet'][listKeys[perm]].push(userName.replace(/_/g, ' ')) |
|||
| ⚫ | |||
newContent['userSet'][listKeys[perm]].sort() |
|||
} |
|||
newContent = JSON.stringify(newContent, null, 4) |
|||
return api.postWithToken( 'edit', { |
|||
'action': 'edit', |
|||
'title': 'MediaWiki:Gadget-markadmins.json', |
|||
'text': newContent, |
|||
'tags': 'userRightsManagerTW', |
|||
summary: 'Adding [[User:' + userName + '|' + userName.replace(/_/g, ' ') + ']] to ' + names[permission] + 's ' + '([[Special:Diff/' + revId + '|per request]])' |
|||
}) |
|||
}); |
}); |
||
} |
} |
||
| Line 268: | Line 238: | ||
'section': sectionId, |
'section': sectionId, |
||
'text': newContent, |
'text': newContent, |
||
'tags': ' |
'tags': 'userRightsManager', |
||
summary: '/* User:' + userName + ' */ done' |
summary: '/* User:' + userName + ' */ done' |
||
}) |
}) |
||