'json',
),
),
+ 'mediawiki.api.user' => array(
+ 'scripts' => 'resources/src/mediawiki/api/user.js',
+ 'dependencies' => array(
+ 'mediawiki.api',
+ ),
+ 'targets' => array( 'desktop', 'mobile' ),
+ ),
'mediawiki.api.watch' => array(
'scripts' => 'resources/src/mediawiki/api/watch.js',
'dependencies' => array(
'dependencies' => array(
'mediawiki.cookie',
'mediawiki.api',
+ 'mediawiki.api.user',
'user.options',
'user.tokens',
),
--- /dev/null
+/**
+ * @class mw.Api.plugin.user
+ * @since 1.27
+ */
+( function ( mw, $ ) {
+
+ $.extend( mw.Api.prototype, {
+
+ /**
+ * Get the current user's groups and rights.
+ *
+ * @return {jQuery.Promise}
+ * @return {Function} return.done
+ * @return {Object} return.done.userInfo
+ * @return {string[]} return.done.userInfo.groups User groups that the current user belongs to
+ * @return {string[]} return.done.userInfo.rights Current user's rights
+ */
+ getUserInfo: function () {
+ return this.get( {
+ action: 'query',
+ meta: 'userinfo',
+ uiprop: [ 'groups', 'rights' ]
+ } ).then( function ( data ) {
+ if ( data.query && data.query.userinfo ) {
+ return data.query.userinfo;
+ }
+ return $.Deferred().reject().promise();
+ } );
+ }
+ } );
+
+ /**
+ * @class mw.Api
+ * @mixins mw.Api.plugin.user
+ */
+
+}( mediaWiki, jQuery ) );
*/
( function ( mw, $ ) {
var i,
- deferreds = {},
+ userInfoPromise,
byteToHex = [];
/**
* Get the current user's groups or rights
*
* @private
- * @param {string} info One of 'groups' or 'rights'
* @return {jQuery.Promise}
*/
- function getUserInfo( info ) {
- var api;
- if ( !deferreds[ info ] ) {
-
- deferreds.rights = $.Deferred();
- deferreds.groups = $.Deferred();
-
- api = new mw.Api();
- api.get( {
- action: 'query',
- meta: 'userinfo',
- uiprop: 'rights|groups'
- } ).always( function ( data ) {
- var rights, groups;
- if ( data.query && data.query.userinfo ) {
- rights = data.query.userinfo.rights;
- groups = data.query.userinfo.groups;
- }
- deferreds.rights.resolve( rights || [] );
- deferreds.groups.resolve( groups || [] );
- } );
-
+ function getUserInfo() {
+ if ( !userInfoPromise ) {
+ userInfoPromise = new mw.Api().getUserInfo();
}
-
- return deferreds[ info ].promise();
+ return userInfoPromise;
}
// Map from numbers 0-255 to a hex string (with padding)
* @return {jQuery.Promise}
*/
getGroups: function ( callback ) {
- return getUserInfo( 'groups' ).done( callback );
+ return getUserInfo().then(
+ function ( userInfo ) { return userInfo.groups; },
+ function () { return []; }
+ ).done( callback );
},
/**
* @return {jQuery.Promise}
*/
getRights: function ( callback ) {
- return getUserInfo( 'rights' ).done( callback );
+ return getUserInfo().then(
+ function ( userInfo ) { return userInfo.rights; },
+ function () { return []; }
+ ).done( callback );
}
} );