1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
|
'use strict';
'require fs';
'require ui';
'require rpc';
var callLuciProcessList = rpc.declare({
object: 'luci',
method: 'getProcessList',
expect: { result: [] }
});
return L.view.extend({
load: function() {
return callLuciProcessList();
},
handleSignal: function(signum, pid, ev) {
return fs.exec('/bin/kill', ['-%d'.format(signum), '%s'.format(pid)]).then(L.bind(function() {
return callLuciProcessList().then(L.bind(function(processes) {
this.updateTable('.table', processes);
}, this));
}, this)).catch(function(e) { ui.addNotification(null, E('p', e.message)) });
},
updateTable: function(table, processes) {
var rows = [];
processes.sort(function(a, b) {
return (a.PID - b.PID);
});
for (var i = 0; i < processes.length; i++) {
var proc = processes[i];
rows.push([
proc.PID,
proc.USER,
proc.COMMAND,
proc['%CPU'],
proc['%MEM'],
E('div', { 'class': 'nowrap' }, [
E('button', {
'class': 'btn cbi-button-action',
'click': ui.createHandlerFn(this, 'handleSignal', 1, proc.PID)
}, _('Hang Up')), ' ',
E('button', {
'class': 'btn cbi-button-negative',
'click': ui.createHandlerFn(this, 'handleSignal', 15, proc.PID)
}, _('Terminate')), ' ',
E('button', {
'class': 'btn cbi-button-negative',
'click': ui.createHandlerFn(this, 'handleSignal', 9, proc.PID)
}, _('Kill'))
])
]);
}
cbi_update_table(table, rows, E('em', _('No information available')));
},
render: function(processes) {
var v = E([], [
E('h2', _('Processes')),
E('div', { 'class': 'cbi-map-descr' }, _('This list gives an overview over currently running system processes and their status.')),
E('div', { 'class': 'table' }, [
E('div', { 'class': 'tr table-titles' }, [
E('div', { 'class': 'th' }, _('PID')),
E('div', { 'class': 'th' }, _('Owner')),
E('div', { 'class': 'th' }, _('Command')),
E('div', { 'class': 'th' }, _('CPU usage (%)')),
E('div', { 'class': 'th' }, _('Memory usage (%)')),
E('div', { 'class': 'th center' }, _('Actions'))
])
])
]);
this.updateTable(v.lastElementChild, processes);
return v;
},
handleSaveApply: null,
handleSave: null,
handleReset: null
});
|