Bugzilla – Bugzilla 3.2.5 Release Notes |
Bugzilla 3.2 にようこそ! これは、Bugzilla 3.0 以来はじめての機能追加のリリースで、さまざまな改善と、Bugzilla の利便性改善を含んでいます。
アップグレードを考えている場合、古いバージョンからの アップグレード方法 を読んでください。3.0 より前のリリースからアップグレードする場合、 以前のバージョン のリリースノートのうち、 あなたが利用しているバージョンとこのバージョンの間の全てのものを読んでください。 特に各バージョンのリリースノートでの "アップグレード利用者向け" の章に目を通してください。
この節では 3.2 以降の最新の Bugzilla 修正版リリースでの変更点を説明しています。 それぞれのリリースでの最も重要な修正のみが掲載されています。 もし、各リリースでどのような変更が加えられたかのすべての詳細が必要なら、 変更点一覧 (英語) を参照してください。
このリリースは非常に重大なセキュリティー修正を含んでいます。詳細については セキュリティー修正の節 を参照してください。
このリリースではセキュリティー修正も含んでいます。 詳細に関しては セキュリティー修正の項 をご覧ください。
recode.pl
が古い Bugzilla のデータベースを変換する際に、
時折クラッシュする問題の修正。
(bug 431201)shadowdb
パラメータを使っているサイトにて、Bugzilla
が、"複数 bug を一度に更新する" ページからの更新時に、
"tokens" テーブルの内容を (master でなく) shadow データベースに書き込んでしまう問題がありました。
(bug 476943)このリリースではセキュリティー修正も含んでいます。 詳細に関しては セキュリティー修正の項 をご覧ください。
このリリースでは 3.2.1 を mod_perl 環境でインストールしたときに発生する 重大なセキュリティー問題1件を修正しています。詳細については、 セキュリティーアドバイザリ をご覧ください。
params
ファイルを更新するための権限が、
ウェブサーバにない場合) Bugzilla はこのような場合にエラーを送出し、
管理者に何がおかしいかを知らせます。
(bug 347707)usemenuforuser
パラメータを利用しており、bug
が無効化されたユーザを担当者としている (もしくは QA コンタクトにしている)
場合、フィーるは bug を更新するときのリストの先頭のユーザに設定されます。
(bug 465589)PROJECT
環境変数を利用し、複数の Bugzilla
サーバを一つのコードで運用している場合、プロジェクト独自のテンプレートが無視されます。
(bug 467324)checksetup.pl
を更新し、
問題のあるバージョンを検出しエラーを出すようにしました。
(bug 468009)このリリースでは一つの重大なセキュリティー問題を修正しています。詳細は セキュリティーアドバイザり をご覧ください。
このリリースでは bug 編集に関するセキュリティー問題1件を修正しています。 詳細については、セキュリティーアドバイザリ をご覧ください。
このリリースでは添付ファイルに関するセキュリティー問題1件を修正しています。 詳細については、セキュリティーアドバイザリ をご覧ください。
このリリースでは 3.2.1 を mod_perl 環境でインストールしたときに発生する 重大なセキュリティー問題1件を修正しています。詳細については、 セキュリティーアドバイザリ をご覧ください。
このリリースでは複数のセキュリティー更新を含みます。中には、process_bug.cgi を直接呼び出すような自動スクリプトすべてに影響する問題もあります。 これらの詳細について、このリリースの セキュリティーアドバイザリ を読むことを強く推奨します。
3.0.5 以降の動作環境の更新は このように 表示されます。
Perl v5.8.1
モジュール | バージョン |
---|---|
CGI | 3.33 |
Date::Format | 2.21 |
File::Spec | 0.84 |
DBI | 1.41 |
Template | 2.15 |
Email::Send | 2.00 |
Email::MIME | 1.861 |
Email::MIME::Encodings | 1.313 |
Email::MIME::Modifier | 1.442 |
以下の perl モジュールがインストールされていれば、Bugzilla のさまざまな機能が有効化されます:
モジュール | バージョン | 有効になる機能 |
---|---|---|
LWP::UserAgent | (指定なし) | Automatic Update Notifications |
Template::Plugin::GD::Image | (指定なし) | Graphical Reports |
GD::Text | (指定なし) | Graphical Reports |
GD::Graph | (指定なし) | Graphical Reports |
GD | 1.20 | Graphical Reports, New Charts, Old Charts |
Email::MIME::Attachment::Stripper | (指定なし) | Inbound Email |
Email::Reply | (指定なし) | Inbound Email |
Net::LDAP | (指定なし) | LDAP Authentication |
HTML::Parser | 3.40 | More HTML in Product/Group Descriptions |
HTML::Scrubber | (指定なし) | More HTML in Product/Group Descriptions |
XML::Twig | (指定なし) | Move Bugs Between Installations |
MIME::Parser | 5.406 | Move Bugs Between Installations |
Chart::Base | 1.0 | New Charts, Old Charts |
Image::Magick | (指定なし) | Optionally Convert BMP Attachments to PNGs |
PatchReader | 0.9.4 | Patch Viewer |
Authen::Radius | (指定なし) | RADIUS Authentication |
Authen::SASL | (指定なし) | SMTP Authentication |
SOAP::Lite | (指定なし) | XML-RPC Interface |
mod_perl2 | 1.999022 | mod_perl |
Bugzilla 3.2 では NASA HCI と新しい Bugzilla UI チーム による新しい UI が導入されました。
特に、新スキン に加え、bug 編集フォームの内容が大幅に更新されています。
Bugzilla 3.2 では新しい "Dusk" と呼ばれるスキンを利用しています。 これは古い既定の "Classic" スキンに比べて少しカラフルになっています。
アップグレードを行うと、既定は "Classic" スキンのままになりますが、 管理者はコントロールパネルの規定の設定から変更できます。 ユーザも自身の設定から古いスキンを選択することも可能です。 (もしくは、Firefox の表示 :: スタイルシートメニューから。)
Bugzilla に Dusk を適用するための変更により Bugzilla のスキンがより作りやすくなりました。 アドオンページ にある追加のスキンや、自分のを作ってみてください !
Bugzilla でのステータスのリストやステータス間の遷移を、 カスタマイズ可能になりました。
特定の遷移を行う際にコメントを入力しなければならないように設定することも可能です。
Bugzilla 3.2 から3つの新しいカスタムフィールドの型が利用可能です :
Bugzilla に、install-module.pl スクリプトが添付されるようになり、Bugzilla に必要な Perl モジュールを、 自動的にダウンロードしてインストール可能です。 このスクリプトでは、Bugzilla のディレクトリの下にインストールするので、 ホストの管理者レベルの権限が必要なく、システムの Perl に変更なしに利用可能になります。
checksetup.pl で、install-module.pl の利用方法を出力しますし、 ドキュメント にも解説があります。
Bugzilla 3.2 では Oracle をデータベースに利用するための、 実験的なサポートを含みます。Bugzilla のいくつかの機能は、 Oracle では動かないことが確認されていますが、 次のリリースでは動作するようになるでしょう。
Bugzilla プロジェクトは、オープンソースプロジェクトとして、 もちろんのことながらプロプラエタリなデータベース環境を強要するわけではありません。 しかしながら、あなたの組織が Oracle を利用することを指定しているなら、 この実装により Bugzilla を利用することができるようになります !
Bugzilla プロジェクトは Oracle 社に対し、 Oracle が利用可能になった Bugzilla への多大な開発での貢献について感謝します。
Bugzilla 3.2 ではコード自体の UTF-8 サポートが強化され、 多バイト言語での切り詰めやラッピングも改善されました。 多バイトなどの言語での主な問題は解決され、Bugzilla は最低限の (か少ない) カスタマイズで全ての国で 利用可能になっています。
管理者は特定のグループに所属するユーザに対して、 コメントに表示される名前の後ろにアイコンを表示するように指定可能です。bug 報告者の中から開発者を見分けるために便利なこともあります。
これ以外にも細かい機能追加や、短い説明でわかる拡張があります。 ただ、これらの中にも有用なものもあります !
ssl
パラメータが
"authenticated sessions" である場合、
ログイン後のアクセスすべてを保護するようになりました。
また、これが設定されていれば、SSL
はウェブサービスインターフェースでも要求されます。max_packet_size
を追加しなくてよくなりました。
しかしながら、mysqldump などでデータベースに手動でリストアする際には必要でしょう。shutdownhtml
パラメータが Bugzilla
のデータベースサーバが落ちているときにも動作するようになりました。上記の注意を読んだあとは、 アップグレードに関するドキュメント を参照してアップグレードしてください。
3.0 に比べて 3.2 ではよりフックできる場所が増えました。詳細に関しては、 Bugzilla::Hook のドキュメントを参照してください。
Bugzilla/Search.pm は大幅に書き換えられ、より簡単に読め、 利用できるようになりました。3.0 と大部分は同じコードですが、 移動され、単純な形に再構築されました。
install-module.pl の実装上、 標準的なシステムパスに加えて、ローカルの lib ディレクトリを、 モジュール検索のパスに Bugzilla が追加するようになりました。
これは、全ての Bugzilla スクリプトが、
use lib qw(. lib);
を先頭の行として始まることを意味します。
status_descs.NEW
の代わりに get_status('NEW')
をテンプレート中で利用すべきです。[%# version = 1.0 %]
コメントは削除されました。Welcome to Bugzilla 3.0! It's been over eight years since we released Bugzilla 2.0, and everything has changed since then. Even just since our previous release, Bugzilla 2.22, we've added a lot of new features. So enjoy the release, we're happy to bring it to you.
If you're upgrading, make sure to read How to Upgrade From An Older Version. If you are upgrading from a release before 2.22, make sure to read the release notes for all the previous versions in between your version and this one.
This section describes what's changed in the most recent bug-fix releases of Bugzilla after 3.0. We only list the most important fixes in each release. If you want a detailed list of everything that's changed in each version, you should use our Change Log Page.
faultCode
that was a string instead of a number.
(bug 446327)See also the Security Advisory section for information about a security issue fixed in this release.
Email::
modules are required in Perl, thus avoiding the
problem where emails show up with a body like
SCALAR(0xBF126795).
(bug 441541)See also the Security Advisory section for information about security issues fixed in this release.
See also the Security Advisory section for information about security issues fixed in this release.
See also the Security Advisory section for information about an important security issue fixed in this release.
show_bug.cgi
user interface
should no longer "collapse" after you modify a bug.
(bug 370739)specific_search_allow_empty_words
.
(bug 385910)text/x-patch
or text/x-diff
, it will automatically be treated as a
patch by Bugzilla.
(bug 365756)data
directory called
errorlog
, in which case warnings will be printed there.
(bug 390148)ThrowUserError
.
(bug 380709)Date
header.
(bug 304999).Bug.legal_values
now
correctly returns values for custom fields if you request values
for custom fields.
(bug 381737)urlbase
parameter included a port number,
like www.domain.com:8080
, SMTP might have failed.
(bug 384501)smtp_debug
.
Turning on this parameter will log the full information about
every SMTP session to your web server's error log, to help with
debugging issues with SMTP.
(bug 384497)2.22 以降の動作環境の更新は このように 表示されます。
モジュール | バージョン |
---|---|
CGI | 2.93 |
Date::Format | 2.21 |
DBI | 1.41 |
File::Spec | 0.84 |
Template | 2.12 |
Email::Send | 2.00 |
Email::MIME | 1.861 |
Email::MIME::Modifier | 1.442 |
以下の perl モジュールがインストールされていれば、Bugzilla のさまざまな機能が有効化されます:
モジュール | バージョン | 有効化される機能 |
---|---|---|
LWP::UserAgent | (指定なし) | Automatic Update Notifications |
Template::Plugin::GD::Image | (指定なし) | Graphical Reports |
GD::Graph | (指定なし) | Graphical Reports |
GD::Text | (指定なし) | Graphical Reports |
GD | 1.20 | Graphical Reports, New Charts, Old Charts |
Email::MIME::Attachment::Stripper | (指定なし) | Inbound Email |
Email::Reply | (指定なし) | Inbound Email |
Net::LDAP | (指定なし) | LDAP Authentication |
HTML::Parser | 3.40 | More HTML in Product/Group Descriptions |
HTML::Scrubber | (指定なし) | More HTML in Product/Group Descriptions |
XML::Twig | (指定なし) | Move bug Between Installations |
MIME::Parser | 5.406 | Move bug Between Installations |
Chart::Base | 1.0 | New Charts, Old Charts |
Image::Magick | (指定なし) | Optionally Convert BMP Attachments to PNGs |
PatchReader | 0.9.4 | Patch Viewer |
SOAP::Lite | (指定なし) | XML-RPC Interface |
mod_perl2 | 1.999022 | mod_perl |
CGI | 3.11 | mod_perl |
Bugzilla now includes very basic support for custom fields.
Users in the admin group can add plain-text or drop-down custom fields. You can edit the values available for drop-down fields using the "Field Values" control panel.
Don't add too many custom fields! It can make Bugzilla very difficult to use. Try your best to get along with the default fields, and then if you find that you can't live without custom fields after a few weeks of using Bugzilla, only then should you start your custom fields.
Bugzilla 3.0 supports mod_perl, which allows for extremely enhanced page-load performance. mod_perl trades memory usage for performance, allowing near-instantaneous page loads, but using much more memory.
If you want to enable mod_perl for your Bugzilla, we recommend a minimum of 1.5GB of RAM, and for a site with heavy traffic, 4GB to 8GB.
If performance isn't that critical on your installation, you don't have the memory, or you are running some other web server than Apache, Bugzilla still runs perfectly as a normal CGI application, as well.
Users can now choose to "share" their saved searches with a certain group. That group will then be able to "subscribe" to those searches, and have them appear in their footer.
If the sharer can "bless" the group he's sharing to, (that is, if he can add users to that group), it's considered that he's a manager of that group, and his queries show up automatically in that group's footer (although they can unsubscribe from any particular search, if they want.)
In order to allow a user to share their queries, they also
have to be a member of the group specified in the
querysharegroup
parameter.
Users can control their shared and subscribed queries from the "Preferences" screen.
You can now add an attachment while you are filing a new bug.
You can also set flags on the bug and on attachments, while filing a new bug.
You can now customize the list of resolutions available in Bugzilla, including renaming the default resolutions.
The resolutions FIXED
, DUPLICATE
and MOVED
have a special meaning to Bugzilla,
though, and cannot be renamed or deleted.
You can now grant users editbugs and canconfirm for only certain products. You can also grant users editcomponents on a product, which means they will be able to edit that product including adding/removing components and other product-specific controls.
There has been some work on the user interface for Bugzilla 3.0, including:
Bugzilla now has a Web Services interface using the XML-RPC protocol. It can be accessed by external applications by going to the xmlrpc.cgi on your installation.
Documentation can be found in the Bugzilla API Docs, in the various Bugzilla::WebService modules.
Bugzilla can have multiple "skins" installed, and users can pick between them. To write a skin, you just have to write several CSS files. See the Custom Skins Documentation for more details.
We currently don't have any alternate skins shipping withBugzilla. If you write an alternate skin, please let us know!
As long as you are logged in, when viewing bug, if you cannot change a field, it will not look like you can change it. That is, the value will just appear as plain text.
All outbound emails are now controlled by the templating system.
What used to be the passwordmail
, whinemail
,
newchangedmail
and voteremovedmail
parameters are now all templates in the template/ directory.
This means that it's now much easier to customize your outbound emails, and it's also possible for localizers to have more localized emails as part of their language packs, if they want.
We also added a mailfrom
parameter to let you set
who shows up in the From
field on all emails that
Bugzilla sends.
Users of Bugzilla will sometimes accidentally submit bug twice, either by going back in their web browser, or just by refreshing a page. In the past, this could file the same bug twice (or even three times) in a row, irritating developers and confusing users.
Now, if you try to submit bug twice from the same screen (by going back or by refreshing the page), Bugzilla will warn you about what you're doing, before it actually submits the duplicate bug.
You can specify a list of users who will always be added to the CC list of new bug in a component.
You can now file or modify bug via email. Previous versions of Bugzilla included this feature only as an unsupported add-on, but it is now an official interface to Bugzilla.
For more details see the documentation for email_in.pl.
There is now a parameter called globalwatchers. This is a comma-separated list of Bugzilla users who will get all bug notifications generated by Bugzilla.
Group controls still apply, though, so users who can't see a bug still won't get notifications about that bug.
Bugzilla users running MySQL should now have excellent UTF-8 support if they turn on the utf8 parameter. (New installs have this parameter on by default.) Bugzilla now correctly supports searching and sorting in non-English languages, including multi-bytes languages such as Chinese.
If you belong to the admin group, you will be notified when you log in if there is a new release of Bugzilla available to download.
You can control these notifications by changing the upgrade_notification parameter.
If your Bugzilla installation is on a machine that needs to go through a proxy to access the web, you may also have to set the proxy_url parameter.
When you log in for the first time on a brand-new Bugzilla installation, you will be presented with a page that describes where you should go from here, and what parameters you should set.
Firefox 2 users and Internet Explorer 7 users will be presented with the option to add Bugzilla to their search bar. This uses the QuickSearch syntax.
These are either minor enhancements, or enhancements that have very short descriptions. Some of these are very useful, though!
X-Bugzilla-Status
,
X-Bugzilla-Priority
, X-Bugzilla-Assigned-To
,
X-Bugzilla-Target-Milestone
, and
X-Bugzilla-Changed-Fields
, X-Bugzilla-Who
.
You can look at an email to get an idea of what they contain.X-Bugzilla-Reason
email header
which tells you why you got an email, if you got an email because
you were watching somebody, there is now an
X-Bugzilla-Watch-Reason
header that tells you who you
were watching and what role they had.http://bugs.mycompany.com/show_bug.cgi?id=1212
) that
links to bug, you will see the title of the
bug. Of course, this only works for bug in your
Bugzilla installation.REMIND
and LATER
are no longer part
of the default list of resolutions. Upgrading installations will
not be affected--they will still have these resolutions.Bugzilla contains a minor security fix. 詳細は セキュリティアドバイザリ を参照してください。
Bugzilla contains one security fix for importxml.pl. 詳細は セキュリティアドバイザリ を参照してください。
Bugzilla 3.0.4 contains three security fixes. 詳細は セキュリティアドバイザリ を参照してください。
セキュリティー更新はありませんでした。
Bugzilla 3.0.1 had an important security fix that is critical for public installations with "requirelogin" turned on. 詳細は セキュリティアドバイザリ を参照してください。
Bugzilla 3.0 had three security issues that have been
fixed in this release: one minor information leak, one hole only
exploitable by an admin or using email_in.pl
, and one in an
uncommonly-used template. 詳細は
セキュリティアドバイザリ
を参照してください。
Once you have read the notes above, see the Upgrading documentation for instructions on how to upgrade.
In previous versions of Bugzilla, Bugzilla::Config held all the paths for different things, such as the path to localconfig and the path to the data/ directory.
Now, all of this data is stored in a subroutine, Bugzilla::Constants::bz_locations.
Also, note that for mod_perl, bz_locations must return absolute (not relative) paths. There is already code in that subroutine to help you with this.
Bugzilla now supports a code hook mechanism. See the documentation for Bugzilla::Hook for more details.
This gives Bugzilla very advanced plugin support. You can hook templates, hook code, add new parameters, and use the XML-RPC interface. So we'd like to see some Bugzilla plugins written! Let us know on the developers@bugzilla.org mailing list if you write a plugin.
If you need more hooks, please File a bug!
Bugzilla now ships with all of its perldoc built as HTML. Go ahead and read the API Documentation for all of the Bugzilla modules now! Even scripts like checksetup.pl have HTML documentation.
The old file globals.pl has been eliminated. Its code is now in various modules. Each function went to the module that was appropriate for it.
Usually we filed bug in bugzilla.mozilla.org for each function we moved. You can search there for the old name of the function, and that should get you the information about what it's called now and where it lives.
In normal perl, you can have code like this:
my $var = 0; sub y { $var++ }
However, under mod_perl that doesn't work. So variables are no longer "shared" with subroutines--instead all variables that a subroutine needs must be declared inside the subroutine itself.
The old SendSQL function and all of its companions are gone. Instead, we now use DBI for all database interaction.
For more information about how to use DBI with Bugzilla, see the Developer's Guide Section About DBI
The Bugzilla::Auth family of modules have been completely re-written. For details on how the new structure of authentication, read the Bugzilla::Auth API docs.
It should be very easy to write new authentication plugins, now.
There is a new base class for most of our objects, Bugzilla::Object. It makes it really easy to create new objects based on things that are in the database.
Bugzilla.pm used to cache things like the database
connection in package-global variables (like $_dbh).
That doesn't work in mod_perl, so instead now there's a hash
that can be accessed through Bugzilla->request_cache
to store things for the rest of the current page request.
You shouldn't access Bugzilla->request_cache
directly,
but you should use it inside of Bugzilla.pm if you modify
that. The only time you should be accessing it directly is if you need
to reset one of the caches. Hash keys are always named after the function
that they cache, so to reset the template object, you'd do:
delete Bugzilla->request_cache->{template};
.
checksetup.pl
has been completely re-written, and most
of its code moved into modules in the Bugzilla::Install
namespace. See the
checksetup
documentation and Bugzilla
bug 277502 for details.Bugzilla->localconfig
hash instead of through
Bugzilla::Config.Release notes for versions of Bugzilla for versions prior to 3.0 are only available in text format: Release Notes for Bugzilla 2.22 and Earlier.