rewrtitten the users script so it validates xhtml1.0, and fix a security issue removing most of the javascript work.
This commit is contained in:
120
libraries/user_details.js
Normal file
120
libraries/user_details.js
Normal file
@@ -0,0 +1,120 @@
|
||||
/* $Id$ */
|
||||
|
||||
|
||||
/**
|
||||
* Validates the the password field in a form
|
||||
*
|
||||
* @param object the form
|
||||
*
|
||||
* @return boolean whether the field value is valid or not
|
||||
*/
|
||||
function checkPassword(the_form)
|
||||
{
|
||||
if (the_form.elements['nopass'][1].checked) {
|
||||
if (the_form.elements['pma_pw'].value == '') {
|
||||
alert(jsPasswordEmpty);
|
||||
the_form.elements['pma_pw2'].value = '';
|
||||
the_form.elements['pma_pw'].focus();
|
||||
return false;
|
||||
} else if (the_form.elements['pma_pw'].value != the_form.elements['pma_pw2'].value) {
|
||||
alert(jsPasswordNotSame);
|
||||
the_form.elements['pma_pw'].value = '';
|
||||
the_form.elements['pma_pw2'].value = '';
|
||||
the_form.elements['pma_pw'].focus();
|
||||
return false;
|
||||
} // end if...else if
|
||||
} // end if
|
||||
|
||||
return true;
|
||||
} // end of the 'checkPassword()' function
|
||||
|
||||
|
||||
/**
|
||||
* Validates the "add an user" form
|
||||
*
|
||||
* @return boolean whether the form is validated or not
|
||||
*/
|
||||
function checkAddUser()
|
||||
{
|
||||
var the_form = document.forms['addUserForm'];
|
||||
|
||||
if (the_form.elements['anyhost'][1].checked && the_form.elements['host'].value == '') {
|
||||
alert(jsHostEmpty);
|
||||
the_form.elements['host'].focus();
|
||||
return false;
|
||||
}
|
||||
|
||||
if (the_form.elements['anyuser'][1].checked && the_form.elements['pma_user'].value == '') {
|
||||
alert(jsUserEmpty);
|
||||
the_form.elements['pma_user'].focus();
|
||||
return false;
|
||||
}
|
||||
|
||||
return checkPassword(the_form);
|
||||
} // end of the 'addUser()' function
|
||||
|
||||
|
||||
/**
|
||||
* Gets the list of selected options in combo
|
||||
*
|
||||
* @param object the form to check
|
||||
*
|
||||
* @return string the list of selected options
|
||||
*/
|
||||
function getSelected(the_field) {
|
||||
var the_list = '';
|
||||
var opts = the_field.options;
|
||||
var opts_cnt = opts.length;
|
||||
|
||||
for (var i = 0; i < opts_cnt; i++) {
|
||||
if (opts[i].selected) {
|
||||
the_list += opts[i].text + ', ';
|
||||
}
|
||||
} // end for
|
||||
|
||||
return the_list.substring(0, the_list.length - 2);
|
||||
} // end of the 'getSelected()' function
|
||||
|
||||
|
||||
/**
|
||||
* Reloads the page to get tables names in a database or fields names in a
|
||||
* table
|
||||
*
|
||||
* @param object the input text box to build the query from
|
||||
*/
|
||||
function change(the_field) {
|
||||
var l = location.href;
|
||||
var box_name = the_field.name;
|
||||
|
||||
if (box_name == 'dbgrant') {
|
||||
var lpos = l.indexOf('&' + box_name);
|
||||
if (lpos >= 0) {
|
||||
l = l.substring(0, lpos);
|
||||
}
|
||||
} // end if
|
||||
|
||||
location.href = l + '&' + box_name + '=' + getSelected(the_field);
|
||||
} // end of the 'change()' function
|
||||
|
||||
|
||||
/**
|
||||
* Checks/unchecks all privileges
|
||||
*
|
||||
* @param string the form name
|
||||
* @param boolean whether to check or to uncheck the element
|
||||
*
|
||||
* @return boolean always true
|
||||
*/
|
||||
function checkForm(the_form, do_check) {
|
||||
var elts = document.forms[the_form].elements;
|
||||
var elts_cnt = elts.length;
|
||||
|
||||
for (var i = 0; i < elts_cnt; i++) {
|
||||
var whichElt = elts[i].name;
|
||||
if (whichElt.indexOf('_priv') >= 0) {
|
||||
document.forms[the_form].elements[whichElt].checked = do_check;
|
||||
} // end if
|
||||
} // end for
|
||||
|
||||
return true;
|
||||
} // end of the 'checkForm()' function
|
Reference in New Issue
Block a user