mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-19 04:19:28 +01:00
fix redirect loop initiated eg. by saving a mail, caused by document.location=url triggering etemplate unload handler and destroying et2 request, identical redirect url detected by jdots framework causes refresh via nextmatch --> next redirect
This commit is contained in:
parent
bf51e940b0
commit
7f619fe32d
@ -177,6 +177,8 @@ class etemplate_request
|
|||||||
list($app) = explode('.', $_GET['menuaction']);
|
list($app) = explode('.', $_GET['menuaction']);
|
||||||
$index_url = isset($GLOBALS['egw_info']['apps'][$app]['index']) ?
|
$index_url = isset($GLOBALS['egw_info']['apps'][$app]['index']) ?
|
||||||
'/index.php?menuaction='.$GLOBALS['egw_info']['apps'][$app]['index'] : '/'.$app.'/index.php';
|
'/index.php?menuaction='.$GLOBALS['egw_info']['apps'][$app]['index'] : '/'.$app.'/index.php';
|
||||||
|
// add a unique token to redirect to avoid client-side framework tries refreshing via nextmatch
|
||||||
|
$index_url .= (strpos($index_url, '?') ? '&' : '?').'redirect='.microtime(true);
|
||||||
error_log(__METHOD__."('$id', ...) eT2 request not found / expired --> redirecting app $app to $index_url (_GET[menuaction]=$_GET[menuaction], isJSONRequest()=".array2string(egw_json_request::isJSONRequest()).')');
|
error_log(__METHOD__."('$id', ...) eT2 request not found / expired --> redirecting app $app to $index_url (_GET[menuaction]=$_GET[menuaction], isJSONRequest()=".array2string(egw_json_request::isJSONRequest()).')');
|
||||||
if (egw_json_request::isJSONRequest())
|
if (egw_json_request::isJSONRequest())
|
||||||
{
|
{
|
||||||
|
@ -113,7 +113,7 @@ var et2_nextmatch = et2_DOMWidget.extend([et2_IResizeable, et2_IInput],
|
|||||||
"description": "Hide the second filter",
|
"description": "Hide the second filter",
|
||||||
"default": et2_no_init,
|
"default": et2_no_init,
|
||||||
},
|
},
|
||||||
|
|
||||||
"onselect": {
|
"onselect": {
|
||||||
"name": "onselect",
|
"name": "onselect",
|
||||||
"type": "js",
|
"type": "js",
|
||||||
@ -206,7 +206,7 @@ var et2_nextmatch = et2_DOMWidget.extend([et2_IResizeable, et2_IInput],
|
|||||||
// Unbind handler used for toggling autorefresh
|
// Unbind handler used for toggling autorefresh
|
||||||
$j(this.getInstanceManager().DOMContainer.parentNode).off('show.et2_nextmatch');
|
$j(this.getInstanceManager().DOMContainer.parentNode).off('show.et2_nextmatch');
|
||||||
$j(this.getInstanceManager().DOMContainer.parentNode).off('hide.et2_nextmatch');
|
$j(this.getInstanceManager().DOMContainer.parentNode).off('hide.et2_nextmatch');
|
||||||
|
|
||||||
// Free the grid components
|
// Free the grid components
|
||||||
this.dataview.free();
|
this.dataview.free();
|
||||||
this.rowProvider.free();
|
this.rowProvider.free();
|
||||||
@ -303,10 +303,14 @@ var et2_nextmatch = et2_DOMWidget.extend([et2_IResizeable, et2_IInput],
|
|||||||
* Implements the et2_IResizeable interface - lets the dynheight manager
|
* Implements the et2_IResizeable interface - lets the dynheight manager
|
||||||
* update the width and height and then update the dataview container.
|
* update the width and height and then update the dataview container.
|
||||||
*/
|
*/
|
||||||
resize: function() {
|
resize: function()
|
||||||
this.dynheight.update(function(_w, _h) {
|
{
|
||||||
this.dataview.resize(_w, _h);
|
if (this.dynheight)
|
||||||
}, this);
|
{
|
||||||
|
this.dynheight.update(function(_w, _h) {
|
||||||
|
this.dataview.resize(_w, _h);
|
||||||
|
}, this);
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -731,7 +735,7 @@ var et2_nextmatch = et2_DOMWidget.extend([et2_IResizeable, et2_IInput],
|
|||||||
if(this.options.settings.columnselection_pref && app)
|
if(this.options.settings.columnselection_pref && app)
|
||||||
{
|
{
|
||||||
var size_pref = this.options.settings.columnselection_pref +"-size";
|
var size_pref = this.options.settings.columnselection_pref +"-size";
|
||||||
|
|
||||||
// If columnselection pref is missing prefix, add it in
|
// If columnselection pref is missing prefix, add it in
|
||||||
if(size_pref.indexOf('nextmatch') == -1)
|
if(size_pref.indexOf('nextmatch') == -1)
|
||||||
{
|
{
|
||||||
@ -902,7 +906,7 @@ var et2_nextmatch = et2_DOMWidget.extend([et2_IResizeable, et2_IInput],
|
|||||||
var oldCols = this.activeFilters.selectcols ? this.activeFilters.selectcols : [];
|
var oldCols = this.activeFilters.selectcols ? this.activeFilters.selectcols : [];
|
||||||
|
|
||||||
this.activeFilters.selectcols = colDisplay;
|
this.activeFilters.selectcols = colDisplay;
|
||||||
|
|
||||||
// We don't need to re-query if they've removed a column
|
// We don't need to re-query if they've removed a column
|
||||||
var changed = [];
|
var changed = [];
|
||||||
ColLoop:
|
ColLoop:
|
||||||
@ -1094,7 +1098,7 @@ var et2_nextmatch = et2_DOMWidget.extend([et2_IResizeable, et2_IInput],
|
|||||||
this.options.settings.dataStorePrefix = list[0];
|
this.options.settings.dataStorePrefix = list[0];
|
||||||
}
|
}
|
||||||
this.controller.setPrefix(this.options.settings.dataStorePrefix);
|
this.controller.setPrefix(this.options.settings.dataStorePrefix);
|
||||||
|
|
||||||
// Load the initial order
|
// Load the initial order
|
||||||
/*this.controller.loadInitialOrder(this._getInitialOrder(
|
/*this.controller.loadInitialOrder(this._getInitialOrder(
|
||||||
this.options.settings.rows, this.options.settings.row_id
|
this.options.settings.rows, this.options.settings.row_id
|
||||||
@ -1437,7 +1441,7 @@ var et2_nextmatch = et2_DOMWidget.extend([et2_IResizeable, et2_IInput],
|
|||||||
this._autorefresh_timer = setTimeout(jQuery.proxy(function() {
|
this._autorefresh_timer = setTimeout(jQuery.proxy(function() {
|
||||||
// Check in case it was stopped / destroyed since
|
// Check in case it was stopped / destroyed since
|
||||||
if(!this._autorefresh_timer || !this.getInstanceManager()) return;
|
if(!this._autorefresh_timer || !this.getInstanceManager()) return;
|
||||||
|
|
||||||
$j(this.getInstanceManager().DOMContainer.parentNode).one('show.et2_nextmatch',
|
$j(this.getInstanceManager().DOMContainer.parentNode).one('show.et2_nextmatch',
|
||||||
// Important to use anonymous function instead of just 'this.refresh' because
|
// Important to use anonymous function instead of just 'this.refresh' because
|
||||||
// of the parameters passed
|
// of the parameters passed
|
||||||
@ -1621,7 +1625,7 @@ var et2_nextmatch = et2_DOMWidget.extend([et2_IResizeable, et2_IInput],
|
|||||||
this.resize();
|
this.resize();
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Actions are handled by the controller, so ignore these during init.
|
* Actions are handled by the controller, so ignore these during init.
|
||||||
*
|
*
|
||||||
|
@ -123,7 +123,7 @@ etemplate2.prototype.resize = function()
|
|||||||
etemplate2.prototype.clear = function()
|
etemplate2.prototype.clear = function()
|
||||||
{
|
{
|
||||||
$j(this.DOMContainer).trigger('clear');
|
$j(this.DOMContainer).trigger('clear');
|
||||||
|
|
||||||
// Remove any handlers on window (resize)
|
// Remove any handlers on window (resize)
|
||||||
if(this.uniqueId)
|
if(this.uniqueId)
|
||||||
{
|
{
|
||||||
@ -245,6 +245,22 @@ etemplate2.prototype.unbind_unload = function()
|
|||||||
delete this.destroy_session;
|
delete this.destroy_session;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Download a URL not triggering our unload handler and therefore destroying our et2 request
|
||||||
|
*
|
||||||
|
* @param {string} _url
|
||||||
|
*/
|
||||||
|
etemplate2.prototype.download = function(_url)
|
||||||
|
{
|
||||||
|
// need to unbind unload handler to NOT destroy et2 session
|
||||||
|
this.unbind_unload();
|
||||||
|
|
||||||
|
document.location = _url;
|
||||||
|
|
||||||
|
// bind unload handler again (can NOT do it direct, as this would be quick enough to be still triggered!)
|
||||||
|
window.setTimeout(jQuery.proxy(this.bind_unload, this), 100);
|
||||||
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Loads the template from the given URL and sets the data object
|
* Loads the template from the given URL and sets the data object
|
||||||
*
|
*
|
||||||
|
@ -2158,7 +2158,7 @@ app.classes.mail = AppJS.extend(
|
|||||||
url += 'menuaction=mail.mail_ui.saveMessage'; // todo compose for Draft folder
|
url += 'menuaction=mail.mail_ui.saveMessage'; // todo compose for Draft folder
|
||||||
url += '&id='+_elems[0].id;
|
url += '&id='+_elems[0].id;
|
||||||
//window.open(url,'_blank','dependent=yes,width=100,height=100,scrollbars=yes,status=yes');
|
//window.open(url,'_blank','dependent=yes,width=100,height=100,scrollbars=yes,status=yes');
|
||||||
document.location = url;
|
this.et2._inst.download(url);
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -2294,8 +2294,7 @@ app.classes.mail = AppJS.extend(
|
|||||||
windowName = windowName+'displayAttachment_'+mailid+'_'+attgrid.partID;
|
windowName = windowName+'displayAttachment_'+mailid+'_'+attgrid.partID;
|
||||||
width = 870;
|
width = 870;
|
||||||
height = 600;
|
height = 600;
|
||||||
//document.location = url;
|
break;
|
||||||
//return;
|
|
||||||
}
|
}
|
||||||
egw_openWindowCentered(url,windowName,width,height);
|
egw_openWindowCentered(url,windowName,width,height);
|
||||||
},
|
},
|
||||||
@ -2402,8 +2401,7 @@ app.classes.mail = AppJS.extend(
|
|||||||
windowName = windowName+'displayAttachment_'+attgrid.file.replace(/\//g,"_");
|
windowName = windowName+'displayAttachment_'+attgrid.file.replace(/\//g,"_");
|
||||||
width = 870;
|
width = 870;
|
||||||
height = 600;
|
height = 600;
|
||||||
//document.location = url;
|
break;
|
||||||
//return;
|
|
||||||
}
|
}
|
||||||
egw_openWindowCentered(url,windowName,width,height);
|
egw_openWindowCentered(url,windowName,width,height);
|
||||||
},
|
},
|
||||||
@ -2425,15 +2423,12 @@ app.classes.mail = AppJS.extend(
|
|||||||
attgrid = this.et2.getArrayMgr("content").getEntry('mail_displayattachments')[widget.id.replace(/\[save\]/,'')];
|
attgrid = this.et2.getArrayMgr("content").getEntry('mail_displayattachments')[widget.id.replace(/\[save\]/,'')];
|
||||||
}
|
}
|
||||||
var url = window.egw_webserverUrl+'/index.php?';
|
var url = window.egw_webserverUrl+'/index.php?';
|
||||||
var width;
|
|
||||||
var height;
|
|
||||||
var windowName ='mail';
|
|
||||||
url += 'menuaction=mail.mail_ui.getAttachment'; // todo compose for Draft folder
|
url += 'menuaction=mail.mail_ui.getAttachment'; // todo compose for Draft folder
|
||||||
url += '&mode=save';
|
url += '&mode=save';
|
||||||
url += '&id='+mailid;
|
url += '&id='+mailid;
|
||||||
url += '&part='+attgrid.partID;
|
url += '&part='+attgrid.partID;
|
||||||
url += '&is_winmail='+attgrid.winmailFlag;
|
url += '&is_winmail='+attgrid.winmailFlag;
|
||||||
document.location = url;
|
this.et2._inst.download(url);
|
||||||
},
|
},
|
||||||
|
|
||||||
saveAllAttachmentsToZip: function(tag_info, widget)
|
saveAllAttachmentsToZip: function(tag_info, widget)
|
||||||
@ -2453,13 +2448,10 @@ app.classes.mail = AppJS.extend(
|
|||||||
attgrid = this.et2.getArrayMgr("content").getEntry('mail_displayattachments')[widget.id.replace(/\[save\]/,'')];
|
attgrid = this.et2.getArrayMgr("content").getEntry('mail_displayattachments')[widget.id.replace(/\[save\]/,'')];
|
||||||
}
|
}
|
||||||
var url = window.egw_webserverUrl+'/index.php?';
|
var url = window.egw_webserverUrl+'/index.php?';
|
||||||
var width;
|
|
||||||
var height;
|
|
||||||
var windowName ='mail';
|
|
||||||
url += 'menuaction=mail.mail_ui.download_zip'; // todo compose for Draft folder
|
url += 'menuaction=mail.mail_ui.download_zip'; // todo compose for Draft folder
|
||||||
url += '&mode=save';
|
url += '&mode=save';
|
||||||
url += '&id='+mailid;
|
url += '&id='+mailid;
|
||||||
document.location = url;
|
this.et2._inst.download(url);
|
||||||
},
|
},
|
||||||
|
|
||||||
saveAttachmentToVFS: function(tag_info, widget)
|
saveAttachmentToVFS: function(tag_info, widget)
|
||||||
@ -2557,8 +2549,6 @@ app.classes.mail = AppJS.extend(
|
|||||||
url += '&method=mail.mail_ui.vfsSaveMessage';
|
url += '&method=mail.mail_ui.vfsSaveMessage';
|
||||||
url += '&id='+_elems[0].id;
|
url += '&id='+_elems[0].id;
|
||||||
url += '&label=Save';
|
url += '&label=Save';
|
||||||
//window.open(url,'_blank','dependent=yes,width=100,height=100,scrollbars=yes,status=yes')
|
|
||||||
//document.location = url;
|
|
||||||
egw_openWindowCentered(url,'vfs_save_message_'+_elems[0].id,'640','570',window.outerWidth/2,window.outerHeight/2);
|
egw_openWindowCentered(url,'vfs_save_message_'+_elems[0].id,'640','570',window.outerWidth/2,window.outerHeight/2);
|
||||||
|
|
||||||
},
|
},
|
||||||
|
Loading…
Reference in New Issue
Block a user