]>
git.proxmox.com Git - pmg-gui.git/blob - js/SpamQuarantine.js
a68568602e5ef136668daf47b1b38cbe65b5153d
1 Ext
.define('pmg-spam-archive', {
2 extend
: 'Ext.data.Model',
4 { type
: 'number', name
: 'spamavg' },
5 { type
: 'integer', name
: 'count' },
6 { type
: 'date', dateFormat
: 'timestamp', name
: 'day' },
10 url
: "/api2/json/quarantine/spam",
15 Ext
.define('pmg-spam-list', {
16 extend
: 'Ext.data.Model',
17 fields
: ['id', 'envelope_sender', 'from', 'sender', 'receiver', 'subject',
18 { type
: 'number', name
: 'spamlevel' },
19 { type
: 'integer', name
: 'bytes' },
20 { type
: 'date', dateFormat
: 'timestamp', name
: 'time' },
24 convert: function(v
, rec
) {
25 return Ext
.Date
.format(rec
.get('time'), 'Y-m-d');
31 url
: "/api2/json/quarantine/spam",
36 Ext
.define('PMG.SpamQuarantine', {
37 extend
: 'Ext.container.Container',
38 xtype
: 'pmgSpamQuarantine',
41 layout
: { type
: 'border' },
43 defaults
: { border
: false },
54 downloadMailURL
: get => '/api2/json/quarantine/download?mailid=' + encodeURIComponent(get('mailid')),
59 xclass
: 'Ext.app.ViewController',
61 updatePreview: function(raw
, rec
) {
62 var preview
= this.lookupReference('preview');
64 if (!rec
|| !rec
.data
|| !rec
.data
.id
) {
66 preview
.setDisabled(true);
70 var url
= '/api2/htmlmail/quarantine/content?id=' + rec
.data
.id
+ (raw
?'&raw=1':'');
71 preview
.setDisabled(false);
72 this.lookupReference('raw').setDisabled(false);
73 this.lookupReference('spam').setDisabled(false);
74 this.lookupReference('download').setDisabled(false);
75 preview
.update("<iframe frameborder=0 width=100% height=100% sandbox='allow-same-origin' src='" + url
+"'></iframe>");
78 multiSelect: function(selection
) {
79 var preview
= this.lookupReference('preview');
80 var raw
= this.lookupReference('raw');
81 var spam
= this.lookupReference('spam');
82 var spaminfo
= this.lookupReference('spaminfo');
83 var mailinfo
= this.lookupReference('mailinfo');
84 var download
= this.lookupReference('download');
86 preview
.setDisabled(false);
87 preview
.update(`<h3 style="padding-left:5px;">${gettext('Multiple E-Mails selected')} (${selection.length})</h3>`);
88 raw
.setDisabled(true);
89 spam
.setDisabled(true);
90 spam
.setPressed(false);
91 spaminfo
.setVisible(false);
92 mailinfo
.setVisible(false);
93 download
.setDisabled(true);
96 toggleRaw: function(button
) {
98 var list
= me
.lookupReference('list');
99 var rec
= list
.selModel
.getSelection()[0];
100 me
.lookupReference('mailinfo').setVisible(me
.raw
);
102 me
.updatePreview(me
.raw
, rec
);
105 btnHandler: function(button
, e
) {
107 var action
= button
.reference
;
108 var list
= this.lookupReference('list');
109 var selected
= list
.getSelection();
110 me
.doAction(action
, selected
);
113 doAction: function(action
, selected
) {
114 if (!selected
.length
) {
118 var list
= this.lookupReference('list');
120 if (selected
.length
> 1) {
121 let idlist
= selected
.map(item
=> item
.data
.id
);
125 gettext("Action '{0}' for '{1}' items"),
126 action
, selected
.length
,
128 async
function(button
) {
129 if (button
!== 'yes') {
133 list
.mask(gettext('Processing...'), 'x-mask-loading');
135 const sliceSize
= 2500, maxInFlight
= 2;
136 let batches
= [], batchCount
= Math
.ceil(selected
.length
/ sliceSize
);
137 for (let i
= 0; i
* sliceSize
< selected
.length
; i
++) {
138 let sliceStart
= i
* sliceSize
;
139 let sliceEnd
= Math
.min(sliceStart
+ sliceSize
, selected
.length
);
143 idlist
.slice(sliceStart
, sliceEnd
),
148 if (batches
.length
>= maxInFlight
) {
149 await Promise
.allSettled(batches
); // eslint-disable-line no-await-in-loop
153 await Promise
.allSettled(batches
); // await possible remaining ones
155 // below can be slow, we could remove directly from the in-memory store, but
156 // with lots of elements and some failures we could be quite out of sync?
157 list
.getController().load();
163 PMG
.Utils
.doQuarantineAction(action
, selected
[0].data
.id
, function() {
164 // success -> remove directly to avoid slow store reload for a single-element action
165 list
.getStore().remove(selected
[0]);
169 onSelectMail: function() {
171 var list
= this.lookupReference('list');
172 var selection
= list
.selModel
.getSelection();
173 if (selection
.length
> 1) {
174 me
.multiSelect(selection
);
178 var rec
= selection
[0] || {};
180 me
.getViewModel().set('mailid', rec
.data
? rec
.data
.id
: '');
181 me
.updatePreview(me
.raw
|| false, rec
);
182 me
.lookupReference('spaminfo').setID(rec
);
183 me
.lookupReference('mailinfo').setVisible(!!rec
.data
&& !me
.raw
);
184 me
.lookupReference('mailinfo').update(rec
.data
);
187 toggleSpamInfo: function(btn
) {
188 var grid
= this.lookupReference('spaminfo');
189 grid
.setVisible(!grid
.isVisible());
192 openContextMenu: function(table
, record
, tr
, index
, event
) {
195 let list
= me
.lookup('list');
196 Ext
.create('PMG.menu.SpamContextMenu', {
197 callback
: action
=> me
.doAction(action
, list
.getSelection()),
198 }).showAt(event
.getXY());
201 keyPress: function(table
, record
, item
, index
, event
) {
203 var list
= me
.lookup('list');
204 var key
= event
.getKey();
211 case Ext
.event
.Event
.D
:
212 case Ext
.event
.Event
.D
+ 32:
215 case Ext
.event
.Event
.W
:
216 case Ext
.event
.Event
.W
+ 32:
217 action
= 'whitelist';
219 case Ext
.event
.Event
.B
:
220 case Ext
.event
.Event
.B
+ 32:
221 action
= 'blacklist';
226 me
.doAction(action
, list
.getSelection());
230 init: function(view
) {
231 this.lookup('list').cselect
= view
.cselect
;
235 'button[reference=raw]': {
238 'button[reference=spam]': {
239 click
: 'toggleSpamInfo',
241 'pmgQuarantineList': {
242 selectionChange
: 'onSelectMail',
243 itemkeypress
: 'keyPress',
244 rowcontextmenu
: 'openContextMenu',
251 title
: gettext('Spam Quarantine'),
252 xtype
: 'pmgQuarantineList',
253 selModel
: 'checkboxmodel',
254 emailSelection
: true,
261 model
: 'pmg-spam-list',
272 header
: gettext('Sender/Subject'),
273 dataIndex
: 'subject',
274 renderer
: PMG
.Utils
.sender_renderer
,
278 header
: gettext('Score'),
279 dataIndex
: 'spamlevel',
284 header
: gettext('Size') + ' (KB)',
285 renderer: function(v
) { return Ext
.Number
.toFixed(v
/1024, 0); },
291 header
: gettext('Date'),
297 header
: gettext('Time'),
304 title
: gettext('Selected Mail'),
308 reference
: 'preview',
318 text
: gettext('Toggle Raw'),
320 iconCls
: 'fa fa-file-code-o',
325 text
: gettext('Toggle Spam Info'),
327 iconCls
: 'fa fa-bullhorn',
332 reference
: 'download',
333 text
: gettext('Download'),
334 setDownload: function(id
) {
335 this.el
.dom
.download
= id
+ ".eml";
338 href
: '{downloadMailURL}',
339 download
: '{mailid}',
341 iconCls
: 'fa fa-download',
345 reference
: 'whitelist',
346 text
: gettext('Whitelist'),
347 iconCls
: 'fa fa-check',
348 handler
: 'btnHandler',
351 reference
: 'blacklist',
352 text
: gettext('Blacklist'),
353 iconCls
: 'fa fa-times',
354 handler
: 'btnHandler',
357 reference
: 'deliver',
358 text
: gettext('Deliver'),
359 iconCls
: 'fa fa-paper-plane-o',
360 handler
: 'btnHandler',
364 text
: gettext('Delete'),
365 iconCls
: 'fa fa-trash-o',
366 handler
: 'btnHandler',
371 xtype
: 'pmgSpamInfoGrid',
373 reference
: 'spaminfo',
376 xtype
: 'pmgMailInfo',
378 reference
: 'mailinfo',