blob: fb19dab2055d5357c068f019211e0c1381042b4d [file] [log] [blame]
window.angular && (function(angular) {
'use strict';
/**
* Role table
* Table of privilege role descriptions
*/
angular.module('app.accessControl').directive('roleTable', [
'$sce',
function($sce) {
return {
restrict: 'E',
template: require('./role-table.html'),
controllerAs: 'roleTableCtrl',
controller: function() {
// TODO: This is a workaround to render the checkmark svg icon
// Would eventually like to enhance <bmc-table> component to
// compile custom directives as table items
const svg = require('../../assets/icons/icon-check.svg');
const check =
$sce.trustAsHtml(`<span class="icon__check-mark">${svg}<span>`);
this.tableHeader = [
{label: ''}, {label: 'Admin'}, {label: 'Operator'}, {label: 'User'},
{label: 'Callback'}
];
// TODO: When API changed from D-Bus to Redfish, 'Operator' role
// should have 'Configure components managed by this service'
// privilege checked
// TODO: When 'Operator' and 'User' roles have ability to change
// own account's passwords, should have 'Update password for
// current user account' privilege checked
// TODO: Update Callback privileges when backend removes privileges
// for Callback role.
this.tableData = [
{
uiData: [
'Configure components managed by this service', check, '', '',
''
]
},
{uiData: ['Configure manager resources', check, '', '', '']},
{
uiData: [
'Update password for current user account', check, '', '', ''
]
},
{uiData: ['Configure users and their accounts', check, '', '', '']},
{
uiData: [
'Log in to the service and read resources', check, check, check,
check
]
},
{uiData: ['IPMI access point', check, check, check, check]},
{uiData: ['Redfish access point', check, check, check, check]},
{uiData: ['SSH access point', check, check, check, check]},
{uiData: ['WebUI access point', check, check, check, check]},
];
this.isCollapsed = true;
this.onClick = () => {
this.isCollapsed = !this.isCollapsed;
};
}
};
}
]);
})(window.angular);