summaryrefslogtreecommitdiff
path: root/rt/docs/UPGRADING-3.8
blob: cb53030e4325b3f1c88ed8a80021ca007d6bda6f (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
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
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
UPGRADING FROM 3.8.8 and earlier - Changes:

Previous versions of RT used a password hashing scheme which was too
easy to reverse, which could allow attackers with read access to the RT
database to possibly compromise users' passwords.  Even if RT does no
password authentication itself, it may still store these weak password
hashes -- using ExternalAuth does not guarantee that you are not
vulnerable!  To upgrade stored passwords to a stronger hash, run:

    perl etc/upgrade/vulnerable-passwords

We have also proved that it's possible to delete a notable set of
records from Transactions table without losing functionality. To delete
these records, run the following script:

    perl -I /opt/rt4/local/lib -I /opt/rt4/lib etc/upgrade/shrink_transactions_table.pl

If you chose not to run the shrink_cgm_table.pl script when you upgraded
to 3.8, you should read more about it below and run it at this point.

The default for $MessageBoxWrap is now SOFT and $MessageBoxWidth is now
unset by default.  This means the message box will expand to fill all
the available width.  $MessageBoxWrap is also overridable by the user
now.  These changes accommodate the new default two column layout for
ticket create and update pages.  You may turn this layout off by setting
$UseSideBySideLayout to 0.  To retain the original behavior, set
$MessageBoxWrap to HARD and $MessageBoxWidth to 72.


UPGRADING FROM 3.8.7 and earlier - Changes:

RT's ChartFont option has been changed from a string to a hash which
lets you specify per-language fonts. RT now comes with a better default
font for charts, too.  You should either update your 'ChartFont' option
to match the new format, or consider trying the new default.

RT now gives you more precise control over the order in which custom
fields are displayed.  This change requires some small changes to your
currently saved custom field orders.  RT will automatically clean up
your existing custom fields when you run the standard database upgrade
steps.  After that cleanup, you should make sure that custom fields are
ordered in a way that you and your users find pleasing.


UPGRADING FROM 3.8.6 and earlier - Changes:

For MySQL and Oracle users:
If you upgraded from a version of RT earlier than 3.7.81, you should
already have a CachedGroupMembers3 index on your CachedGroupMembers
table.  If you did a clean install of RT somewhere in the 3.8 release
series, you most likely don't have this index.  You can add it manually
with:

  CREATE INDEX CachedGroupMembers3 on CachedGroupMembers (MemberId, ImmediateParentId);


UPGRADING FROM 3.8.5 and earlier - Changes:

You can now forward an entire Ticket history (in addition to specific
transactions) but this requires a new Template called "Forward Ticket".
This template will be added as part of the standard database upgrade
step.

Custom fields with categories can optionally be split out into
hierarchical custom fields.  If you wish to convert your old
category-based custom fields, run:

    perl etc/upgrade/split-out-cf-categories

It will prompt you for each custom field with categories that it finds,
and the name of the custom field to create to store the categories.

If you were using the LocalizedDateTime RT::Date formatter from custom
code, and passing a DateFormat or TimeFormat argument, you need to
switch from the strftime methods to the cldr methods; that is,
'full_date_format' becomes 'date_format_full'.

You may also have done this from your RT_SiteConfig.pm, using:
    Set($DateTimeFormat, {
        Format => 'LocalizedDateTime',
        DateFormat => 'medium_date_format',
    );
Which would need to be changed to:
    Set($DateTimeFormat, {
        Format => 'LocalizedDateTime',
        DateFormat => 'date_format_medium',
    );


UPGRADING FROM 3.8.3 and earlier - Changes:

Arguments to the NotifyGroup Scrip Action will be updated as part of the
standard database upgrade process.


UPGRADING FROM 3.8.2 and earlier - Changes:

A new scrip condition, 'On Reject', has been added.


UPGRADING FROM 3.8.1 and earlier - Changes:

When using Oracle, $DatabaseName is now used as SID, so RT can connect
without environment variables or tnsnames.ora file. Because of this
change, your RT instance may loose its ability to connect to your DB; to
resolve this, you will need to update RT's configuration and restart
your web server.  Example configuration:

    Set($DatabaseType, 'Oracle');
    Set($DatabaseHost, '192.168.0.1');
    # undefined port => will try both 1526 and 1521
    Set($DatabasePort, undef);
    # ORACLE SID
    Set($DatabaseName, 'XE');
    # user for RT in Oracle, RT's tables in his schema
    Set($DatabaseUser, 'test');
    # above user's password
    Set($DatabasePassword, 'test');

If you want a user to be able to access the Approvals tools (a.k.a.  the
Approvals tab), you must grant that user the "ShowApprovalsTab" right.


UPGRADING FROM 3.8.0 and earlier - Changes:

The TicketSQL syntax for bookmarked tickets has been changed.
Specifically, the new phrasing is "id = '__Bookmarked__'", rather than
the old "__Bookmarks__".  The old form will remain, for backwards
compatibility.  The standard database upgrade process will only
automatically change the global 'Bookmarked Tickets' search


UPGRADING FROM 3.7.85 and earlier - Changes:

We have proved that it is possible to delete a large set of records from
the CachedGroupMembers table without losing functionality; in fact,
failing to do so may result in occasional problems where RT miscounts
users, particularly in the chart functionality.  To delete these records
run the following script:

    perl -I /opt/rt4/local/lib -I /opt/rt4/lib etc/upgrade/shrink_cgm_table.pl

After you run this, you will have significantly reduced the number of
records in your CachedGroupMembers table, and may need to tell your
database to refresh indexes/statistics.  Please consult your DBA for
specific instructions for your database.


UPGRADING FROM 3.7.81 and earlier - Changes:

RT::Extension::BrandedQueues has been integrated into core, and the
handling of subject tags has changed as a consequence.  You will need to
modify any of your email templates which use the $rtname variable, in
order to make them respect the per-queue subject tags. To edit your
templates, log into RT as your administrative user, then click:

    Configuration -> Global -> Templates -> Select -> <Some template name>

The only template which ships with RT which needs updating is the
"Autoreply" template, which includes this line:

    "There is no need to reply to this message right now.  Your ticket
    has been assigned an ID of [{$rtname} #{$Ticket->id()}]."

Change this line to read:

    "There is no need to reply to this message right now.  Your ticket
    has been assigned an ID of { $Ticket->SubjectTag }."

If you were previously using RT::Extension::BrandedQueues, you MUST
uninstall it before upgrading. In addition, you must run the
'etc/upgrade/3.8-branded-queues-extension' perl script.  This will
convert the extension's configuration into the new format.  Finally, in
templates where you were using the Tag method ($Ticket->QueueObj->Tag),
you will need to replace it with $Ticket->SubjectTag

RT::Action::LinearEscalate extension has been integrated into core,
so you MUST uninstall it before upgrading.

RT::Extension::iCal has been integrated into core, so you MUST uninstall
it before upgrading. In addition, you must run etc/upgrade/3.8-ical-extension
script to convert old data.


UPGRADING FROM 3.7.80 and earlier - Changes:

Added indexes to CachedGroupMembers for MySQL and Oracle.
If you have previously installed RTx-Shredder, you may already
have these indexes.  You can see the indexes by looking at
etc/upgrade/3.7.81/schema.*

These indexes may take a very long time to create.