]> git.proxmox.com Git - pmg-gui.git/blobdiff - js/PostfixMailQueue.js
remove BETA, do not display repoid
[pmg-gui.git] / js / PostfixMailQueue.js
index e887322e1ce6c77806cd3cf0a393872730f445d9..101a43b91b36a0e1fe723e64c9a807dc969a5f06 100644 (file)
@@ -1,3 +1,4 @@
+/*global Proxmox*/
 Ext.define('pmg-mailq', {
     extend: 'Ext.data.Model',
     fields: [
@@ -13,9 +14,12 @@ Ext.define('PMG.Postfix.MailQueue', {
     extend: 'Ext.grid.GridPanel',
     alias: 'widget.pmgPostfixMailQueue',
 
-    nodename : undefined,
+    nodename: undefined,
+
     filter: undefined,
 
+    queuename: 'deferred',
+
     store: {
        xclass: 'Ext.data.BufferedStore',
        model: 'pmg-mailq',
@@ -28,7 +32,9 @@ Ext.define('PMG.Postfix.MailQueue', {
        xclass: 'Ext.app.ViewController',
 
        init: function(view) {
-           if (view.nodename) view.setNodename(view.nodename);
+           if (view.nodename) {
+               view.setNodename(view.nodename);
+           }
 
            view.delayFilterTask = new Ext.util.DelayedTask(function() {
                var filter = view.lookupReference('filter').getValue();
@@ -43,10 +49,59 @@ Ext.define('PMG.Postfix.MailQueue', {
            view.delayFilterTask.delay(500);
        },
 
+       onFlush: function(button, event, rec) {
+           var view = this.getView();
+
+           Proxmox.Utils.API2Request({
+               url: '/api2/extjs/nodes/' + view.nodename + '/postfix/queue/' +
+                   view.queuename + '/' + rec.data.queue_id,
+               method: 'POST',
+               waitMsgTarget: view,
+               failure: function (response, opts) {
+                   Ext.Msg.alert(gettext('Error'), response.htmlStatus);
+               }
+           });
+
+       },
+
+       onRemove: function(button, event, rec) {
+           var view = this.getView();
+
+           Proxmox.Utils.API2Request({
+               url: '/api2/extjs/nodes/' + view.nodename + '/postfix/queue/' +
+                   view.queuename + '/' + rec.data.queue_id,
+               method: 'DELETE',
+               waitMsgTarget: view,
+               success: function(response, opts) {
+                   view.selModel.deselectAll();
+                   view.store.load();
+               },
+               failure: function (response, opts) {
+                   Ext.Msg.alert(gettext('Error'), response.htmlStatus);
+               }
+           });
+       },
+
+       onHeaders: function(button, event, rec) {
+           var view = this.getView();
+
+           var url = '/api2/extjs/nodes/' + view.nodename + '/postfix/queue/' +
+               view.queuename + '/' + rec.data.queue_id;
+
+           var win = Ext.create('PMG.ViewMailHeaders', {
+               title: view.title + ' : ' + rec.data.queue_id,
+               url: url
+           });
+           win.show();
+       },
+
        control: {
            '#': {
                activate: function() {
                    this.view.updateProxy(); // reload
+               },
+               itemdblclick: function(grid, rec, item, index, event) {
+                   this.onHeaders(grid, event, rec);
                }
            },
            'field[reference=filter]': {
@@ -56,6 +111,22 @@ Ext.define('PMG.Postfix.MailQueue', {
     },
 
     tbar: [
+       {
+           xtype: 'proxmoxButton',
+           disabled: true,
+           text: gettext('Headers'),
+           handler: 'onHeaders'
+       },
+       {
+           xtype: 'proxmoxButton',
+           disabled: true,
+           text: gettext('Flush'),
+           handler: 'onFlush'
+       },
+       {
+           xtype: 'proxmoxStdRemoveButton',
+           handler: 'onRemove'
+       },
        {
            xtype: 'label',
            html: gettext('Filter') + ':'
@@ -101,17 +172,20 @@ Ext.define('PMG.Postfix.MailQueue', {
     updateProxy: function() {
        var me = this;
 
-       if (me.pendingLoad) return;
+       if (me.pendingLoad) {
+           return;
+       }
 
        var proxy = {
            type: 'proxmox',
            startParam: 'start',
            limitParam: 'limit',
-           url: "/api2/json/nodes/" + me.nodename + "/postfix/mailq"
+           url: "/api2/json/nodes/" + me.nodename + "/postfix/queue/" + me.queuename
        };
 
        var filter = me.filter;
        var nodename = me.nodename;
+       var queuename = me.queuename;
 
        if (filter) { proxy.extraParams = { filter: filter }; }
 
@@ -122,7 +196,7 @@ Ext.define('PMG.Postfix.MailQueue', {
 
        me.store.load(function() {
            me.pendingLoad = false;
-           if (me.nodename != nodename || me.filter != filter) {
+           if (me.nodename !== nodename || me.filter !== filter || me.queuename !== queuename) {
                setTimeout(function() {
                    me.updateProxy();
                }, 100);
@@ -139,6 +213,14 @@ Ext.define('PMG.Postfix.MailQueue', {
 
        me.nodename = nodename;
 
+       me.updateProxy();
+    },
+
+    setQueueName: function(queuename) {
+       var me = this;
+
+       me.queuename = queuename;
+
        me.updateProxy();
     }