| 1 | = CGIとして Trac をインストールする = |
| 2 | |
| 3 | Trac を CGI スクリプトとしてインストールするために、 Web サーバが `trac.cgi` を CGI として実行できるようにする必要があります。使用している Web サーバが [http://httpd.apache.org/ Apache HTTPD] であれば、2つの方法があります: |
| 4 | |
| 5 | 1. `ScriptAlias` を使用し、 `trac.cgi` スクリプトを URL にマップする。 |
| 6 | 2. CGI プログラムが実行可能な、Web サーバ上のディレクトリ (通常は `cgi-bin` が使用される) に `trac.cgi` ファイルをコピーする。シンボリックリンクでも代用できますが、その場合 `cgi-bin` ディレクトリでは `FollowSymLinks` オプションを有効にして下さい。 |
| 7 | |
| 8 | CGI を分かりやすい URL にマッピングできるので、 1 番目のオプションを推奨します。 |
| 9 | |
| 10 | それでは、 Apache の設定ファイルに以下のブロックを追記し、ファイル名とロケーションを変更してください: |
| 11 | {{{ |
| 12 | ScriptAlias /trac /usr/share/trac/cgi-bin/trac.cgi |
| 13 | |
| 14 | # Trac needs to know where the database is located |
| 15 | <Location "/trac"> |
| 16 | SetEnv TRAC_ENV "/path/to/projectenv" |
| 17 | </Location> |
| 18 | }}} |
| 19 | |
| 20 | `http://yourhost.example.org/trac` のような URL で Trac が使用できるようになります。 |
| 21 | |
| 22 | ''Note: 上記の設定で Apache がエラーを出力する場合、 `mod_alias` と `mod_env` モジュールが有効な状態になっていることを確認して下さい。'' |
| 23 | |
| 24 | ''Note: [http://httpd.apache.org/docs/suexec.html Apache suEXEC] 機能を使用している場合、 [http://projects.edgewall.com/trac/wiki/ApacheSuexec ApacheSuexec] を参照して下さい。'' |
| 25 | |
| 26 | == 静的なリソースをマッピングする == |
| 27 | |
| 28 | このままでも Trac はスタイルシートや画像ファイルなどの静的なリソースを扱えますが、 CGI のセットアップとしては妥当な設定とは言えません。 Web サーバ自身がより効率良くに扱うことができるドキュメントまで、 CGI スクリプトとして呼び出してしまうという結果になるからです。 |
| 29 | |
| 30 | [http://httpd.apache.org/ Apache HTTPD] のような Web サーバはリソースに対して "Alias" を設定することで仮想の URL を与え、サーバのファイルシステムのレイアウトとは異なる位置にマップすることができます。すでに CGI スクリプトに対して `ScriptAlias` を定義していますので、ファイルシステム上の静的リソースを含んだコンテンツをマッピングすることで CGI スクリプトの要求を回避します。 |
| 31 | |
| 32 | Apacheの設定ファイルを再び編集して、 CGI スクリプトの `ScriptAlias` を追記したブロックより '''上に''' 以下のブロックを追記します。ファイル名とロケーションは適宜変更してください: |
| 33 | {{{ |
| 34 | Alias /trac/chrome/common /usr/share/trac/htdocs |
| 35 | <Directory "/usr/share/trac/htdocs"> |
| 36 | Order allow,deny |
| 37 | Allow from all |
| 38 | </Directory> |
| 39 | }}} |
| 40 | |
| 41 | `trac.cgi` スクリプトにどんな URL をマッピングしたとしても、 `/chrome/common` というパスでは静的リソースのロケーションを使用するようになります。 |
| 42 | |
| 43 | 例えば、Trac が `/cgi-bin/trac.cgi`にマッピングされているとしたら、AliasのURLは `cgi-bin/trac.cgi/chrome/common` となります。 |
| 44 | |
| 45 | 代わりに、[wiki:TracIni trac.ini] のオプションで `htdocs_location` を設定することができます: |
| 46 | {{{ |
| 47 | [trac] |
| 48 | htdocs_location = /trac-htdocs |
| 49 | }}} |
| 50 | |
| 51 | Trac は HTML ページに静的リソースを組み込むときに、この URL を使用するようになります。もちろん、それでも、特定の URL が指定されたときに 例えば、 Web サーバーのドキュメントルートにディレクトリをコピーするなり、シンボリックリンクを張るなりして、Web サーバ経由で、 Trac が `htdocs` ディレクトリを利用できるようにしておく必要があります。 |
| 52 | |
| 53 | == 認証を追加する == |
| 54 | |
| 55 | Apache で認証を追加する最も単純な方法はパスワードファイルを作ることです。 `htpasswd` プログラムを使用してパスワードファイルを作成します: |
| 56 | {{{ |
| 57 | $ htpasswd -c /somewhere/trac.htpasswd admin |
| 58 | New password: <type password> |
| 59 | Re-type new password: <type password again> |
| 60 | Adding password for user admin |
| 61 | }}} |
| 62 | |
| 63 | 一番最初のユーザ以外は "-c" オプションは必要ありません: |
| 64 | {{{ |
| 65 | $ htpasswd /somewhere/trac.htpasswd john |
| 66 | New password: <type password> |
| 67 | Re-type new password: <type password again> |
| 68 | Adding password for user john |
| 69 | }}} |
| 70 | |
| 71 | ''`htpasswd` についての詳細は man を見てください。'' |
| 72 | |
| 73 | ユーザを作成した後、 TracPermissions の記述通りユーザに権限を設定することができます。 |
| 74 | |
| 75 | Apache の設定ファイルの中にパスワードファイル名を記述し、認証を有効にする必要があります: |
| 76 | {{{ |
| 77 | <Location "/cgi-bin/trac.cgi/login"> |
| 78 | AuthType Basic |
| 79 | AuthName "Trac" |
| 80 | AuthUserFile /somewhere/trac.htpasswd |
| 81 | Require valid-user |
| 82 | </Location> |
| 83 | }}} |
| 84 | |
| 85 | より堅固なセキュリティのために、 SSL を有効にするか、少なくとも "基本認証" の代わりに "ダイジェスト認証" を使用することを推奨します。より詳しい情報については [http://httpd.apache.org/docs/2.0/ Apache HTTPD documentation] を参照して下さい。 |
| 86 | |
| 87 | ---- |
| 88 | See also: TracGuide, TracInstall, TracFastCgi, TracModPython |