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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
|
#!/usr/bin/perl -w
# -*- 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.
#
# The Initial Developer of the Original Code is Netscape Communications
# Corporation. Portions created by Netscape are
# Copyright (C) 1998 Netscape Communications Corporation. All
# Rights Reserved.
#
# Contributor(s): Gervase Markham <gerv@gerv.net>
# See also https://bugzilla.mozilla.org/show_bug.cgi?id=119569
use 5.10.1;
use strict;
use warnings;
use lib qw(. lib local/lib/perl5);
use Bugzilla;
use Bugzilla::Constants;
sub usage() {
print <<USAGE;
Usage: syncflags.pl <srcproduct> <tgtproduct>
E.g.: syncflags.pl FoodReplicator SeaMonkey
will copy any flag inclusions (only) for the product "FoodReplicator"
so matching inclusions exist for the product "SeaMonkey". This script is
normally used prior to moving components from srcproduct to tgtproduct.
USAGE
exit(1);
}
#############################################################################
# MAIN CODE
#############################################################################
# This is a pure command line script.
Bugzilla->usage_mode(USAGE_MODE_CMDLINE);
if (scalar @ARGV < 2) {
usage();
exit();
}
my ($srcproduct, $tgtproduct) = @ARGV;
my $dbh = Bugzilla->dbh;
# Find product IDs
my $srcprodid = $dbh->selectrow_array("SELECT id FROM products WHERE name = ?",
undef, $srcproduct);
if (!$srcprodid) {
print "Can't find product ID for '$srcproduct'.\n";
exit(1);
}
my $tgtprodid = $dbh->selectrow_array("SELECT id FROM products WHERE name = ?",
undef, $tgtproduct);
if (!$tgtprodid) {
print "Can't find product ID for '$tgtproduct'.\n";
exit(1);
}
# Normal flags such as bug flags and attachment flags
$dbh->do(
"INSERT INTO flaginclusions(component_id, type_id, product_id)
SELECT fi1.component_id, fi1.type_id, ? FROM flaginclusions fi1
LEFT JOIN flaginclusions fi2
ON fi1.type_id = fi2.type_id
AND fi2.product_id = ?
WHERE fi1.product_id = ?
AND fi2.type_id IS NULL", undef, $tgtprodid, $tgtprodid,
$srcprodid
);
# Tracking type flags
$dbh->do(
"INSERT INTO tracking_flags_visibility (tracking_flag_id, product_id, component_id)
SELECT tf1.tracking_flag_id, ?, tf1.component_id FROM tracking_flags_visibility tf1
LEFT JOIN tracking_flags_visibility tf2
ON tf1.tracking_flag_id = tf2.tracking_flag_id
AND tf2.product_id = ?
WHERE tf1.product_id = ?
AND tf2.tracking_flag_id IS NULL", undef, $tgtprodid,
$tgtprodid, $srcprodid
);
# It's complex to determine which items now need to be flushed from memcached.
# As this is expected to be a rare event, we just flush the entire cache.
Bugzilla->memcached->clear_all();
|