Line 39 | Line 39 |
---|
switch ($mode) { case 'register':
|
switch ($mode) { case 'register':
|
// If the field is required we show it on the registration page and do not show hidden fields $sql_where .= ' AND (f.field_show_on_reg = 1 OR f.field_required = 1) AND f.field_hide = 0';
| // If the field is required we show it on the registration page $sql_where .= ' AND f.field_show_on_reg = 1';
|
break;
case 'profile': // Show hidden fields to moderators/admins if (!$auth->acl_gets('a_', 'm_') && !$auth->acl_getf_global('m_')) {
|
break;
case 'profile': // Show hidden fields to moderators/admins if (!$auth->acl_gets('a_', 'm_') && !$auth->acl_getf_global('m_')) {
|
$sql_where .= ' AND f.field_hide = 0';
| $sql_where .= ' AND f.field_show_profile = 1';
|
} break;
| } break;
|
Line 90 | Line 90 |
---|
*/ function validate_profile_field($field_type, &$field_value, $field_data) {
|
*/ function validate_profile_field($field_type, &$field_value, $field_data) {
|
switch ($field_type) { case FIELD_INT: case FIELD_DROPDOWN: $field_value = (int) $field_value; break;
case FIELD_BOOL: $field_value = (bool) $field_value; break; }
| |
switch ($field_type) { case FIELD_DATE:
| switch ($field_type) { case FIELD_DATE:
|
Line 133 | Line 121 |
---|
break;
case FIELD_BOOL:
|
break;
case FIELD_BOOL:
|
| $field_value = (bool) $field_value;
|
if (!$field_value && $field_data['field_required']) { return 'FIELD_REQUIRED';
| if (!$field_value && $field_data['field_required']) { return 'FIELD_REQUIRED';
|
Line 140 | Line 130 |
---|
break;
case FIELD_INT:
|
break;
case FIELD_INT:
|
if (empty($field_value) && !$field_data['field_required'])
| if (trim($field_value) === '' && !$field_data['field_required'])
|
{ return false; }
|
{ return false; }
|
| $field_value = (int) $field_value;
|
if ($field_value < $field_data['field_minlen']) {
| if ($field_value < $field_data['field_minlen']) {
|
Line 156 | Line 148 |
---|
break; case FIELD_DROPDOWN:
|
break; case FIELD_DROPDOWN:
|
| $field_value = (int) $field_value;
// retrieve option lang data if necessary if (!isset($this->options_lang[$field_data['field_id']]) || !isset($this->options_lang[$field_data['field_id']][$field_data['lang_id']]) || !sizeof($this->options_lang[$file_data['field_id']][$field_data['lang_id']])) { $this->get_option_lang($field_data['field_id'], $field_data['lang_id'], FIELD_DROPDOWN, false); }
if (!isset($this->options_lang[$field_data['field_id']][$field_data['lang_id']][$field_value])) { return 'FIELD_INVALID_VALUE'; }
|
if ($field_value == $field_data['field_novalue'] && $field_data['field_required']) { return 'FIELD_REQUIRED';
| if ($field_value == $field_data['field_novalue'] && $field_data['field_required']) { return 'FIELD_REQUIRED';
|
Line 164 | Line 169 |
---|
case FIELD_STRING: case FIELD_TEXT:
|
case FIELD_STRING: case FIELD_TEXT:
|
if (empty($field_value) && !$field_data['field_required'])
| if (trim($field_value) === '' && !$field_data['field_required'])
|
{ return false; }
|
{ return false; }
|
else if (empty($field_value) && $field_data['field_required'])
| else if (trim($field_value) === '' && $field_data['field_required'])
|
{ return 'FIELD_REQUIRED'; }
| { return 'FIELD_REQUIRED'; }
|
Line 259 | Line 264 |
---|
}
/**
|
}
/**
|
* Submit profile field
| * Submit profile field for validation
|
* @access public */ function submit_cp_field($mode, $lang_id, &$cp_data, &$cp_error)
| * @access public */ function submit_cp_field($mode, $lang_id, &$cp_data, &$cp_error)
|
Line 270 | Line 275 |
---|
switch ($mode) { case 'register':
|
switch ($mode) { case 'register':
|
// If the field is required we show it on the registration page and do not show hidden fields $sql_where .= ' AND (f.field_show_on_reg = 1 OR f.field_required = 1) AND f.field_hide = 0';
| // If the field is required we show it on the registration page $sql_where .= ' AND f.field_show_on_reg = 1';
|
break;
case 'profile': // Show hidden fields to moderators/admins if (!$auth->acl_gets('a_', 'm_') && !$auth->acl_getf_global('m_')) {
|
break;
case 'profile': // Show hidden fields to moderators/admins if (!$auth->acl_gets('a_', 'm_') && !$auth->acl_getf_global('m_')) {
|
$sql_where .= ' AND f.field_hide = 0';
| $sql_where .= ' AND f.field_show_profile = 1';
|
} break;
| } break;
|
Line 308 | Line 313 |
---|
switch ($cp_result) { case 'FIELD_INVALID_DATE':
|
switch ($cp_result) { case 'FIELD_INVALID_DATE':
|
| case 'FIELD_INVALID_VALUE':
|
case 'FIELD_REQUIRED': $error = sprintf($user->lang[$cp_result], $row['lang_name']); break;
| case 'FIELD_REQUIRED': $error = sprintf($user->lang[$cp_result], $row['lang_name']); break;
|
Line 347 | Line 353 |
---|
} } $db->sql_freeresult($result);
|
} } $db->sql_freeresult($result);
|
| }
/** * Update profile field data directly */ function update_profile_field_data($user_id, &$cp_data) { global $db;
if (!sizeof($cp_data)) { return; }
switch ($db->sql_layer) { case 'oracle': case 'firebird': case 'postgres': $right_delim = $left_delim = '"'; break;
case 'sqlite': case 'mssql': case 'mssql_odbc': case 'mssqlnative': $right_delim = ']'; $left_delim = '['; break;
case 'mysql': case 'mysql4': case 'mysqli': $right_delim = $left_delim = '`'; break; }
// use new array for the UPDATE; changes in the key do not affect the original array $cp_data_sql = array(); foreach ($cp_data as $key => $value) { // Firebird is case sensitive with delimiter $cp_data_sql[$left_delim . (($db->sql_layer == 'firebird' || $db->sql_layer == 'oracle') ? strtoupper($key) : $key) . $right_delim] = $value; }
$sql = 'UPDATE ' . PROFILE_FIELDS_DATA_TABLE . ' SET ' . $db->sql_build_array('UPDATE', $cp_data_sql) . " WHERE user_id = $user_id"; $db->sql_query($sql);
if (!$db->sql_affectedrows()) { $cp_data_sql['user_id'] = (int) $user_id;
$db->sql_return_on_error(true);
$sql = 'INSERT INTO ' . PROFILE_FIELDS_DATA_TABLE . ' ' . $db->sql_build_array('INSERT', $cp_data_sql); $db->sql_query($sql);
$db->sql_return_on_error(false); }
|
}
/**
| }
/**
|
Line 388 | Line 455 |
---|
$db->sql_freeresult($result);
$user_fields = array();
|
$db->sql_freeresult($result);
$user_fields = array();
|
| $user_ids = $user_id;
|
// Go through the fields in correct order foreach (array_keys($this->profile_cache) as $used_ident)
| // Go through the fields in correct order foreach (array_keys($this->profile_cache) as $used_ident)
|
Line 396 | Line 465 |
---|
{ $user_fields[$user_id][$used_ident]['value'] = $row['pf_' . $used_ident]; $user_fields[$user_id][$used_ident]['data'] = $this->profile_cache[$used_ident];
|
{ $user_fields[$user_id][$used_ident]['value'] = $row['pf_' . $used_ident]; $user_fields[$user_id][$used_ident]['data'] = $this->profile_cache[$used_ident];
|
| }
foreach ($user_ids as $user_id) { if (!isset($user_fields[$user_id][$used_ident]) && $this->profile_cache[$used_ident]['field_show_novalue']) { $user_fields[$user_id][$used_ident]['value'] = ''; $user_fields[$user_id][$used_ident]['data'] = $this->profile_cache[$used_ident]; }
|
} }
| } }
|
Line 454 | Line 532 |
---|
switch ($this->profile_types[$field_type]) { case 'int':
|
switch ($this->profile_types[$field_type]) { case 'int':
|
if ($value == '')
| if (($value === '' || $value === null) && !$ident_ary['data']['field_show_novalue'])
|
{ return NULL; }
| { return NULL; }
|
Line 463 | Line 541 |
---|
case 'string': case 'text':
|
case 'string': case 'text':
|
if (!$value)
| if (!$value && !$ident_ary['data']['field_show_novalue'])
|
{ return NULL; }
| { return NULL; }
|
Line 481 | Line 559 |
---|
$month = (isset($date[1])) ? (int) $date[1] : 0; $year = (isset($date[2])) ? (int) $date[2] : 0;
|
$month = (isset($date[1])) ? (int) $date[1] : 0; $year = (isset($date[2])) ? (int) $date[2] : 0;
|
if (!$day && !$month && !$year)
| if (!$day && !$month && !$year && !$ident_ary['data']['field_show_novalue'])
|
{ return NULL; } else if ($day && $month && $year) { global $user;
|
{ return NULL; } else if ($day && $month && $year) { global $user;
|
return $user->format_date(mktime(0, 0, 0, $month, $day, $year), $user->lang['DATE_FORMAT'], true);
| // Date should display as the same date for every user regardless of timezone, so remove offset // to compensate for the offset added by user::format_date() return $user->format_date(gmmktime(0, 0, 0, $month, $day, $year) - ($user->timezone + $user->dst), $user->lang['DATE_FORMAT'], true);
|
}
return $value;
| }
return $value;
|
Line 502 | Line 582 |
---|
$this->get_option_lang($field_id, $lang_id, FIELD_DROPDOWN, false); }
|
$this->get_option_lang($field_id, $lang_id, FIELD_DROPDOWN, false); }
|
if ($value == $ident_ary['data']['field_novalue'])
| if ($value == $ident_ary['data']['field_novalue'] && !$ident_ary['data']['field_show_novalue'])
|
{ return NULL; }
| { return NULL; }
|
Line 511 | Line 591 |
---|
// User not having a value assigned if (!isset($this->options_lang[$field_id][$lang_id][$value]))
|
// User not having a value assigned if (!isset($this->options_lang[$field_id][$lang_id][$value]))
|
| { if ($ident_ary['data']['field_show_novalue']) { $value = $ident_ary['data']['field_novalue']; } else
|
{ return NULL;
|
{ return NULL;
|
| }
|
}
return $this->options_lang[$field_id][$lang_id][$value];
| }
return $this->options_lang[$field_id][$lang_id][$value];
|
Line 524 | Line 611 |
---|
if (!isset($this->options_lang[$field_id][$lang_id])) { $this->get_option_lang($field_id, $lang_id, FIELD_BOOL, false);
|
if (!isset($this->options_lang[$field_id][$lang_id])) { $this->get_option_lang($field_id, $lang_id, FIELD_BOOL, false);
|
| }
if (!$value && $ident_ary['data']['field_show_novalue']) { $value = $ident_ary['data']['field_default_value'];
|
}
if ($ident_ary['data']['field_length'] == 1)
| }
if ($ident_ary['data']['field_length'] == 1)
|
Line 556 | Line 648 |
---|
$profile_row['field_ident'] = (isset($profile_row['var_name'])) ? $profile_row['var_name'] : 'pf_' . $profile_row['field_ident']; $user_ident = $profile_row['field_ident'];
|
$profile_row['field_ident'] = (isset($profile_row['var_name'])) ? $profile_row['var_name'] : 'pf_' . $profile_row['field_ident']; $user_ident = $profile_row['field_ident'];
|
// checkbox - only testing for isset
| // checkbox - set the value to "true" if it has been set to 1
|
if ($profile_row['field_type'] == FIELD_BOOL && $profile_row['field_length'] == 2) {
|
if ($profile_row['field_type'] == FIELD_BOOL && $profile_row['field_length'] == 2) {
|
$value = (isset($_REQUEST[$profile_row['field_ident']])) ? true : ((!isset($user->profile_fields[$user_ident]) || $preview) ? $default_value : $user->profile_fields[$user_ident]);
| $value = (isset($_REQUEST[$profile_row['field_ident']]) && request_var($profile_row['field_ident'], $default_value) == 1) ? true : ((!isset($user->profile_fields[$user_ident]) || $preview) ? $default_value : $user->profile_fields[$user_ident]);
|
} else if ($profile_row['field_type'] == FIELD_INT) {
| } else if ($profile_row['field_type'] == FIELD_INT) {
|
Line 569 | Line 661 |
---|
} else {
|
} else {
|
if (!$preview && isset($user->profile_fields[$user_ident]) && is_null($user->profile_fields[$user_ident]))
| if (!$preview && array_key_exists($user_ident, $user->profile_fields) && is_null($user->profile_fields[$user_ident]))
|
{ $value = NULL; }
| { $value = NULL; }
|
Line 583 | Line 675 |
---|
} }
|
} }
|
return (is_null($value)) ? '' : (int) $value;
| return (is_null($value) || $value === '') ? '' : (int) $value;
|
} else {
| } else {
|
Line 666 | Line 758 |
---|
}
$profile_row['s_year_options'] = '<option value="0"' . ((!$year) ? ' selected="selected"' : '') . '>--</option>';
|
}
$profile_row['s_year_options'] = '<option value="0"' . ((!$year) ? ' selected="selected"' : '') . '>--</option>';
|
for ($i = $now['year'] - 100; $i <= $now['year']; $i++)
| for ($i = $now['year'] - 100; $i <= $now['year'] + 100; $i++)
|
{ $profile_row['s_year_options'] .= '<option value="' . $i . '"' . (($i == $year) ? ' selected="selected"' : '') . ">$i</option>"; }
| { $profile_row['s_year_options'] .= '<option value="' . $i . '"' . (($i == $year) ? ' selected="selected"' : '') . ">$i</option>"; }
|
Line 820 | Line 912 |
---|
{ $now = getdate(); $row['field_default_value'] = sprintf('%2d-%2d-%4d', $now['mday'], $now['mon'], $now['year']);
|
{ $now = getdate(); $row['field_default_value'] = sprintf('%2d-%2d-%4d', $now['mday'], $now['mon'], $now['year']);
|
| } else if ($row['field_default_value'] === '' && $row['field_type'] == FIELD_INT) { // We cannot insert an empty string into an integer column. $row['field_default_value'] = NULL;
|
}
$cp_data['pf_' . $row['field_ident']] = (in_array($row['field_type'], array(FIELD_TEXT, FIELD_STRING))) ? $row['lang_default_value'] : $row['field_default_value'];
| }
$cp_data['pf_' . $row['field_ident']] = (in_array($row['field_type'], array(FIELD_TEXT, FIELD_STRING))) ? $row['lang_default_value'] : $row['field_default_value'];
|
Line 871 | Line 968 |
---|
} else {
|
} else {
|
$var = request_var($var_name, $profile_row['field_default_value']);
| $var = request_var($var_name, (int) $profile_row['field_default_value']);
|
} break;
case FIELD_STRING: case FIELD_TEXT:
|
} break;
case FIELD_STRING: case FIELD_TEXT:
|
$var = utf8_normalize_nfc(request_var($var_name, $profile_row['field_default_value'], true));
| $var = utf8_normalize_nfc(request_var($var_name, (string) $profile_row['field_default_value'], true));
|
break;
case FIELD_INT:
| break;
case FIELD_INT:
|
Line 887 | Line 984 |
---|
} else {
|
} else {
|
$var = request_var($var_name, $profile_row['field_default_value']);
| $var = request_var($var_name, (int) $profile_row['field_default_value']);
|
}
|
}
|
| break;
case FIELD_DROPDOWN: $var = request_var($var_name, (int) $profile_row['field_default_value']);
|
break;
default:
| break;
default:
|