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:
Loïc Chapeaux
2001-09-16 20:07:46 +00:00
parent cc378e20c1
commit 3a0410b2a8
4 changed files with 1208 additions and 804 deletions

120
libraries/user_details.js Normal file
View 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