]>
git.proxmox.com Git - pmg-gui.git/blob - js/MailTracker.js
ea544e226567b47e9fc40d2ca58f56fb65b2b419
1 Ext
.define('pmg-mail-tracker', {
2 extend
: 'Ext.data.Model',
4 'id' , 'from', 'to', 'dstatus', 'rstatus', 'qid', 'msgid', 'client',
5 { type
: 'number', name
: 'size' },
6 { type
: 'date', dateFormat
: 'timestamp', name
: 'time' }
15 Ext
.define('PMG.MailTrackerFilter', {
16 extend
: 'Ext.container.Container',
17 xtype
: 'pmgMailTrackerFilter',
25 xclass
: 'Ext.app.ViewController',
27 onFilterChange: function() {
28 var view
= this.getView();
29 view
.fireEvent('filterChanged');
32 onSpecialKey: function(field
, e
) {
33 if (e
.getKey() == e
.ENTER
) {
34 this.onFilterChange();
39 getFilterParams: function() {
43 var names
= ['from', 'target', 'xfilter', 'starttime', 'endtime', 'ndr', 'greylist'];
44 Ext
.Array
.each(names
, function(name
) {
45 var value
= me
.lookupReference(name
).getSubmitValue();
46 if (value
) { param
[name
] = value
; }
63 fieldLabel
: gettext('Sender'),
65 listeners
: { specialkey
: 'onSpecialKey' },
69 fieldLabel
: gettext('Receiver'),
71 listeners
: { specialkey
: 'onSpecialKey' },
75 fieldLabel
: gettext('Filter'),
77 listeners
: { specialkey
: 'onSpecialKey' },
92 fieldLabel
: gettext('Start'),
93 reference
: 'starttime',
94 listeners
: { change
: 'onFilterChange' },
97 return new Date(now
.getTime() - 3600000);
99 xtype
: 'promxoxDateTimeField'
102 fieldLabel
: gettext('End'),
103 reference
: 'endtime',
104 listeners
: { change
: 'onFilterChange' },
105 xtype
: 'promxoxDateTimeField'
112 boxLabel
: gettext('Include NDRs'),
113 xtype
: 'proxmoxcheckbox',
114 listeners
: { change
: 'onFilterChange' },
119 boxLabel
: gettext('Include Greylist'),
120 xtype
: 'proxmoxcheckbox',
121 listeners
: { change
: 'onFilterChange' },
122 margin
: { left
: 20 },
123 reference
: 'greylist',
133 Ext
.define('PMG.MaiLogWindow', {
134 extend
: 'Ext.window.Window',
135 xtype
: 'pmgMaiLogWindow',
137 title
: gettext('Syslog'),
140 starttime
: undefined,
154 Proxmox
.Utils
.API2Request({
156 params
: { starttime
: me
.starttime
, endtime
: me
.endtime
},
157 url
: '/nodes/' + Proxmox
.NodeName
+ '/tracker/' + me
.logid
,
159 failure: function(response
, opts
) {
160 me
.update(gettext('Error') + " " + response
.htmlStatus
);
162 success: function(response
, opts
) {
163 var data
= response
.result
.data
;
165 var logs
= "<pre style='margin: 0;'>";
166 Ext
.Array
.each(data
.logs
, function(line
) {
167 logs
+= Ext
.htmlEncode(line
) + "\n";
175 initComponent : function() {
179 throw "no logid specified";
183 throw "no starttime specified";
186 throw "no endtime specified";
191 me
.setHtml('Loading...');
196 Ext
.define('PMG.MailTracker', {
197 extend
: 'Ext.grid.GridPanel',
198 xtype
: 'pmgMailTracker',
200 title
: gettext('Tracking Center'),
204 emptyText
: gettext('No data in database.'),
205 disableSelection
: true,
208 deferEmptyText
: false,
209 enableTextSelection
: true,
210 getRowClass: function(record
, index
) {
211 var status
= record
.data
.rstatus
|| record
.data
.dstatus
;
212 return PMG
.Utils
.mail_status_map
[status
];
218 ptype
: 'rowexpander',
219 rowBodyTpl
: '<p class="logs">{logs}</p>',
225 model
: 'pmg-mail-tracker'
230 xclass
: 'Ext.app.ViewController',
232 onSearch: function() {
233 var view
= this.getView();
234 var filter
= this.lookupReference('filter');
235 var status
= this.lookupReference('status');
236 var params
= filter
.getFilterParams();
237 status
.update(''); // clear status before load
238 view
.store
.proxy
.setExtraParams(params
);
239 view
.store
.proxy
.setUrl('/api2/json/nodes/' + Proxmox
.NodeName
+ '/tracker');
240 view
.store
.load(function(records
, operation
, success
) {
241 var response
= operation
.getResponse();
243 // fixme: howto avoid duplicate Ext.decode ?
244 var result
= Ext
.decode(response
.responseText
);
245 if (result
.changes
) {
246 status
.update(result
.changes
);
252 showDetails: function(rowNode
, record
) {
253 var view
= this.getView();
255 var params
= view
.store
.proxy
.getExtraParams();
257 Proxmox
.Utils
.API2Request({
259 params
: { starttime
: params
.starttime
, endtime
: params
.endtime
},
260 url
: '/nodes/' + Proxmox
.NodeName
+ '/tracker/' + record
.data
.id
,
262 failure: function(response
, opts
) {
263 record
.set('logs',gettext('Error') + " " + response
.htmlStatus
);
265 success: function(response
, opts
) {
266 var data
= response
.result
.data
;
269 Ext
.Array
.each(data
.logs
, function(line
) {
270 logs
+= Ext
.htmlEncode(line
) + "<br>";
273 record
.set('logs', logs
);
280 expandbody
: 'showDetails'
287 xtype
: 'pmgMailTrackerFilter',
289 listeners
: { filterChanged
: 'onSearch' },
296 { text
: 'Search', handler
: 'onSearch' },
297 { xtype
: 'component', html
: '', reference
: 'status' }
305 header
: gettext('Time'),
311 header
: gettext('From'),
316 header
: gettext('To'),
321 header
: gettext('Status'),
323 renderer: function(v
, metaData
, rec
) {
324 var returntext
= 'unknown';
325 var icon
= 'question-circle';
326 var rstatus
= rec
.data
.rstatus
;
327 if (v
!== undefined && v
!== '') {
328 vtext
= PMG
.Utils
.mail_status_map
[v
] || v
;
330 if (rstatus
!== undefined && rstatus
!== '') {
331 rtext
= PMG
.Utils
.mail_status_map
[rstatus
] || rstatus
;
332 returntext
= vtext
+ '/' + rtext
;
334 } else if (rec
.data
.qid
!== undefined) {
335 returntext
= 'queued/' + vtext
;
341 return PMG
.Utils
.format_status_icon(icon
) + returntext
;
346 header
: gettext('Size'),
357 header
: gettext('Client'),
364 initComponent: function() {
369 Proxmox
.Utils
.monStoreErrors(me
.getView(), me
.store
);