5.7.77. Bugzilla::User::Setting

5.7.77.1. NAME

Bugzilla::User::Setting - Object for a user preference setting

5.7.77.2. SYNOPSIS

Setting.pm creates a setting object, which is a hash containing the user preference information for a single preference for a single user. These are usually accessed through the "settings" object of a user, and not directly.

5.7.77.3. DESCRIPTION

use Bugzilla::User::Setting; my $settings;

$settings->{$setting_name} = new Bugzilla::User::Setting(
$setting_name, $user_id);

OR

$settings->{$setting_name} = new Bugzilla::User::Setting(
$setting_name, $user_id, $is_enabled, $default_value, $value, $is_default);

5.7.77.4. CLASS FUNCTIONS

add_setting($name, \@values, $default_value, $subclass, $force_check)

Description: Checks for the existence of a setting, and adds it
to the database if it does not yet exist.
Params: $name - string - the name of the new setting
$values - arrayref - contains the new choices
for the new Setting.

$default_value - string - the site default $subclass - string - name of the module returning

the list of valid values. This means legal values are not stored in the DB.
$force_check - boolean - when true, the existing setting
and all its values are deleted and replaced by new data.

Returns: a pointer to a hash of settings

get_all_settings($user_id)

Description: Provides the user's choices for each setting in the
system; if the user has made no choice, uses the site default instead.

Params: $user_id - integer - the user id. Returns: a pointer to a hash of settings

get_defaults($user_id)

Description: When a user is not logged in, they must use the site
defaults for every settings; this subroutine provides them.
Params: $user_id (optional) - integer - the user id. Note that
this optional parameter is mainly for internal use only.
Returns: A pointer to a hash of settings. If $user_id was passed, set
the user_id value for each setting.

set_default($setting_name, $default_value, $is_enabled)

Description: Sets the global default for a given setting. Also sets
whether users are allowed to choose their own value for this setting, or if they must use the global default.
Params: $setting_name - string - the name of the setting
$default_value - string - the new default value for this setting $is_enabled - boolean - if false, all users must use the global default

Returns: nothing

clear_settings_cache($user_id)

Description: Clears cached settings data for the specified user. Must be
called after updating any user's setting.

Params: $user_id - integer - the user id. Returns: nothing

_setting_exists

Description: Determines if a given setting exists in the database. Params: C<$setting_name> - string - the setting name Returns: boolean - true if the setting already exists in the DB.

5.7.77.5. METHODS

legal_values($setting_name)

Description: Returns all legal values for this setting Params: none Returns: A reference to an array containing all legal values

validate_value

Description: Determines whether a value is valid for the setting
by checking against the list of legal values. Untaints the parameter if the value is indeed valid, and throws a setting_value_invalid code error if not.

Params: An lvalue containing a candidate for a setting value Returns: nothing

reset_to_default

Description: If a user chooses to use the global default for a given
setting, their saved entry is removed from the database via this subroutine.

Params: none Returns: nothing

set($value)

Description: If a user chooses to use their own value rather than the
global value for a given setting, OR changes their value for a given setting, this subroutine is called to insert or update the database as appropriate.

Params: C<$value> - string - the new value for this setting for this user. Returns: nothing


This documentation undoubtedly has bugs; if you find some, please file them here.