⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 setting.pm

📁 bugzilla
💻 PM
字号:
# -*- Mode: perl; indent-tabs-mode: nil -*-## The contents of this file are subject to the Mozilla Public# License Version 1.1 (the "License"); you may not use this file# except in compliance with the License. You may obtain a copy of# the License at http://www.mozilla.org/MPL/## Software distributed under the License is distributed on an "AS# IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or# implied. See the License for the specific language governing# rights and limitations under the License.## The Original Code is the Bugzilla Bug Tracking System.## Contributor(s): Shane H. W. Travis <travis@sedsystems.ca>#                 Max Kanat-Alexander <mkanat@bugzilla.org>#                 Marc Schumann <wurblzap@gmail.com>#                 Fr茅d茅ric Buclin <LpSolit@gmail.com>package Bugzilla::User::Setting;use strict;use base qw(Exporter);# Module stuff@Bugzilla::User::Setting::EXPORT = qw(get_all_settings get_defaults     add_setting);use Bugzilla::Error;use Bugzilla::Util qw(trick_taint get_text);##################################  Module Initialization  ##################################sub new {    my $invocant = shift;    my $setting_name = shift;    my $user_id = shift;    my $class = ref($invocant) || $invocant;    my $subclass = '';    # Create a ref to an empty hash and bless it    my $self = {};    my $dbh = Bugzilla->dbh;    # Confirm that the $setting_name is properly formed;    # if not, throw a code error.     #     # NOTE: due to the way that setting names are used in templates,    # they must conform to to the limitations set for HTML NAMEs and IDs.    #    if ( !($setting_name =~ /^[a-zA-Z][-.:\w]*$/) ) {      ThrowCodeError("setting_name_invalid", { name => $setting_name });    }    # If there were only two parameters passed in, then we need    # to retrieve the information for this setting ourselves.    if (scalar @_ == 0) {        my ($default, $is_enabled, $value);        ($default, $is_enabled, $value, $subclass) =           $dbh->selectrow_array(             q{SELECT default_value, is_enabled, setting_value, subclass                 FROM setting            LEFT JOIN profile_setting                   ON setting.name = profile_setting.setting_name                WHERE name = ?                  AND profile_setting.user_id = ?},             undef,              $setting_name, $user_id);        # if not defined, then grab the default value        if (! defined $value) {            ($default, $is_enabled, $subclass) =              $dbh->selectrow_array(                 q{SELECT default_value, is_enabled, subclass                   FROM setting                   WHERE name = ?},              undef,              $setting_name);        }        $self->{'is_enabled'} = $is_enabled;        $self->{'default_value'} = $default;        # IF the setting is enabled, AND the user has chosen a setting        # THEN return that value        # ELSE return the site default, and note that it is the default.        if ( ($is_enabled) && (defined $value) ) {            $self->{'value'} = $value;        } else {            $self->{'value'} = $default;            $self->{'isdefault'} = 1;        }    }    else {        ($subclass) = $dbh->selectrow_array(            q{SELECT subclass FROM setting WHERE name = ?},            undef,            $setting_name);        # If the values were passed in, simply assign them and return.        $self->{'is_enabled'}    = shift;        $self->{'default_value'} = shift;        $self->{'value'}         = shift;        $self->{'is_default'}    = shift;    }    if ($subclass) {        eval('require ' . $class . '::' . $subclass);        $@ && ThrowCodeError('setting_subclass_invalid',                             {'subclass' => $subclass});        $class = $class . '::' . $subclass;    }    bless($self, $class);    $self->{'_setting_name'} = $setting_name;    $self->{'_user_id'}      = $user_id;    return $self;}##################################  Subroutine Definitions ##################################sub add_setting {    my ($name, $values, $default_value, $subclass, $force_check) = @_;    my $dbh = Bugzilla->dbh;    my $exists = _setting_exists($name);    return if ($exists && !$force_check);    ($name && $default_value)      ||  ThrowCodeError("setting_info_invalid");    if ($exists) {        # If this setting exists, we delete it and regenerate it.        $dbh->do('DELETE FROM setting_value WHERE name = ?', undef, $name);        $dbh->do('DELETE FROM setting WHERE name = ?', undef, $name);        # Remove obsolete user preferences for this setting.        my $list = join(', ', map {$dbh->quote($_)} @$values);        $dbh->do("DELETE FROM profile_setting                  WHERE setting_name = ? AND setting_value NOT IN ($list)",                  undef, $name);    }    else {        print get_text('install_setting_new', { name => $name }) . "\n";    }    $dbh->do(q{INSERT INTO setting (name, default_value, is_enabled, subclass)                    VALUES (?, ?, 1, ?)},             undef, ($name, $default_value, $subclass));    my $sth = $dbh->prepare(q{INSERT INTO setting_value (name, value, sortindex)                                    VALUES (?, ?, ?)});    my $sortindex = 5;    foreach my $key (@$values){        $sth->execute($name, $key, $sortindex);        $sortindex += 5;    }}sub get_all_settings {    my ($user_id) = @_;    my $settings = get_defaults($user_id); # first get the defaults    my $dbh = Bugzilla->dbh;    my $sth = $dbh->prepare(           q{SELECT name, default_value, is_enabled, setting_value               FROM setting          LEFT JOIN profile_setting                 ON setting.name = profile_setting.setting_name              WHERE profile_setting.user_id = ?           ORDER BY name});    $sth->execute($user_id);    while (my ($name, $default_value, $is_enabled, $value)                = $sth->fetchrow_array()) {        my $is_default;        if ( ($is_enabled) && (defined $value) ) {            $is_default = 0;        } else {            $value = $default_value;            $is_default = 1;        }        $settings->{$name} = new Bugzilla::User::Setting(           $name, $user_id, $is_enabled,            $default_value, $value, $is_default);    }    return $settings;}sub get_defaults {    my ($user_id) = @_;    my $dbh = Bugzilla->dbh;    my $default_settings = {};    $user_id ||= 0;    my $sth = $dbh->prepare(q{SELECT name, default_value, is_enabled                                FROM setting                            ORDER BY name});    $sth->execute();    while (my ($name, $default_value, $is_enabled) = $sth->fetchrow_array()) {        $default_settings->{$name} = new Bugzilla::User::Setting(            $name, $user_id, $is_enabled, $default_value, $default_value, 1);    }    return $default_settings;}sub set_default {    my ($setting_name, $default_value, $is_enabled) = @_;    my $dbh = Bugzilla->dbh;    my $sth = $dbh->prepare(q{UPDATE setting                                 SET default_value = ?, is_enabled = ?                               WHERE name = ?});    $sth->execute($default_value, $is_enabled, $setting_name);}sub _setting_exists {    my ($setting_name) = @_;    my $dbh = Bugzilla->dbh;    my $sth = $dbh->prepare("SELECT name FROM setting WHERE name = ?");    $sth->execute($setting_name);    return ($sth->rows) ? 1 : 0;}sub legal_values {    my ($self) = @_;    return $self->{'legal_values'} if defined $self->{'legal_values'};    my $dbh = Bugzilla->dbh;    $self->{'legal_values'} = $dbh->selectcol_arrayref(              q{SELECT value                  FROM setting_value                 WHERE name = ?              ORDER BY sortindex},        undef, $self->{'_setting_name'});    return $self->{'legal_values'};}sub validate_value {    my $self = shift;    if (grep(/^$_[0]$/, @{$self->legal_values()})) {        trick_taint($_[0]);    }    else {        ThrowCodeError('setting_value_invalid',                       {'name'  => $self->{'_setting_name'},                        'value' => $_[0]});    }}sub reset_to_default {    my ($self) = @_;    my $dbh = Bugzilla->dbh;    my $sth = $dbh->do(q{ DELETE                            FROM profile_setting                           WHERE setting_name = ?                             AND user_id = ?},                       undef, $self->{'_setting_name'}, $self->{'_user_id'});      $self->{'value'}       = $self->{'default_value'};      $self->{'is_default'}  = 1;}sub set {    my ($self, $value) = @_;    my $dbh = Bugzilla->dbh;    my $query;    if ($self->{'is_default'}) {        $query = q{INSERT INTO profile_setting                   (setting_value, setting_name, user_id)                   VALUES (?,?,?)};    } else {        $query = q{UPDATE profile_setting                      SET setting_value = ?                    WHERE setting_name = ?                      AND user_id = ?};    }    $dbh->do($query, undef, $value, $self->{'_setting_name'}, $self->{'_user_id'});    $self->{'value'}       = $value;    $self->{'is_default'}  = 0;}1;__END__=head1 NAMEBugzilla::User::Setting - Object for a user preference setting=head1 SYNOPSISSetting.pm creates a setting object, which is a hash containing the userpreference information for a single preference for a single user. These are usually accessed through the "settings" object of a user, and not directly.=head1 DESCRIPTIONuse 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);=head1 CLASS FUNCTIONS=over 4=item C<add_setting($name, \@values, $default_value)>Description: Checks for the existence of a setting, and adds it              to the database if it does not yet exist.Params:      C<$name> - string - the name of the new setting             C<$values> - arrayref - contains the new choices               for the new Setting.             C<$default_value> - string - the site defaultReturns:     a pointer to a hash of settings=item C<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:      C<$user_id> - integer - the user id.Returns:     a pointer to a hash of settings=item C<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:      C<$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.=item C<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:      C<$setting_name> - string - the name of the setting             C<$default_value> - string - the new default value for this setting             C<$is_enabled> - boolean - if false, all users must use the global defaultReturns:     nothing=begin private=item C<_setting_exists>Description: Determines if a given setting exists in the database.Params:      C<$setting_name> - string - the setting nameReturns:     boolean - true if the setting already exists in the DB.=back=end private=head1 METHODS=over 4=item C<legal_values($setting_name)>Description: Returns all legal values for this settingParams:      noneReturns:     A reference to an array containing all legal values=item C<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 valueReturns:     nothing=item C<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:      noneReturns:     nothing=item C<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=back

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -