--- /dev/null
+Ext.define('PMG.grid.AttachmentGrid',{
+ extend: 'Ext.grid.GridPanel',
+ xtype: 'pmgAttachmentGrid',
+
+ store: {
+ autoDestroy: true,
+ fields: [ 'name', 'content-type', 'size' ],
+ proxy: {
+ type: 'proxmox',
+ }
+ },
+
+ setID: function(rec) {
+ var me = this;
+ if (!rec || !rec.data || !rec.data.id) {
+ me.getStore().removeAll();
+ return;
+ }
+ var url = '/api2/json/quarantine/listattachments?id=' + rec.data.id;
+ me.mailid = rec.data.id;
+ me.store.proxy.setUrl(url);
+ me.store.load();
+ },
+
+ emptyText: gettext('No Attachments'),
+
+ download: function() {
+ alert(arguments);
+ },
+
+ columns: [
+ {
+ text: gettext('Filename'),
+ dataIndex: 'name',
+ flex: 1,
+ },
+ {
+ text: gettext('Filetype'),
+ dataIndex: 'content-type',
+ renderer: PMG.Utils.render_filetype,
+ flex: 1,
+ },
+ {
+ text: gettext('Size'),
+ renderer: Proxmox.Utils.format_size,
+ dataIndex: 'size',
+ flex: 1,
+ },
+ {
+ header: gettext('Download'),
+ renderer: function(value, mD, rec) {
+ var me = this;
+ let url = '/api2/json/quarantine/download';
+ url += '?mailid=' + me.mailid;
+ url += '&attachmentid=' + rec.data.id;
+ return "<a target='_blank' class='download' download='"+ rec.data.name +"' href='" +
+ url + "'><i class='fa fa-fw fa-download'</i></a>";
+ },
+ }
+ ]
+});
--- /dev/null
+/*global Proxmox*/
+/*jslint confusion: true*/
+/*format is a string and a function*/
+Ext.define('pmg-attachment-list', {
+ extend: 'Ext.data.Model',
+ fields: [ 'id', 'envelope_sender', 'from', 'sender', 'receiver', 'subject',
+ { type: 'integer', name: 'bytes' },
+ { type: 'date', dateFormat: 'timestamp', name: 'time' },
+ {
+ type: 'string',
+ name: 'day',
+ convert: function(v, rec) {
+ return Ext.Date.format(rec.get('time'), 'Y-m-d');
+ }, depends: ['time']
+ }
+ ],
+ proxy: {
+ type: 'proxmox',
+ url: "/api2/json/quarantine/attachment"
+ },
+ idProperty: 'id'
+});
+
+Ext.define('PMG.AttachmentQuarantine', {
+ extend: 'Ext.container.Container',
+ xtype: 'pmgAttachmentQuarantine',
+
+ border: false,
+ layout: { type: 'border' },
+
+ defaults: { border: false },
+
+ controller: {
+
+ xclass: 'Ext.app.ViewController',
+
+ updatePreview: function(raw, rec) {
+ var preview = this.lookupReference('preview');
+
+ if (!rec || !rec.data || !rec.data.id) {
+ preview.update('');
+ preview.setDisabled(true);
+ return;
+ }
+
+ var url = '/api2/htmlmail/quarantine/content?id=' + rec.data.id + ((raw)?'&raw=1':'');
+ preview.setDisabled(false);
+ preview.update("<iframe frameborder=0 width=100% height=100% sandbox='allow-same-origin' src='" + url +"'></iframe>");
+ },
+
+ toggleRaw: function(button) {
+ var me = this;
+ var list = this.lookupReference('list');
+ var rec = list.getSelection()[0] || {};
+ me.raw = !me.raw;
+ me.updatePreview(me.raw, rec);
+ },
+
+ btnHandler: function(button, e) {
+ var list = this.lookupReference('list');
+ var selected = list.getSelection();
+ if (!selected.length) {
+ return;
+ }
+
+ var action = button.reference;
+
+ PMG.Utils.doQuarantineAction(action, selected[0].data.id, function() {
+ list.getController().load();
+ });
+ },
+
+ onSelectMail: function() {
+ var me = this;
+ var list = this.lookupReference('list');
+ var rec = list.getSelection()[0] || {};
+
+ me.updatePreview(me.raw || false, rec);
+ this.lookupReference('attachmentlist').setID(rec);
+ },
+
+ control: {
+ 'button[reference=raw]': {
+ click: 'toggleRaw'
+ },
+ 'pmgQuarantineList': {
+ selectionChange: 'onSelectMail'
+ }
+ }
+
+ },
+
+ items: [
+ {
+ title: gettext('Attachment Quarantine'),
+ xtype: 'pmgQuarantineList',
+ emptyText: gettext('No data in database'),
+ emailSelection: false,
+ reference: 'list',
+ region: 'west',
+ width: 500,
+ split: true,
+ collapsible: false,
+ store: {
+ model: 'pmg-attachment-list',
+ groupField: 'day',
+ groupDir: 'DESC',
+ sorters: [{
+ property: 'time',
+ direction: 'DESC'
+ }]
+ },
+
+ columns: [
+ {
+ header: gettext('Sender/Subject'),
+ dataIndex: 'subject',
+ renderer: PMG.Utils.sender_renderer,
+ flex: 1
+ },
+ {
+ header: gettext('Size') + ' (KB)',
+ renderer: function(v) { return Ext.Number.toFixed(v/1024, 0); },
+ dataIndex: 'bytes',
+ align: 'right',
+ width: 90
+ },
+ {
+ header: gettext('Date'),
+ dataIndex: 'day',
+ hidden: true
+ },
+ {
+ xtype: 'datecolumn',
+ header: gettext('Time'),
+ dataIndex: 'time',
+ format: 'H:i:s'
+ }
+ ]
+ },
+ {
+ title: gettext('Selected Mail'),
+ border: false,
+ region: 'center',
+ split: true,
+ reference: 'preview',
+ disabled: true,
+ dockedItems: [
+ {
+ xtype: 'toolbar',
+ dock: 'top',
+ items: [
+ {
+ xtype: 'button',
+ reference: 'raw',
+ text: gettext('Toggle Raw'),
+ enableToggle: true,
+ iconCls: 'fa fa-file-code-o'
+ },
+ '->',
+ {
+ reference: 'deliver',
+ text: gettext('Deliver'),
+ iconCls: 'fa fa-paper-plane-o',
+ handler: 'btnHandler'
+ },
+ {
+ reference: 'delete',
+ text: gettext('Delete'),
+ iconCls: 'fa fa-trash-o',
+ handler: 'btnHandler'
+ }
+ ]
+ },
+ {
+ xtype: 'pmgAttachmentGrid',
+ minHeight: 50,
+ maxHeight: 250,
+ scrollable: true,
+ reference: 'attachmentlist',
+ }
+ ]
+ }
+ ]
+});