]>
Commit | Line | Data |
---|---|---|
06694509 DM |
1 | Ext.define('Proxmox.window.TaskProgress', { |
2 | extend: 'Ext.window.Window', | |
3 | alias: 'widget.proxmoxTaskProgress', | |
4 | ||
fde8e8bb TL |
5 | taskDone: Ext.emptyFn, |
6 | ||
06694509 | 7 | initComponent: function() { |
05a977a2 | 8 | let me = this; |
06694509 DM |
9 | |
10 | if (!me.upid) { | |
11 | throw "no task specified"; | |
12 | } | |
13 | ||
05a977a2 | 14 | let task = Proxmox.Utils.parse_task_upid(me.upid); |
06694509 | 15 | |
05a977a2 | 16 | let statstore = Ext.create('Proxmox.data.ObjectStore', { |
06694509 DM |
17 | url: "/api2/json/nodes/" + task.node + "/tasks/" + me.upid + "/status", |
18 | interval: 1000, | |
19 | rows: { | |
20 | status: { defaultValue: 'unknown' }, | |
01031528 TL |
21 | exitstatus: { defaultValue: 'unknown' }, |
22 | }, | |
06694509 DM |
23 | }); |
24 | ||
13fc756d | 25 | me.on('destroy', statstore.stopUpdate); |
06694509 | 26 | |
05a977a2 TL |
27 | let getObjectValue = function(key, defaultValue) { |
28 | let rec = statstore.getById(key); | |
06694509 DM |
29 | if (rec) { |
30 | return rec.data.value; | |
31 | } | |
32 | return defaultValue; | |
33 | }; | |
34 | ||
05a977a2 | 35 | let pbar = Ext.create('Ext.ProgressBar', { text: 'running...' }); |
06694509 DM |
36 | |
37 | me.mon(statstore, 'load', function() { | |
05a977a2 | 38 | let status = getObjectValue('status'); |
06694509 | 39 | if (status === 'stopped') { |
05a977a2 TL |
40 | let exitstatus = getObjectValue('exitstatus'); |
41 | if (exitstatus === 'OK') { | |
06694509 DM |
42 | pbar.reset(); |
43 | pbar.updateText("Done!"); | |
44 | Ext.Function.defer(me.close, 1000, me); | |
45 | } else { | |
46 | me.close(); | |
47 | Ext.Msg.alert('Task failed', exitstatus); | |
48 | } | |
05a977a2 | 49 | me.taskDone(exitstatus === 'OK'); |
06694509 DM |
50 | } |
51 | }); | |
52 | ||
05a977a2 | 53 | let descr = Proxmox.Utils.format_task_description(task.type, task.id); |
06694509 DM |
54 | |
55 | Ext.apply(me, { | |
d7139140 | 56 | title: gettext('Task') + ': ' + descr, |
06694509 DM |
57 | width: 300, |
58 | layout: 'auto', | |
59 | modal: true, | |
60 | bodyPadding: 5, | |
61 | items: pbar, | |
62 | buttons: [ | |
13fc756d | 63 | { |
06694509 | 64 | text: gettext('Details'), |
13fc756d | 65 | handler: function() { |
05a977a2 | 66 | let win = Ext.create('Proxmox.window.TaskViewer', { |
fde8e8bb | 67 | taskDone: me.taskDone, |
01031528 | 68 | upid: me.upid, |
06694509 DM |
69 | }); |
70 | win.show(); | |
71 | me.close(); | |
01031528 TL |
72 | }, |
73 | }, | |
74 | ], | |
06694509 DM |
75 | }); |
76 | ||
77 | me.callParent(); | |
78 | ||
79 | statstore.startUpdate(); | |
80 | ||
81 | pbar.wait(); | |
01031528 | 82 | }, |
06694509 DM |
83 | }); |
84 | ||
85 | // fixme: how can we avoid those lint errors? | |
06694509 DM |
86 | |
87 | Ext.define('Proxmox.window.TaskViewer', { | |
88 | extend: 'Ext.window.Window', | |
89 | alias: 'widget.proxmoxTaskViewer', | |
90 | ||
641df09e TL |
91 | extraTitle: '', // string to prepend after the generic task title |
92 | ||
fde8e8bb TL |
93 | taskDone: Ext.emptyFn, |
94 | ||
06694509 | 95 | initComponent: function() { |
05a977a2 | 96 | let me = this; |
06694509 DM |
97 | |
98 | if (!me.upid) { | |
99 | throw "no task specified"; | |
100 | } | |
101 | ||
05a977a2 | 102 | let task = Proxmox.Utils.parse_task_upid(me.upid); |
06694509 | 103 | |
05a977a2 | 104 | let statgrid; |
06694509 | 105 | |
05a977a2 | 106 | let rows = { |
06694509 DM |
107 | status: { |
108 | header: gettext('Status'), | |
109 | defaultValue: 'unknown', | |
110 | renderer: function(value) { | |
05a977a2 | 111 | if (value !== 'stopped') { |
06694509 DM |
112 | return value; |
113 | } | |
05a977a2 | 114 | let es = statgrid.getObjectValue('exitstatus'); |
06694509 DM |
115 | if (es) { |
116 | return value + ': ' + es; | |
117 | } | |
05a977a2 | 118 | return 'unknown'; |
01031528 | 119 | }, |
06694509 | 120 | }, |
13fc756d | 121 | exitstatus: { |
01031528 | 122 | visible: false, |
06694509 DM |
123 | }, |
124 | type: { | |
125 | header: gettext('Task type'), | |
01031528 | 126 | required: true, |
06694509 DM |
127 | }, |
128 | user: { | |
129 | header: gettext('User name'), | |
92d1c20d | 130 | renderer: Ext.String.htmlEncode, |
01031528 | 131 | required: true, |
06694509 DM |
132 | }, |
133 | node: { | |
134 | header: gettext('Node'), | |
01031528 | 135 | required: true, |
06694509 DM |
136 | }, |
137 | pid: { | |
138 | header: gettext('Process ID'), | |
01031528 | 139 | required: true, |
06694509 | 140 | }, |
21efafeb TL |
141 | task_id: { |
142 | header: gettext('Task ID'), | |
143 | }, | |
06694509 DM |
144 | starttime: { |
145 | header: gettext('Start Time'), | |
13fc756d | 146 | required: true, |
01031528 | 147 | renderer: Proxmox.Utils.render_timestamp, |
06694509 DM |
148 | }, |
149 | upid: { | |
92d1c20d DC |
150 | header: gettext('Unique task ID'), |
151 | renderer: Ext.String.htmlEncode, | |
01031528 | 152 | }, |
06694509 DM |
153 | }; |
154 | ||
c9d603af DC |
155 | if (me.endtime) { |
156 | if (typeof me.endtime === 'object') { | |
157 | // convert to epoch | |
158 | me.endtime = parseInt(me.endtime.getTime()/1000, 10); | |
159 | } | |
160 | rows.endtime = { | |
161 | header: gettext('End Time'), | |
162 | required: true, | |
163 | renderer: function() { | |
164 | return Proxmox.Utils.render_timestamp(me.endtime); | |
165 | }, | |
166 | }; | |
167 | } | |
168 | ||
169 | rows.duration = { | |
170 | header: gettext('Duration'), | |
171 | required: true, | |
172 | renderer: function() { | |
173 | let starttime = statgrid.getObjectValue('starttime'); | |
174 | let endtime = me.endtime || Date.now()/1000; | |
175 | let duration = endtime - starttime; | |
176 | return Proxmox.Utils.format_duration_human(duration); | |
177 | }, | |
178 | }; | |
179 | ||
05a977a2 | 180 | let statstore = Ext.create('Proxmox.data.ObjectStore', { |
06694509 DM |
181 | url: "/api2/json/nodes/" + task.node + "/tasks/" + me.upid + "/status", |
182 | interval: 1000, | |
01031528 | 183 | rows: rows, |
06694509 DM |
184 | }); |
185 | ||
13fc756d | 186 | me.on('destroy', statstore.stopUpdate); |
06694509 | 187 | |
05a977a2 | 188 | let stop_task = function() { |
06694509 DM |
189 | Proxmox.Utils.API2Request({ |
190 | url: "/nodes/" + task.node + "/tasks/" + me.upid, | |
191 | waitMsgTarget: me, | |
192 | method: 'DELETE', | |
193 | failure: function(response, opts) { | |
194 | Ext.Msg.alert(gettext('Error'), response.htmlStatus); | |
01031528 | 195 | }, |
06694509 DM |
196 | }); |
197 | }; | |
198 | ||
05a977a2 | 199 | let stop_btn1 = new Ext.Button({ |
06694509 DM |
200 | text: gettext('Stop'), |
201 | disabled: true, | |
01031528 | 202 | handler: stop_task, |
06694509 DM |
203 | }); |
204 | ||
05a977a2 | 205 | let stop_btn2 = new Ext.Button({ |
06694509 DM |
206 | text: gettext('Stop'), |
207 | disabled: true, | |
01031528 | 208 | handler: stop_task, |
06694509 DM |
209 | }); |
210 | ||
211 | statgrid = Ext.create('Proxmox.grid.ObjectGrid', { | |
212 | title: gettext('Status'), | |
213 | layout: 'fit', | |
01031528 | 214 | tbar: [stop_btn1], |
06694509 DM |
215 | rstore: statstore, |
216 | rows: rows, | |
01031528 | 217 | border: false, |
06694509 DM |
218 | }); |
219 | ||
05a977a2 | 220 | let logView = Ext.create('Proxmox.panel.LogView', { |
06694509 | 221 | title: gettext('Output'), |
01031528 | 222 | tbar: [stop_btn2], |
06694509 | 223 | border: false, |
01031528 | 224 | url: "/api2/extjs/nodes/" + task.node + "/tasks/" + me.upid + "/log", |
06694509 DM |
225 | }); |
226 | ||
227 | me.mon(statstore, 'load', function() { | |
05a977a2 | 228 | let status = statgrid.getObjectValue('status'); |
13fc756d | 229 | |
06694509 | 230 | if (status === 'stopped') { |
06694509 | 231 | logView.scrollToEnd = false; |
65bb3b67 | 232 | logView.requestUpdate(); |
06694509 | 233 | statstore.stopUpdate(); |
05a977a2 | 234 | me.taskDone(statgrid.getObjectValue('exitstatus') === 'OK'); |
06694509 DM |
235 | } |
236 | ||
237 | stop_btn1.setDisabled(status !== 'running'); | |
238 | stop_btn2.setDisabled(status !== 'running'); | |
239 | }); | |
240 | ||
241 | statstore.startUpdate(); | |
242 | ||
243 | Ext.apply(me, { | |
641df09e | 244 | title: "Task viewer: " + task.desc + me.extraTitle, |
06694509 DM |
245 | width: 800, |
246 | height: 400, | |
247 | layout: 'fit', | |
248 | modal: true, | |
249 | items: [{ | |
250 | xtype: 'tabpanel', | |
251 | region: 'center', | |
01031528 TL |
252 | items: [logView, statgrid], |
253 | }], | |
06694509 DM |
254 | }); |
255 | ||
256 | me.callParent(); | |
257 | ||
258 | logView.fireEvent('show', logView); | |
01031528 | 259 | }, |
06694509 DM |
260 | }); |
261 |