97 lines
3.2 KiB
JavaScript
97 lines
3.2 KiB
JavaScript
/* jslint node: true */
|
|
'use strict';
|
|
|
|
// ENiGMA½
|
|
const { MenuModule } = require('./menu_module.js');
|
|
const { getUserList } = require('./user.js');
|
|
const { Errors } = require('./enig_error.js');
|
|
|
|
// deps
|
|
const moment = require('moment');
|
|
const async = require('async');
|
|
const _ = require('lodash');
|
|
|
|
/*
|
|
Available listFormat/focusListFormat object members:
|
|
|
|
userId : User ID
|
|
userName : User name/handle
|
|
lastLoginTs : Last login timestamp
|
|
status : Status: active | inactive
|
|
location : Location
|
|
affiliation : Affils
|
|
note : User note
|
|
*/
|
|
|
|
exports.moduleInfo = {
|
|
name : 'User List',
|
|
desc : 'Lists all system users',
|
|
author : 'NuSkooler',
|
|
};
|
|
|
|
const MciViewIds = {
|
|
userList : 1,
|
|
};
|
|
|
|
exports.getModule = class UserListModule extends MenuModule {
|
|
constructor(options) {
|
|
super(options);
|
|
}
|
|
|
|
mciReady(mciData, cb) {
|
|
super.mciReady(mciData, err => {
|
|
if(err) {
|
|
return cb(err);
|
|
}
|
|
|
|
async.series(
|
|
[
|
|
(next) => {
|
|
return this.prepViewController('userList', 0, mciData.menu, next);
|
|
},
|
|
(next) => {
|
|
const userListView = this.viewControllers.userList.getView(MciViewIds.userList);
|
|
if(!userListView) {
|
|
return cb(Errors.MissingMci(`Missing user list MCI ${MciViewIds.userList}`));
|
|
}
|
|
|
|
const fetchOpts = {
|
|
properties : [ 'real_name', 'location', 'affiliation', 'last_login_timestamp' ],
|
|
propsCamelCase : true, // e.g. real_name -> realName
|
|
};
|
|
getUserList(fetchOpts, (err, userList) => {
|
|
if(err) {
|
|
return next(err);
|
|
}
|
|
|
|
const dateTimeFormat = _.get(
|
|
this, 'menuConfig.config.dateTimeFormat', this.client.currentTheme.helpers.getDateTimeFormat('short'));
|
|
|
|
userList = userList.map(entry => {
|
|
return Object.assign(
|
|
entry,
|
|
{
|
|
text : entry.userName,
|
|
affils : entry.affiliation,
|
|
lastLoginTs : moment(entry.lastLoginTimestamp).format(dateTimeFormat),
|
|
}
|
|
);
|
|
});
|
|
|
|
userListView.setItems(userList);
|
|
userListView.redraw();
|
|
return next(null);
|
|
});
|
|
}
|
|
],
|
|
err => {
|
|
if(err) {
|
|
this.client.log.error( { error : err.message }, 'Error loading user list');
|
|
}
|
|
return cb(err);
|
|
}
|
|
);
|
|
});
|
|
}
|
|
};
|