]>
git.proxmox.com Git - pmg-gui.git/blob - js/SpamQuarantine.js
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]);
166 list
.getController().restoreSavedSelection();
170 onSelectMail: function() {
172 var list
= this.lookupReference('list');
173 var selection
= list
.selModel
.getSelection();
174 if (selection
.length
> 1) {
175 me
.multiSelect(selection
);
179 var rec
= selection
[0] || {};
181 me
.getViewModel().set('mailid', rec
.data
? rec
.data
.id
: '');
182 me
.updatePreview(me
.raw
|| false, rec
);
183 me
.lookupReference('spaminfo').setID(rec
);
184 me
.lookupReference('mailinfo').setVisible(!!rec
.data
&& !me
.raw
);
185 me
.lookupReference('mailinfo').update(rec
.data
);
188 toggleSpamInfo: function(btn
) {
189 var grid
= this.lookupReference('spaminfo');
190 grid
.setVisible(!grid
.isVisible());
193 openContextMenu: function(table
, record
, tr
, index
, event
) {
196 let list
= me
.lookup('list');
197 Ext
.create('PMG.menu.SpamContextMenu', {
198 callback
: action
=> me
.doAction(action
, list
.getSelection()),
199 }).showAt(event
.getXY());
202 keyPress: function(table
, record
, item
, index
, event
) {
204 var list
= me
.lookup('list');
205 var key
= event
.getKey();
212 case Ext
.event
.Event
.D
:
213 case Ext
.event
.Event
.D
+ 32:
216 case Ext
.event
.Event
.W
:
217 case Ext
.event
.Event
.W
+ 32:
218 action
= 'whitelist';
220 case Ext
.event
.Event
.B
:
221 case Ext
.event
.Event
.B
+ 32:
222 action
= 'blacklist';
227 me
.doAction(action
, list
.getSelection());
231 init: function(view
) {
232 this.lookup('list').cselect
= view
.cselect
;
236 'button[reference=raw]': {
239 'button[reference=spam]': {
240 click
: 'toggleSpamInfo',
242 'pmgQuarantineList': {
243 selectionChange
: 'onSelectMail',
244 itemkeypress
: 'keyPress',
245 rowcontextmenu
: 'openContextMenu',
252 title
: gettext('Spam Quarantine'),
253 xtype
: 'pmgQuarantineList',
254 selModel
: 'checkboxmodel',
255 emailSelection
: true,
262 model
: 'pmg-spam-list',
273 header
: gettext('Sender/Subject'),
274 dataIndex
: 'subject',
275 renderer
: PMG
.Utils
.sender_renderer
,
279 header
: gettext('Score'),
280 dataIndex
: 'spamlevel',
285 header
: gettext('Size') + ' (KB)',
286 renderer: function(v
) { return Ext
.Number
.toFixed(v
/1024, 0); },
292 header
: gettext('Date'),
298 header
: gettext('Time'),
305 title
: gettext('Selected Mail'),
309 reference
: 'preview',
319 text
: gettext('Toggle Raw'),
321 iconCls
: 'fa fa-file-code-o',
326 text
: gettext('Toggle Spam Info'),
328 iconCls
: 'fa fa-bullhorn',
333 reference
: 'download',
334 text
: gettext('Download'),
335 setDownload: function(id
) {
336 this.el
.dom
.download
= id
+ ".eml";
339 href
: '{downloadMailURL}',
340 download
: '{mailid}',
342 iconCls
: 'fa fa-download',
346 reference
: 'whitelist',
347 text
: gettext('Whitelist'),
348 iconCls
: 'fa fa-check',
349 handler
: 'btnHandler',
352 reference
: 'blacklist',
353 text
: gettext('Blacklist'),
354 iconCls
: 'fa fa-times',
355 handler
: 'btnHandler',
358 reference
: 'deliver',
359 text
: gettext('Deliver'),
360 iconCls
: 'fa fa-paper-plane-o',
361 handler
: 'btnHandler',
365 text
: gettext('Delete'),
366 iconCls
: 'fa fa-trash-o',
367 handler
: 'btnHandler',
372 xtype
: 'pmgSpamInfoGrid',
374 reference
: 'spaminfo',
377 xtype
: 'pmgMailInfo',
379 reference
: 'mailinfo',