]> git.proxmox.com Git - proxmox-widget-toolkit.git/blame - src/node/ServiceView.js
node/services: optionally show unit/active states
[proxmox-widget-toolkit.git] / src / node / ServiceView.js
CommitLineData
d7139140
DM
1Ext.define('proxmox-services', {
2 extend: 'Ext.data.Model',
6607de47 3 fields: ['service', 'name', 'desc', 'state', 'unit-state', 'active-state'],
01031528 4 idProperty: 'service',
d7139140
DM
5});
6
7Ext.define('Proxmox.node.ServiceView', {
8 extend: 'Ext.grid.GridPanel',
9
10 alias: ['widget.proxmoxNodeServiceView'],
11
12 startOnlyServices: {},
13
2815c428
TL
14 restartCommand: "restart", // TODO: default to reload once everywhere supported
15
01031528 16 initComponent: function() {
05a977a2 17 let me = this;
d7139140
DM
18
19 if (!me.nodename) {
20 throw "no node name specified";
21 }
22
05a977a2 23 let rstore = Ext.create('Proxmox.data.UpdateStore', {
d7139140 24 interval: 1000,
d7139140
DM
25 model: 'proxmox-services',
26 proxy: {
ab34f5b2
TL
27 type: 'proxmox',
28 url: `/api2/json/nodes/${me.nodename}/services`,
01031528 29 },
d7139140
DM
30 });
31
05a977a2 32 let store = Ext.create('Proxmox.data.DiffStore', {
d7139140
DM
33 rstore: rstore,
34 sortAfterUpdate: true,
35 sorters: [
36 {
01031528
TL
37 property: 'name',
38 direction: 'ASC',
39 },
40 ],
d7139140
DM
41 });
42
05a977a2 43 let view_service_log = function() {
ab34f5b2
TL
44 let { data: { service } } = me.getSelectionModel().getSelection()[0];
45 Ext.create('Ext.window.Window', {
46 title: gettext('Syslog') + ': ' + service,
f21840aa 47 modal: true,
8093ded0
DC
48 width: 800,
49 height: 400,
50 layout: 'fit',
f21840aa
DM
51 items: {
52 xtype: 'proxmoxLogView',
ab34f5b2 53 url: `/api2/extjs/nodes/${me.nodename}/syslog?service=${service}`,
01031528
TL
54 log_select_timespan: 1,
55 },
ab34f5b2 56 autoShow: true,
f21840aa 57 });
f21840aa
DM
58 };
59
05a977a2 60 let service_cmd = function(cmd) {
ab34f5b2 61 let { data: { service } } = me.getSelectionModel().getSelection()[0];
d7139140 62 Proxmox.Utils.API2Request({
77ff40e4 63 url: `/nodes/${me.nodename}/services/${service}/${cmd}`,
d7139140
DM
64 method: 'POST',
65 failure: function(response, opts) {
66 Ext.Msg.alert(gettext('Error'), response.htmlStatus);
67 me.loading = true;
68 },
69 success: function(response, opts) {
70 rstore.startUpdate();
ab34f5b2
TL
71 Ext.create('Proxmox.window.TaskProgress', {
72 upid: response.result.data,
73 autoShow: true,
d7139140 74 });
01031528 75 },
d7139140
DM
76 });
77 };
78
05a977a2 79 let start_btn = new Ext.Button({
d7139140
DM
80 text: gettext('Start'),
81 disabled: true,
01031528 82 handler: function() {
d7139140 83 service_cmd("start");
01031528 84 },
d7139140
DM
85 });
86
05a977a2 87 let stop_btn = new Ext.Button({
d7139140
DM
88 text: gettext('Stop'),
89 disabled: true,
01031528 90 handler: function() {
d7139140 91 service_cmd("stop");
01031528 92 },
d7139140
DM
93 });
94
05a977a2 95 let restart_btn = new Ext.Button({
d7139140
DM
96 text: gettext('Restart'),
97 disabled: true,
01031528 98 handler: function() {
2815c428 99 service_cmd(me.restartCommand || "restart");
01031528 100 },
d7139140
DM
101 });
102
05a977a2 103 let syslog_btn = new Ext.Button({
ecb07824
DM
104 text: gettext('Syslog'),
105 disabled: true,
01031528 106 handler: view_service_log,
ecb07824
DM
107 });
108
05a977a2
TL
109 let set_button_status = function() {
110 let sm = me.getSelectionModel();
111 let rec = sm.getSelection()[0];
d7139140
DM
112
113 if (!rec) {
114 start_btn.disable();
115 stop_btn.disable();
116 restart_btn.disable();
ecb07824 117 syslog_btn.disable();
d7139140
DM
118 return;
119 }
05a977a2
TL
120 let service = rec.data.service;
121 let state = rec.data.state;
d7139140 122
ecb07824
DM
123 syslog_btn.enable();
124
05a977a2
TL
125 if (state === 'running') {
126 start_btn.disable();
127 restart_btn.enable();
128 } else {
129 start_btn.enable();
130 restart_btn.disable();
131 }
132 if (!me.startOnlyServices[service]) {
133 if (state === 'running') {
d7139140
DM
134 stop_btn.enable();
135 } else {
d7139140
DM
136 stop_btn.disable();
137 }
05a977a2 138 }
d7139140
DM
139 };
140
141 me.mon(store, 'refresh', set_button_status);
142
143 Proxmox.Utils.monStoreErrors(me, rstore);
144
145 Ext.apply(me, {
146 store: store,
147 stateful: false,
01031528 148 tbar: [start_btn, stop_btn, restart_btn, syslog_btn],
d7139140
DM
149 columns: [
150 {
151 header: gettext('Name'),
ab29b73d 152 flex: 1,
d7139140 153 sortable: true,
01031528 154 dataIndex: 'name',
d7139140
DM
155 },
156 {
157 header: gettext('Status'),
158 width: 100,
159 sortable: true,
01031528 160 dataIndex: 'state',
6607de47
TL
161 renderer: (v, meta, rec) => rec.get('unit-state') === 'masked'
162 ? gettext('disabled')
163 : v,
164 },
165 {
166 header: gettext('Active'),
167 width: 100,
168 sortable: true,
169 hidden: true,
170 dataIndex: 'active-state',
171 },
172 {
173 header: gettext('Unit'),
174 width: 120,
175 sortable: true,
176 hidden: typeof PVE === 'object', // FIXME currently only PVE supports it
177 dataIndex: 'unit-state',
d7139140
DM
178 },
179 {
180 header: gettext('Description'),
181 renderer: Ext.String.htmlEncode,
182 dataIndex: 'desc',
01031528
TL
183 flex: 2,
184 },
d7139140
DM
185 ],
186 listeners: {
187 selectionchange: set_button_status,
f21840aa 188 itemdblclick: view_service_log,
d7139140 189 activate: rstore.startUpdate,
01031528
TL
190 destroy: rstore.stopUpdate,
191 },
d7139140
DM
192 });
193
194 me.callParent();
01031528 195 },
d7139140 196});