MediaWiki:Gadget-UserRightsManager.js: Difference between revisions

Jump to navigation Jump to search
no edit summary
(update the gadget to allow selecting which rights to grant + changing the target user)
No edit summary
Tags: Mobile edit Mobile web edit
(17 intermediate revisions by 4 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:Request_permissions' && !mw.config.get('wgPageName').includes('URMTW-TESTPAGE-RFP')) {
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 Administrator',
'interface-admin': 'Interface administrator',
'non-stewardsuppress': 'Suppressor',
}
}
var cannedResponses = {
var cannedResponses = {
'sysop': '{{done}}. ~~~~',
'sysop': '{{administrator granted}} ~~~~',
'bureaucrat': '{{done}}. ~~~~',
'bureaucrat': '{{bureaucrat granted}} ~~~~',
'interface-admin': '{{done}}. ~~~~',
'interface-admin': '{{interface administrator granted}} ~~~~',
'non-stewardsuppress': '{{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.groupsNonStewardSuppressInput = new OO.ui.CheckboxInputWidget({
selected: permissionText.includes('suppress') && 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.groupsNonStewardSuppressInput, {label: 'Suppressor', 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.groupsNonStewardSuppressInput.isSelected()) perms.push('non-stewardsuppress');
var self = this, promiseCount = 3;
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:RFP]]',
reason: '+' + perms.join(', +') + '; ' + permaLink + ' at [[TW:RfP]]',
expiry: 'infinity',
expiry: 'infinity',
tags: 'userRightsManagerTW'
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': 'userRightsManagerTW',
'tags': 'userRightsManager',
summary: '/* User:' + userName + ' */ done'
summary: '/* User:' + userName + ' */ done'
})
})
Cookies help us deliver our services. By using our services, you agree to our use of cookies.

Navigation menu