From 1e2e5a7e0a085067371fd763fe016ef4665d6414 Mon Sep 17 00:00:00 2001 From: dheeyi Date: Wed, 22 Apr 2015 17:54:58 -0400 Subject: [PATCH 1/2] =?UTF-8?q?PM-1879=200015808:=20Incorrect=20messages?= =?UTF-8?q?=20handling=20and/or=20actions=20when=20the=20user's=20session?= =?UTF-8?q?=20expires=20in=20the=20DESIGNER=20module=200016086:=20Informat?= =?UTF-8?q?ion=20of=20templates=20lost.=20Causa=20:=20Esto=20fue=20debido?= =?UTF-8?q?=20a=20que=20no=20se=20tenia=20una=20validacion=20de=20perdida?= =?UTF-8?q?=20de=20session.=20Soluci=C3=B3=20Aplica=20a=20secci=C3=B3roces?= =?UTF-8?q?s=20Files=20Manager)=20=20para=20el=20antiguo=20dise=C3=B1r,=20?= =?UTF-8?q?a=20la=20cual=20se=20considera=20todos=20los=20posibles=20casos?= =?UTF-8?q?=20de=20perdida=20de=20session=20haciendo=20una=20validaci?= =?UTF-8?q?=C3=B3ara=20todo=20estas=20situaciones.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../methods/processes/processes_Ajax.php | 7 + .../processes/processes_FilesOptions.xml | 331 +++++++++++++----- 2 files changed, 246 insertions(+), 92 deletions(-) diff --git a/workflow/engine/methods/processes/processes_Ajax.php b/workflow/engine/methods/processes/processes_Ajax.php index 484d8fbe2..17a4ab221 100755 --- a/workflow/engine/methods/processes/processes_Ajax.php +++ b/workflow/engine/methods/processes/processes_Ajax.php @@ -789,6 +789,13 @@ try { echo 'saved: ' . $sDirectory; } break; + case 'getSessid': + if(isset($_SESSION['USER_LOGGED'])){ + echo Bootstrap::json_encode(1); + }else{ + echo Bootstrap::json_encode(0); + } + break; case 'events': $oProcessMap->eventsList($oData->pro_uid, $oData->type); break; diff --git a/workflow/engine/xmlform/processes/processes_FilesOptions.xml b/workflow/engine/xmlform/processes/processes_FilesOptions.xml index 5fdfe43a5..859470d68 100755 --- a/workflow/engine/xmlform/processes/processes_FilesOptions.xml +++ b/workflow/engine/xmlform/processes/processes_FilesOptions.xml @@ -16,64 +16,185 @@ var CURRENT_MAIN_DIRECTORY; var CURRENT_CURRENT_DIRECTORY; var oUploadFilesPanel; var oUploadFilesPanel; +var showPromptLogin = function(lastAction) { + lastActionPerformed = lastAction; + promptPanel = new leimnud.module.panel(); + promptPanel.options={ + statusBarButtons:[{value: _('LOGIN')}], + position:{center:true}, + size:{w:370,h:160}, + control:{ + close:false, + resize:false + }, + fx:{ + modal:true + } + }; + promptPanel.setStyle={ + content:{ + padding:10, + paddingBottom:2, + textAlign:'left', + paddingLeft:24, + backgroundRepeat:'no-repeat', + backgroundPosition:'10 50%', + backgroundColor:'transparent', + borderWidth:0 + } + }; + promptPanel.make(); + promptPanel.addContent(_('ID_FILES_MANAGER_EDITOR_LOGIN_AGAIN')); + promptPanel.addContent('
'); + var label = document.createElement("label"); + var theUser = document.createElement("input"); + theUser.title = 'Username'; + theUser.id = 'theUser'; + leimnud.dom.setStyle(theUser,{ + font:'normal 10pt Tahoma,MiscFixed', + color:'#000', + width:'75%', + marginTop:3, + backgroundColor:'white', + border:'1px solid #919B9C', + }); + label.appendChild(theUser); + label.innerHTML = (_('ID_USERNAME')) + ': '; + promptPanel.addContent(label); + promptPanel.addContent(theUser); + theUser.focus(); + var labelpass = document.createElement("label"); + var thePassword = document.createElement("input"); + thePassword.type = 'password'; + thePassword.id = 'thePassword'; + leimnud.dom.setStyle(thePassword,{ + font:'normal 10pt Tahoma,MiscFixed', + color:'#000', + width:'76%', + marginTop:3, + backgroundColor:'white', + border:'1px solid #919B9C' + }); + labelpass.appendChild(thePassword); + labelpass.innerHTML = (_('ID_FIELD_DYNAFORM_PASSWORD')) +': '; + promptPanel.addContent(labelpass); + promptPanel.addContent(thePassword); + thePassword.onkeyup=function(evt) + { + var evt = (window.event)?window.event:evt; + var key = (evt.which)?evt.which:evt.keyCode; + if(key == 13) { + verifyLogin(); + } + }.extend(this); + promptPanel.fixContent(); + promptPanel.elements.statusBarButtons[0].onmouseup = verifyLogin; +}; +var verifyLogin = function() { + if (document.getElementById('thePassword').value.trim() == '') { + new leimnud.module.app.alert().make({ + label: (_('ID_WRONG_USER_PASS')) + }); + return; + } + var rpc = new leimnud.module.rpc.xmlhttp({ + url : '../login/authentication', + args: 'form[USR_USERNAME]=' + document.getElementById('theUser').value.trim() + '&form[USR_PASSWORD]=' + document.getElementById('thePassword').value.trim() + '&form[USR_LANG]=' + window.location.href.split("/")[4] + }); + rpc.callback = function(rpc) { + if (rpc.xmlhttp.responseText.indexOf('form[USR_USERNAME]') == -1) { + promptPanel.remove(); + lastActionPerformed = ''; + } else { + new leimnud.module.app.alert().make({ + label: (_('ID_WRONG_USER_PASS')) + }); + } + }.extend(this); + rpc.make(); +}; var uploadFilesScreen = function(PRO_UID, MAIN_DIRECTORY, CURRENT_DIRECTORY) { + var oRPC = new leimnud.module.rpc.xmlhttp({ + url : 'processes_Ajax', + args: 'action=getSessid&filename=filename' + }); - var swNavigator; - if(navigator.appName=='Microsoft Internet Explorer'){ - var rv = ''; - if (new RegExp("MSIE ([0-9]{1,}[\.0-9]{0,})").exec(navigator.userAgent) != null) { - rv = parseFloat(RegExp.$1); + oRPC.callback = function(rpc) { + if(rpc.xmlhttp.response==0){ + showPromptLogin('session'); + }else{ + var swNavigator; + if(navigator.appName=='Microsoft Internet Explorer'){ + var rv = ''; + if (new RegExp("MSIE ([0-9]{1,}[\.0-9]{0,})").exec(navigator.userAgent) != null) { + rv = parseFloat(RegExp.$1); + } + + if (rv >= 9) { + swNavigator='ie9+'; + } + else { + swNavigator='ie'; + } + + wd = 420; + hg = 170; + } else { + swNavigator='wknormal'; + wd=420; + hg=100; + } + + CURRENT_MAIN_DIRECTORY = MAIN_DIRECTORY; + CURRENT_CURRENT_DIRECTORY = CURRENT_DIRECTORY; + + Pm.tmp.processFilesManagerPanel.events = { + remove: function() { oUploadFilesPanel.remove(); }.extend(this) + }; + + oUploadFilesPanel = new leimnud.module.panel(); + oUploadFilesPanel.options={ + limit : true, + size : {w:wd,h:hg}, + position : {x:Pm.tmp.processFilesManagerPanel.options.position.x,y:Pm.tmp.processFilesManagerPanel.options.position.y-90,center:false}, + title : '', + control : {close:true,resize:false},fx:{modal:true}, + fx : {shadow:true,modal:true} + }; + oUploadFilesPanel.make(); + oIFrame = window.document.createElement('iframe'); + oIFrame.style.border = '0'; + oIFrame.style.width = '100%'; + oIFrame.style.height = '100%'; + oIFrame.src = 'processes_UploadFilesForm?PRO_UID=' + PRO_UID + '&MAIN_DIRECTORY=' + MAIN_DIRECTORY + '&CURRENT_DIRECTORY=' + CURRENT_DIRECTORY+'&NAVIGATOR='+swNavigator; + oUploadFilesPanel.addContent(oIFrame); } - - if (rv >= 9) { - swNavigator='ie9+'; - } - else { - swNavigator='ie'; - } - - wd = 420; - hg = 170; - } else { - swNavigator='wknormal'; - wd=420; - hg=100; - } - - CURRENT_MAIN_DIRECTORY = MAIN_DIRECTORY; - CURRENT_CURRENT_DIRECTORY = CURRENT_DIRECTORY; - - Pm.tmp.processFilesManagerPanel.events = { - remove: function() { oUploadFilesPanel.remove(); }.extend(this) - }; - - oUploadFilesPanel = new leimnud.module.panel(); - oUploadFilesPanel.options={ - limit : true, - size : {w:wd,h:hg}, - position : {x:Pm.tmp.processFilesManagerPanel.options.position.x,y:Pm.tmp.processFilesManagerPanel.options.position.y-90,center:false}, - title : '', - control : {close:true,resize:false},fx:{modal:true}, - fx : {shadow:true,modal:true} - }; - oUploadFilesPanel.make(); - oIFrame = window.document.createElement('iframe'); - oIFrame.style.border = '0'; - oIFrame.style.width = '100%'; - oIFrame.style.height = '100%'; - oIFrame.src = 'processes_UploadFilesForm?PRO_UID=' + PRO_UID + '&MAIN_DIRECTORY=' + MAIN_DIRECTORY + '&CURRENT_DIRECTORY=' + CURRENT_DIRECTORY+'&NAVIGATOR='+swNavigator; - oUploadFilesPanel.addContent(oIFrame); + }.extend(this); + oRPC.make(); }; var oPanel; function editFile(pro_uid, fileName){ + + var oRPC = new leimnud.module.rpc.xmlhttp({ + url : 'processes_Ajax', + args: 'action=getSessid&filename='+fileName + }); + + oRPC.callback = function(rpc) { + if(rpc.xmlhttp.response==0){ + showPromptLogin('session'); + } + }.extend(this); + oRPC.make(); + var typofile = fileName.split("."); if( typofile[typofile.length-1].toLowerCase() != 'txt' && typofile[typofile.length-1].toLowerCase() != 'html' ){ msgBox(G_STRINGS.HTML_FILES,"alert");return; } - oPanel = new leimnud.module.panel(); - oPanel.options={ + oPanel = new leimnud.module.panel(); + oPanel.options={ limit: true, size: {w: 820, h: 500}, position: {x: 50, y: 50, center: true}, @@ -81,68 +202,94 @@ function editFile(pro_uid, fileName){ control: {close: true, resize: false}, statusBar: true, fx: {shadow: true, modal: true} - }; - oPanel.make(); + }; + oPanel.make(); - var oRPC = new leimnud.module.rpc.xmlhttp({ - url : 'processes_Ajax', - args: 'action=editFile&filename='+fileName+'&pro_uid='+pro_uid - }); + var oRPC = new leimnud.module.rpc.xmlhttp({ + url : 'processes_Ajax', + args: 'action=editFile&filename='+fileName+'&pro_uid='+pro_uid + }); - oPanel.loader.show(); - oRPC.callback = function(rpc) { - oPanel.loader.hide(); - oPanel.addContent(rpc.xmlhttp.responseText); - var scs=rpc.xmlhttp.responseText.extractScript(); - scs.evalScript(); - }.extend(this); - oRPC.make(); + oPanel.loader.show(); + oRPC.callback = function(rpc) { + oPanel.loader.hide(); + oPanel.addContent(rpc.xmlhttp.responseText); + var scs=rpc.xmlhttp.responseText.extractScript(); + scs.evalScript(); + }.extend(this); + oRPC.make(); } /*refresh content tiny*/ function saveFile(pro_uid, fileName){ + + var oRPC = new leimnud.module.rpc.xmlhttp({ + url : 'processes_Ajax', + args: 'action=getSessid&filename='+fileName + }); + + oPanel.loader.show(); + oRPC.callback = function(rpc) { + if(rpc.xmlhttp.response==0){ + showPromptLogin('session'); + } + }.extend(this); + oRPC.make(); var fc64 = base64_encode(getField('fcontent').value); tinyMCE.execCommand('mceRemoveControl',false,'form[fcontent]'); fc64 = fc64.replace(/&/g, "@amp@"); fc64 = fc64.replace(/\+/g, '%2B'); - var oRPC = new leimnud.module.rpc.xmlhttp({ - url : 'processes_Ajax', - args: 'action=saveFile&filename='+fileName+'&pro_uid='+pro_uid+'&MAIN_DIRECTORY='+CURRENT_MAIN_DIRECTORY+'&fcontent='+fc64 - }); + var oRPC = new leimnud.module.rpc.xmlhttp({ + url : 'processes_Ajax', + args: 'action=saveFile&filename='+fileName+'&pro_uid='+pro_uid+'&MAIN_DIRECTORY='+CURRENT_MAIN_DIRECTORY+'&fcontent='+fc64 + }); - oPanel.loader.show(); - oRPC.callback = function(rpc) { - oPanel.remove(); - }.extend(this); - oRPC.make(); + oPanel.loader.show(); + oRPC.callback = function(rpc) { + oPanel.remove(); + }.extend(this); + oRPC.make(); } var showCreateEmptyOptionsPanel; function showCreateEmptyOptions(e, MAIN_DIRECTORY){ + + var oRPC = new leimnud.module.rpc.xmlhttp({ + url : 'processes_Ajax', + args: 'action=getSessid&filename=filename' + }); + + oRPC.callback = function(rpc) { + if(rpc.xmlhttp.response==0){ + showPromptLogin('session'); + } + }.extend(this); + oRPC.make(); + CURRENT_MAIN_DIRECTORY = MAIN_DIRECTORY; - oPanel = new leimnud.module.panel(); - oPanel.options={ - limit : true, - size : {w:400,h:100}, - position : {x:e.clientX,y:e.clientY,center:false}, - title : '', - control : {close:true,resize:false},fx:{modal:true}, - fx : {shadow:true,modal:true} - }; - oPanel.make(); - var oRPC = new leimnud.module.rpc.xmlhttp({url : 'processes_Ajax', args: 'action=emptyFileOptions&MAIN_DIRECTORY='+CURRENT_MAIN_DIRECTORY }); - oPanel.loader.show(); - oRPC.callback = function(rpc) { - oPanel.loader.hide(); - oPanel.addContent(rpc.xmlhttp.responseText); - var scs=rpc.xmlhttp.responseText.extractScript(); - scs.evalScript(); - }.extend(this); - oRPC.make(); - showCreateEmptyOptionsPanel = oPanel; + oPanel = new leimnud.module.panel(); + oPanel.options={ + limit : true, + size : {w:400,h:100}, + position : {x:e.clientX,y:e.clientY,center:false}, + title : '', + control : {close:true,resize:false},fx:{modal:true}, + fx : {shadow:true,modal:true} + }; + oPanel.make(); + var oRPC = new leimnud.module.rpc.xmlhttp({url : 'processes_Ajax', args: 'action=emptyFileOptions&MAIN_DIRECTORY='+CURRENT_MAIN_DIRECTORY }); + oPanel.loader.show(); + oRPC.callback = function(rpc) { + oPanel.loader.hide(); + oPanel.addContent(rpc.xmlhttp.responseText); + var scs=rpc.xmlhttp.responseText.extractScript(); + scs.evalScript(); + }.extend(this); + oRPC.make(); + showCreateEmptyOptionsPanel = oPanel; } function saveEmptyFile(){ @@ -164,8 +311,8 @@ function saveEmptyFile(){ var status = response.status; if (status == "OK") { - var oRPC = new leimnud.module.rpc.xmlhttp({ - url : 'processes_Ajax', + var oRPC = new leimnud.module.rpc.xmlhttp({ + url : 'processes_Ajax', args: 'action=saveFile&filename='+fileName+'&pro_uid='+CURRENT_PRO_UID+'&MAIN_DIRECTORY='+CURRENT_MAIN_DIRECTORY+'&fcontent=' }); @@ -179,7 +326,7 @@ function saveEmptyFile(){ } editFile(CURRENT_PRO_UID, fileName) }.extend(this); - oRPC.make(); + oRPC.make(); } else { new leimnud.module.app.alert().make({label: _("ID_EXISTS_FILES")}); } From a6c9c49cbf994c915da2e26ae7cba51c20156986 Mon Sep 17 00:00:00 2001 From: dheeyi Date: Wed, 29 Apr 2015 09:31:49 -0400 Subject: [PATCH 2/2] =?UTF-8?q?PM-1879=200015808:=20Incorrect=20messages?= =?UTF-8?q?=20handling=20and/or=20actions=20when=20the=20user's=20session?= =?UTF-8?q?=20expires=20in=20the=20DESIGNER=20module=200016086:=20Informat?= =?UTF-8?q?ion=20of=20templates=20lost.=20Causa=20:=20Esto=20fue=20debido?= =?UTF-8?q?=20a=20que=20no=20se=20tenia=20una=20validacion=20de=20perdida?= =?UTF-8?q?=20de=20session.=20Soluci=C3=B3=20Aplica=20a=20secci=C3=B3roces?= =?UTF-8?q?s=20Files=20Manager)=20=20para=20el=20antiguo=20dise=C3=B1r,=20?= =?UTF-8?q?a=20la=20cual=20se=20considera=20todos=20los=20posibles=20casos?= =?UTF-8?q?=20de=20perdida=20de=20session=20haciendo=20una=20validaci?= =?UTF-8?q?=C3=B3ara=20todo=20estas=20situaciones.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../processes/processes_FilesOptions.xml | 32 +++++++++++++------ 1 file changed, 22 insertions(+), 10 deletions(-) diff --git a/workflow/engine/xmlform/processes/processes_FilesOptions.xml b/workflow/engine/xmlform/processes/processes_FilesOptions.xml index 859470d68..c8dc54fb4 100755 --- a/workflow/engine/xmlform/processes/processes_FilesOptions.xml +++ b/workflow/engine/xmlform/processes/processes_FilesOptions.xml @@ -16,8 +16,11 @@ var CURRENT_MAIN_DIRECTORY; var CURRENT_CURRENT_DIRECTORY; var oUploadFilesPanel; var oUploadFilesPanel; -var showPromptLogin = function(lastAction) { +var showPromptLogin = function(lastAction, pro_uid, fileName, fc64) { lastActionPerformed = lastAction; + prouid = pro_uid; + filename = fileName; + fcont = fc64; promptPanel = new leimnud.module.panel(); promptPanel.options={ statusBarButtons:[{value: _('LOGIN')}], @@ -104,6 +107,15 @@ var verifyLogin = function() { rpc.callback = function(rpc) { if (rpc.xmlhttp.responseText.indexOf('form[USR_USERNAME]') == -1) { promptPanel.remove(); + if(lastActionPerformed=='save'){ + var oRPC = new leimnud.module.rpc.xmlhttp({ + url : 'processes_Ajax', + args: 'action=saveFile&filename='+filename+'&pro_uid='+prouid+'&MAIN_DIRECTORY='+CURRENT_MAIN_DIRECTORY+'&fcontent='+fcont + }); + oRPC.callback = function(rpc) { + }; + oRPC.make(); + } lastActionPerformed = ''; } else { new leimnud.module.app.alert().make({ @@ -121,7 +133,7 @@ var uploadFilesScreen = function(PRO_UID, MAIN_DIRECTORY, CURRENT_DIRECTORY) { oRPC.callback = function(rpc) { if(rpc.xmlhttp.response==0){ - showPromptLogin('session'); + showPromptLogin('upload','','',''); }else{ var swNavigator; if(navigator.appName=='Microsoft Internet Explorer'){ @@ -183,7 +195,7 @@ function editFile(pro_uid, fileName){ oRPC.callback = function(rpc) { if(rpc.xmlhttp.response==0){ - showPromptLogin('session'); + showPromptLogin('edit','','',''); } }.extend(this); oRPC.make(); @@ -223,6 +235,11 @@ function editFile(pro_uid, fileName){ /*refresh content tiny*/ function saveFile(pro_uid, fileName){ + + var fc64 = base64_encode(getField('fcontent').value); + tinyMCE.execCommand('mceRemoveControl',false,'form[fcontent]'); + fc64 = fc64.replace(/&/g, "@amp@"); + fc64 = fc64.replace(/\+/g, '%2B'); var oRPC = new leimnud.module.rpc.xmlhttp({ url : 'processes_Ajax', @@ -232,16 +249,11 @@ function saveFile(pro_uid, fileName){ oPanel.loader.show(); oRPC.callback = function(rpc) { if(rpc.xmlhttp.response==0){ - showPromptLogin('session'); + showPromptLogin('save',pro_uid, fileName, fc64); } }.extend(this); oRPC.make(); - var fc64 = base64_encode(getField('fcontent').value); - tinyMCE.execCommand('mceRemoveControl',false,'form[fcontent]'); - fc64 = fc64.replace(/&/g, "@amp@"); - fc64 = fc64.replace(/\+/g, '%2B'); - var oRPC = new leimnud.module.rpc.xmlhttp({ url : 'processes_Ajax', args: 'action=saveFile&filename='+fileName+'&pro_uid='+pro_uid+'&MAIN_DIRECTORY='+CURRENT_MAIN_DIRECTORY+'&fcontent='+fc64 @@ -264,7 +276,7 @@ function showCreateEmptyOptions(e, MAIN_DIRECTORY){ oRPC.callback = function(rpc) { if(rpc.xmlhttp.response==0){ - showPromptLogin('session'); + showPromptLogin('createEmty','','',''); } }.extend(this); oRPC.make();