summaryrefslogtreecommitdiffstats
path: root/extensions/ComponentWatching/reset-watch-preferences.pl
blob: f190ebd4832b05c113c3009fb64581b109349a46 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
#!/usr/bin/perl

# -*- 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 Component Watching Extension
#
# The Initial Developer of the Original Code is the Mozilla Foundation
# Portions created by the Initial Developers are Copyright (C) 2011 the
# Initial Developer. All Rights Reserved.
#
# Contributor(s):
#   Byron Jones <bjones@mozilla.com>

use strict;
use warnings;

use lib '.';
$| = 1;

use Bugzilla;
use Bugzilla::Constants;
use Bugzilla::Install::Util qw(indicate_progress);

Bugzilla->usage_mode(USAGE_MODE_CMDLINE);

my @DEFAULT_EVENTS = qw(0 2 3 4 5 6 7 9 10 50);
my $REL_COMP_WATCH = 15;

print "This script resets the component watching preferences back to\n";
print "default values.  It is required to be run when upgrading from\n";
print "version 1.0 to 1.1\n";
print "Press <ENTER> to start, or CTRL+C to cancel... ";
getc();
print "\n";

my $dbh = Bugzilla->dbh;

$dbh->bz_start_transaction();

my @users;
my $ra_user_ids = $dbh->selectcol_arrayref(
    "SELECT DISTINCT user_id FROM component_watch"
);

my $total = scalar @$ra_user_ids;
my $count = 0;
foreach my $user_id (@$ra_user_ids) {
    indicate_progress({ current => $count++, total => $total }) if $total > 10;
    $dbh->do(
        "DELETE FROM email_setting WHERE user_id=? AND relationship=?",
        undef,
        $user_id, $REL_COMP_WATCH
    );
    foreach my $event (@DEFAULT_EVENTS) {
        $dbh->do(
            "INSERT INTO email_setting(user_id,relationship,event) VALUES (?,?,?)",
            undef,
            $user_id, $REL_COMP_WATCH, $event
        );
    }
}

$dbh->bz_commit_transaction();

print "Done.\n";