From 71c74b1b572f3bdf00ba99009cc23f8f48072a1c Mon Sep 17 00:00:00 2001 From: Till Brehm <tbrehm@ispconfig.org> Date: Sat, 08 Mar 2014 11:58:49 -0500 Subject: [PATCH] Fixed: FS#3372 - Web browser password autofill function overwrites settings --- interface/web/js/scrigo.js.php | 370 +++++++++++++++++++++++++++++++++++++++++----------- 1 files changed, 288 insertions(+), 82 deletions(-) diff --git a/interface/web/js/scrigo.js.php b/interface/web/js/scrigo.js.php index 0e3fe68..ec7cdb9 100644 --- a/interface/web/js/scrigo.js.php +++ b/interface/web/js/scrigo.js.php @@ -1,43 +1,121 @@ <?php - session_start(); - include('../../lib/config.inc.php'); - $lang = (isset($_SESSION['s']['language']) && $_SESSION['s']['language'] != '')?$_SESSION['s']['language']:'en'; - include_once(ISPC_ROOT_PATH.'/web/strengthmeter/lib/lang/'.$lang.'_strengthmeter.lng'); -?> +session_start(); +include '../../lib/config.inc.php'; +header('Content-Type: text/javascript; charset=utf-8'); // the config file sets the content type header so we have to override it here! +require_once '../../lib/app.inc.php'; +$lang = (isset($_SESSION['s']['language']) && $_SESSION['s']['language'] != '')?$_SESSION['s']['language']:'en'; +include_once ISPC_ROOT_PATH.'/web/strengthmeter/lib/lang/'.$lang.'_strengthmeter.lng'; +$app->uses('ini_parser,getconf'); +$server_config_array = $app->getconf->get_global_config(); +?> +var pageFormChanged = false; +var tabChangeWarningTxt = ''; +var tabChangeDiscardTxt = ''; +var tabChangeWarning = false; +var tabChangeDiscard = false; +var requestsRunning = 0; +var indicatorPaddingH = -1; +var indicatorPaddingW = -1; +var indicatorCompleted = false; redirect = ''; function reportError(request) { - /* Error reporting is disabled by default as some browsers like safari - sometimes throw errors when a ajax request is delayed even if the + /* Error reporting is disabled by default as some browsers like safari + sometimes throw errors when a ajax request is delayed even if the ajax request worked. */ - + /*alert(request);*/ } +function resetFormChanged() { + pageFormChanged = false; +} + +function showLoadIndicator() { + document.body.style.cursor = 'wait'; + +<?php +if($server_config_array['misc']['use_loadindicator'] == 'y'){ +?> + requestsRunning += 1; + + if(requestsRunning < 2) { + var indicator = jQuery('#ajaxloader'); + if(indicator.length < 1) { + indicator = jQuery('<div id="ajaxloader" style="display: none;"></div>'); + indicator.appendTo('body'); + } + var parent = jQuery('#content'); + if(parent.length < 1) return; + indicatorCompleted = false; + + var atx = parent.offset().left + 150; //((parent.outerWidth(true) - indicator.outerWidth(true)) / 2); + var aty = parent.offset().top + 150; + indicator.css( {'left': atx, 'top': aty } ).fadeIn('fast', function() { + // check if loader should be hidden immediately + indicatorCompleted = true; + if(requestsRunning < 1) $(this).fadeOut('fast', function() { $(this).hide();}); + }); + } +<?php +} +?> +} + +function hideLoadIndicator() { + document.body.style.cursor = ''; + + requestsRunning -= 1; + if(requestsRunning < 1) { + requestsRunning = 0; // just for the case... + if(indicatorCompleted == true) jQuery('#ajaxloader').fadeOut('fast', function() { jQuery('#ajaxloader').hide(); } ); + } +} + +function onAfterContentLoad() { +<?php +if($server_config_array['misc']['use_combobox'] == 'y'){ +?> + $('#pageContent').find("select").combobox(); +<?php +} +?> +} + function loadContentRefresh(pagename) { - + if(document.getElementById('refreshinterval').value > 0) { - var pageContentObject2 = jQuery.ajax({ type: "GET", + var pageContentObject2 = jQuery.ajax({ type: "GET", url: pagename, data: "refresh="+document.getElementById('refreshinterval').value, dataType: "html", + beforeSend: function() { + showLoadIndicator(); + }, success: function(data, textStatus, jqXHR) { + hideLoadIndicator(); jQuery('#pageContent').html(jqXHR.responseText); + onAfterContentLoad(); + pageFormChanged = false; }, error: function() { + hideLoadIndicator(); reportError('Ajax Request was not successful.'+pagename); - }, + } }); - setTimeout( "loadContentRefresh('"+pagename+"&refresh="+document.getElementById('refreshinterval').value+"')", document.getElementById('refreshinterval').value*1000 ); + setTimeout( "loadContentRefresh('"+pagename+"&refresh="+document.getElementById('refreshinterval').value+"')", document.getElementById('refreshinterval').value*1000*60 ); } } function capp(module, redirect) { - var submitFormObj = jQuery.ajax({ type: "GET", - url: "capp.php", + var submitFormObj = jQuery.ajax({ type: "GET", + url: "capp.php", data: "mod="+module+((redirect != undefined) ? '&redirect='+redirect : ''), dataType: "html", + beforeSend: function() { + showLoadIndicator(); + }, success: function(data, textStatus, jqXHR) { if(jqXHR.responseText != '') { if(jqXHR.responseText.indexOf('HEADER_REDIRECT:') > -1) { @@ -51,10 +129,12 @@ } } loadMenus(); + hideLoadIndicator(); }, error: function() { + hideLoadIndicator(); reportError('Ajax Request was not successful.'+module); - }, + } }); } @@ -70,11 +150,19 @@ if(passwordObj.value == ''){ passwordObj.focus(); return; - } - var submitFormObj = jQuery.ajax({ type: "POST", + } + + $('#dummy_username').val(userNameObj.value); + $('#dummy_passwort').val(passwordObj.value); + $('#dummy_login_form').submit(); + + var submitFormObj = jQuery.ajax({ type: "POST", url: "content.php", data: jQuery('#'+formname).serialize(), dataType: "html", + beforeSend: function() { + showLoadIndicator(); + }, success: function(data, textStatus, jqXHR) { if(jqXHR.responseText.indexOf('HEADER_REDIRECT:') > -1) { var parts = jqXHR.responseText.split(':'); @@ -87,12 +175,16 @@ document.location.href = 'index.php'; } else { jQuery('#pageContent').html(jqXHR.responseText); + onAfterContentLoad(); + pageFormChanged = false; } loadMenus(); + hideLoadIndicator(); }, error: function() { + hideLoadIndicator(); reportError('Ajax Request was not successful.110'); - }, + } }); /* if(redirect != '') { @@ -101,14 +193,17 @@ } document.getElementById('footer').innerHTML = 'Powered by <a href="http://www.ispconfig.org" target="_blank">ISPConfig</a>'; */ - + } function submitForm(formname,target) { - var submitFormObj = jQuery.ajax({ type: "POST", + var submitFormObj = jQuery.ajax({ type: "POST", url: target, data: jQuery('#'+formname).serialize(), dataType: "html", + beforeSend: function() { + showLoadIndicator(); + }, success: function(data, textStatus, jqXHR) { if(jqXHR.responseText.indexOf('HEADER_REDIRECT:') > -1) { var parts = jqXHR.responseText.split(':'); @@ -118,12 +213,16 @@ //window.setTimeout('loadContent(redirect)', 1000); } else { jQuery('#pageContent').html(jqXHR.responseText); + onAfterContentLoad(); + pageFormChanged = false; } + hideLoadIndicator(); }, error: function(jqXHR, textStatus, errorThrown) { + hideLoadIndicator(); var parts = jqXHR.responseText.split(':'); reportError('Ajax Request was not successful. 111'); - }, + } }); /* if(redirect != '') { @@ -134,12 +233,17 @@ } function submitFormConfirm(formname,target,confirmation) { + var successMessage = arguments[3]; if(window.confirm(confirmation)) { - var submitFormObj = jQuery.ajax({ type: "POST", + var submitFormObj = jQuery.ajax({ type: "POST", url: target, data: jQuery('#'+formname).serialize(), dataType: "html", + beforeSend: function() { + showLoadIndicator(); + }, success: function(data, textStatus, jqXHR) { + if(successMessage) alert(successMessage); if(jqXHR.responseText.indexOf('HEADER_REDIRECT:') > -1) { var parts = jqXHR.responseText.split(':'); //alert(parts[1]); @@ -148,20 +252,24 @@ //window.setTimeout('loadContent(redirect)', 1000); } else { jQuery('#pageContent').html(jqXHR.responseText); + onAfterContentLoad(); + pageFormChanged = false; } + hideLoadIndicator(); }, error: function(jqXHR, textStatus, errorThrown) { + hideLoadIndicator(); var parts = jqXHR.responseText.split(':'); reportError('Ajax Request was not successful. 111'); - }, + } }); } } -function submitUploadForm(formname,target) { +function submitUploadForm(formname,target) { var handleResponse = function(loadedFrame) { var response, responseStr = loadedFrame.contentWindow.document.body.innerHTML; - + try { response = JSON.parse(responseStr); } catch(e) { @@ -177,9 +285,9 @@ msg = msg+'<div id="errorMsg">'+errormsg+'</div>'; } return msg; - + }; - + var frame_id = 'ajaxUploader-iframe-' + Math.round(new Date().getTime() / 1000); jQuery('body').after('<iframe width="0" height="0" style="display:none;" name="'+frame_id+'" id="'+frame_id+'"/>'); jQuery('input[type="file"]').closest("form").attr({target: frame_id, action: target}).submit(); @@ -200,11 +308,13 @@ } function loadContent(pagename) { - var pageContentObject2 = jQuery.ajax({ type: "GET", + var params = arguments[1]; + var pageContentObject2 = jQuery.ajax({ type: "GET", url: pagename, + data: (params ? params : null), dataType: "html", beforeSend: function() { - jQuery('#pageContent').html('<div id="ajaxloader"><img src="themes/default/images/ajax-loader.gif" /></div>'); + showLoadIndicator(); }, success: function(data, textStatus, jqXHR) { if(jqXHR.responseText.indexOf('HEADER_REDIRECT:') > -1) { @@ -218,35 +328,46 @@ //var reponse = jQuery(jqXHR.responseText); //var reponseScript = reponse.filter("script"); //jQuery.each(reponseScript, function(idx, val) { eval(val.text); } ); - + jQuery('#pageContent').html(jqXHR.responseText); + onAfterContentLoad(); + pageFormChanged = false; } + hideLoadIndicator(); }, error: function() { + hideLoadIndicator(); reportError('Ajax Request was not successful. 113'); - }, + } }); } function loadInitContent() { - var pageContentObject = jQuery.ajax({ type: "GET", + var pageContentObject = jQuery.ajax({ type: "GET", url: "content.php", data: "s_mod=login&s_pg=index", dataType: "html", + beforeSend: function() { + showLoadIndicator(); + }, success: function(data, textStatus, jqXHR) { if(jqXHR.responseText.indexOf('HEADER_REDIRECT:') > -1) { var parts = jqXHR.responseText.split(":"); loadContent(parts[1]); } else { jQuery('#pageContent').html(jqXHR.responseText); + onAfterContentLoad(); + pageFormChanged = false; } + hideLoadIndicator(); }, error: function() { + hideLoadIndicator(); reportError('Ajax Request was not successful. 114'); - }, + } }); - + loadMenus(); keepalive(); setTimeout("setFocus()",1000); @@ -255,45 +376,79 @@ function setFocus() { try { - document.pageForm.username.focus(); + jQuery('form#pageForm').find('input[name="username"]').focus(); } catch (e) { } } function loadMenus() { - var sideNavObject = jQuery.ajax({ type: "GET", + var sideNavObject = jQuery.ajax({ type: "GET", url: "nav.php", data: "nav=side", dataType: "html", + beforeSend: function() { + showLoadIndicator(); + }, success: function(data, textStatus, jqXHR) { + hideLoadIndicator(); jQuery('#sideNav').html(jqXHR.responseText); }, error: function() { + hideLoadIndicator(); reportError('Ajax Request was not successful. 115'); - }, + } }); - - var topNavObject = jQuery.ajax({ type: "GET", + + var topNavObject = jQuery.ajax({ type: "GET", url: "nav.php", data: "nav=top", dataType: "html", + beforeSend: function() { + showLoadIndicator(); + }, success: function(data, textStatus, jqXHR) { + hideLoadIndicator(); jQuery('#topNav').html(jqXHR.responseText); }, error: function(o) { + hideLoadIndicator(); reportError('Ajax Request was not successful. 116'); - }, + } }); } -function changeTab(tab,target) { +function changeTab(tab,target,force) { //document.forms[0].next_tab.value = tab; document.pageForm.next_tab.value = tab; - submitForm('pageForm',target); + + var idel = jQuery('form#pageForm').find('[name="id"]'); + var id = null; + if(idel.length > 0) id = idel.val(); + if(tabChangeDiscard == 'y' && !force) { + if((idel.length < 1 || id) && (pageFormChanged == false || window.confirm(tabChangeDiscardTxt))) { + var next_tab = tab; + if(id) loadContent(target, {'next_tab': next_tab, 'id': id}); + else loadContent(target, {'next_tab': next_tab}); + } else { + return false; + } + } else { + if(id && tabChangeWarning == 'y' && pageFormChanged == true) { + if(window.confirm(tabChangeWarningTxt)) { + submitForm('pageForm', target); + } else { + var next_tab = tab; + if(id) loadContent(target, {'next_tab': next_tab, 'id': id}); + else loadContent(target, {'next_tab': next_tab}); + } + } else { + submitForm('pageForm',target); + } + } } - + function del_record(link,confirmation) { if(window.confirm(confirmation)) { loadContent(link); @@ -307,23 +462,32 @@ } function loadContentInto(elementid,pagename) { - var pageContentObject2 = jQuery.ajax({ type: "GET", + var pageContentObject2 = jQuery.ajax({ type: "GET", url: pagename, dataType: "html", + beforeSend: function() { +// showLoadIndicator(); + }, success: function(data, textStatus, jqXHR) { +// hideLoadIndicator(); jQuery('#'+elementid).html(jqXHR.responseText); }, error: function() { +// hideLoadIndicator(); reportError('Ajax Request was not successful. 118'); - }, + } }); } function loadOptionInto(elementid,pagename) { - var pageContentObject2 = jQuery.ajax({ type: "GET", + var pageContentObject2 = jQuery.ajax({ type: "GET", url: pagename, dataType: "html", + beforeSend: function() { +// showLoadIndicator(); + }, success: function(data, textStatus, jqXHR) { +// hideLoadIndicator(); var teste = jqXHR.responseText; var elemente = teste.split('#'); el=document.getElementById(elementid); @@ -337,13 +501,14 @@ } }, error: function() { +// hideLoadIndicator(); reportError('Ajax Request was not successful. 119'); - }, + } }); } function keepalive() { - var pageContentObject3 = jQuery.ajax({ type: "GET", + var pageContentObject3 = jQuery.ajax({ type: "GET", url: "keepalive.php", dataType: "html", success: function(data, textStatus, jqXHR) { @@ -351,7 +516,7 @@ }, error: function() { reportError('Session expired. Please login again.'); - }, + } }); //setTimeout( keepalive, 1000000 ); } @@ -398,24 +563,24 @@ pass_result(0); return; } - + if (length < 5) { pass_result(1); return; } - + if (pass_contains(password, "ABCDEFGHIJKLNMOPQRSTUVWXYZ")) { points += 1; } - + if (pass_contains(password, "0123456789")) { points += 1; } - + if (pass_contains(password, "`~!@#$%^&*()_+|\=-[]}{';:/?.>,<\" ")) { points += 1; } - + if (points == 0) { if (length >= 5 && length <=6) { pass_result(1); @@ -477,45 +642,70 @@ return false; } +var new_tpl_add_id = 0; function addAdditionalTemplate(){ - var tpl_add = document.getElementById('template_additional').value; - - var tpl_list = document.getElementById('template_additional_list').innerHTML; - var addTemplate = document.getElementById('tpl_add_select').value.split('|',2); - var addTplId = addTemplate[0]; - var addTplText = addTemplate[1]; + var tpl_add = jQuery('#template_additional').val(); + var addTemplate = jQuery('#tpl_add_select').val().split('|',2); + var addTplId = addTemplate[0]; + var addTplText = addTemplate[1]; if(addTplId > 0) { - var newVal = tpl_add + '/' + addTplId + '/'; - newVal = newVal.replace('//', '/'); - var newList = tpl_list + '<br>' + addTplText; - newList = newList.replace('<br><br>', '<br>'); - document.getElementById('template_additional').value = newVal; - document.getElementById('template_additional_list').innerHTML = newList; - alert('additional template ' + addTplText + ' added to customer'); + var newVal = tpl_add.split('/'); + new_tpl_add_id += 1; + var delbtn = jQuery('<a href="#"></a>').attr('class', 'button icons16 icoDelete').click(function(e) { + e.preventDefault(); + delAdditionalTemplate($(this).parent().attr('rel')); + }); + newVal[newVal.length] = 'n' + new_tpl_add_id + ':' + addTplId; + jQuery('<li>' + addTplText + '</li>').attr('rel', 'n' + new_tpl_add_id).append(delbtn).appendTo('#template_additional_list ul'); + jQuery('#template_additional').val(newVal.join('/')); + alert('additional template ' + addTplText + ' added to customer'); } else { - alert('no additional template selcted'); + alert('no additional template selcted'); } } -function delAdditionalTemplate(){ - var tpl_add = document.getElementById('template_additional').value; - if(tpl_add != '') { - var tpl_list = document.getElementById('template_additional_list').innerHTML; +function delAdditionalTemplate(tpl_id){ + var tpl_add = jQuery('#template_additional').val(); + if(tpl_id) { + // new style + var $el = jQuery('#template_additional_list ul').find('li[rel="' + tpl_id + '"]').eq(0); // only the first + var addTplText = $el.text(); + $el.remove(); + + var oldVal = tpl_add.split('/'); + var newVal = new Array(); + for(var i = 0; i < oldVal.length; i++) { + var tmp = oldVal[i].split(':', 2); + if(tmp.length == 2 && tmp[0] == tpl_id) continue; + newVal[newVal.length] = oldVal[i]; + } + jQuery('#template_additional').val(newVal.join('/')); + alert('additional template ' + addTplText + ' deleted from customer'); + } else if(tpl_add != '') { + // old style var addTemplate = document.getElementById('tpl_add_select').value.split('|',2); var addTplId = addTemplate[0]; var addTplText = addTemplate[1]; + + jQuery('#template_additional_list ul').find('li:not([rel])').each(function() { + var text = jQuery(this).text(); + if(text == addTplText) { + jQuery(this).remove(); + return false; + } + return this; + }); + var newVal = tpl_add; - newVal = newVal.replace(addTplId, ''); + var repl = new RegExp('(^|\/)' + addTplId + '(\/|$)'); + newVal = newVal.replace(repl, ''); newVal = newVal.replace('//', '/'); - var newList = tpl_list.replace(addTplText, ''); - newList = newList.replace('<br><br>', '<br>'); - document.getElementById('template_additional').value = newVal; - document.getElementById('template_additional_list').innerHTML = newList; + jQuery('#template_additional').val(newVal); alert('additional template ' + addTplText + ' deleted from customer'); } else { alert('no additional template selcted'); } - + } function getInternetExplorerVersion() { @@ -563,6 +753,8 @@ newPWField.attr('id', passwordFieldID).val(pword).trigger('keyup'); } +var funcDisableClick = function(e) { e.preventDefault(); return false; }; + function checkPassMatch(pwField1,pwField2){ var rpass = jQuery('#'+pwField2).val(); var npass = jQuery('#'+pwField1).val(); @@ -570,13 +762,22 @@ jQuery('#confirmpasswordOK').hide(); jQuery('#confirmpasswordError').show(); jQuery('button.positive').attr('disabled','disabled'); - jQuery('.tabbox_tabs ul li a').attr('onclick','return false;'); + jQuery('.tabbox_tabs ul li a').each(function() { + var $this = $(this); + $this.data('saved_onclick', $this.attr('onclick')); + $this.removeAttr('onclick'); + $this.click(funcDisableClick); + }); return false; } else { jQuery('#confirmpasswordError').hide(); jQuery('#confirmpasswordOK').show(); jQuery('button.positive').removeAttr('disabled'); - jQuery('.tabbox_tabs ul li a').removeAttr('onclick'); + jQuery('.tabbox_tabs ul li a').each(function() { + var $this = $(this); + $this.unbind('click', funcDisableClick); + if($this.data('saved_onclick') && !$this.attr('onclick')) $this.attr('onclick', $this.data('saved_onclick')); + }); } } @@ -589,7 +790,13 @@ var template = jQuery(this).siblings(':input'); template.insertAtCaret(placeholderText); }); - + +jQuery('.addPlaceholderContent').live("click", function(){ + var placeholderContentText = jQuery(this).find('.addPlaceholderContent').text(); + var template2 = jQuery(this).siblings(':input'); + template2.insertAtCaret(placeholderContentText); +}); + jQuery.fn.extend({ insertAtCaret: function(myValue){ return this.each(function(i) { @@ -616,4 +823,3 @@ }) } }); - -- Gitblit v1.9.1