| 1 | = リポジトリ管理 = #RepositoryAdministration |
| 2 | [[PageOutline(2-3)]] |
| 3 | |
| 4 | == クイックスタート == #QuickStart |
| 5 | |
| 6 | * リポジトリの管理は、 "リポジトリ" (英語版では "Repository") 管理パネル、 `trac-admin` または、 [wiki:TracIni#repositories-section trac.ini] の `[repositories]` セクションで管理します。 |
| 7 | * 各リポジトリの post-commit フックに `trac-admin $ENV changeset added $REPO $REV` を実行するよう設定して下さい。さらに、リポジトリのリビジョンのプロパティが変更されたときのために、 post-revprop-change フックに `trac-admin $ENV changeset modified $REPO $REV` を追加してください。 |
| 8 | * `[trac] repository_sync_per_request` オプションを empty 値に設定し、リクエスト毎の同期を行なわないようにします。 |
| 9 | |
| 10 | |
| 11 | == リポジトリを指定する == #Repositories |
| 12 | バージョン 0.12 から Trac は 1 つの Trac Environment に対して 1 つ以上のリポジトリを扱えるようになりました。 0.12 以前の [wiki:TracIni trac.ini] の `[trac]` セクションの `repository_dir` と `repository_type` オプションでリポジトリを指定する方法もサポートしていますが、 2 つの新しいメカニズムにより、 Trac Environment にリポジトリを追加することができます。 |
| 13 | |
| 14 | リポジトリのエイリアスを定義することも可能です。エイリアスは実際のリポジトリへの "ポインタ" となります。これはリポジトリの名前変更を行なったときに古い名前へのリンク切れを防ぐのに便利です。 |
| 15 | |
| 16 | 各リポジトリに関連したいくつかの属性があり、リポジトリのロケーション、名前、リポジトリブラウザでどのように表示されるかを定義できます。下記の属性がサポートされています: |
| 17 | |
| 18 | ||='''属性''' =||='''概要''' =|| |
| 19 | ||`alias` ||\ |
| 20 | ||リポジトリは 実在するリポジトリへのエイリアスとなる `alias` 属性を 1 つ持っています。すべての TracLinks はエイリアスされたリポジトリを解決するためにエイリアスを参照します。複数の間接参照はサポートされていません。従って、エイリアスは常に実在するリポジトリをポイントしなければなりません。 `alias` 属性と `dir` 属性は相反するものです。 || |
| 21 | ||`description` ||\ |
| 22 | ||`description` 属性で指定されているテキストは、リポジトリブラウザ内のそのリポジトリのトップレベルのエントリの下部に表示されます。 WikiFormatting をサポートします。 || |
| 23 | ||`dir` ||\ |
| 24 | ||`dir` 属性はファイルシステム内におけるリポジトリのロケーションを指定します。これは以前に設定していた `[trac] repository_dir` と一致するものです。 `alias` 属性と `dir` 属性は相反する設定です。 || |
| 25 | ||`hidden` ||`true` に設定すると、リポジトリブラウザのインデックスのページから見えなくなります。それでもなお、リポジトリをブラウズすることはできますし、リポジトリを参照するリンクは有効です。 || |
| 26 | ||`name` ||`name` 属性はリポジトリへ通じるパスの一部を指定します。 || |
| 27 | ||`type` ||`type` 属性はリポジトリが使用しているバージョン管理システムのタイプを設定します。 Trac は Subversion を当初からサポートしており、プラグインを使用して他のシステムをサポートします。もし `type` 属性が指定されていなかったら、 `[trac] repository_type` オプションの値が使用されます。 || |
| 28 | ||`url` ||`url` 属性はリポジトリからチェックアウトするときに使用するルートのURLを指定します。指定された場合、 "リポジトリ URL" リンクがリポジトリブラウザのナビゲーションコンテキストに追加されます。 URL はツールにコピーすることができるので、ワーキングコピーを作るときに使用できます。 || |
| 29 | |
| 30 | `name` 属性と`alias` 属性または `dir` 属性は必須項目です。他の項目はオプションです。 |
| 31 | |
| 32 | リポジトリを追加した後、そのリポジトリのキャッシュは `trac-admin $ENV repository resync` コマンドで再同期されなければなりません。 |
| 33 | |
| 34 | `repository resync <repos>`:: |
| 35 | Trac とリポジトリを再同期する。 |
| 36 | |
| 37 | |
| 38 | === ファイル (`trac.ini`) を使用した設定 === #ReposTracIni |
| 39 | リポジトリとリポジトリの属性は [wiki:TracIni#repositories-section trac.ini] の `[repositories]` セクションで設定することができます。すべてのキーは `{name}.{attribute}` という規則で構成されていて、キーに対応する値は、等号 (`=`) で区切られています。デフォルトのリポジトリの名前は empty になります。 |
| 40 | |
| 41 | `trac.ini` でリポジトリを設定する主たる利点は、グローバルな設定から継承できることです ( TracIni の [wiki:TracIni#GlobalConfiguration グローバルな設定 ] 参照 ) 欠点は、 `trac.ini` をパースするのに使用されている `ConfigParser` クラスの制限事項として、リポジトリ名が常に小文字しか受け付けないということです。 |
| 42 | |
| 43 | 下記の例では `project`, `lib` という 2 つのSubversion リポジトリが定義されています。そして、デフォルトのリポジトリとしてエイリアスが `project` に設定されていて、hidden 属性設定されています。これは以前の Trac Environment が単一のリポジトリ ( `project` リポジトリ ) を扱っていたときの典型的な使用例です。エイリアスは設定変更前から存在するリンクが `project` リポジトリを解決できることを保証します。 |
| 44 | {{{ |
| 45 | #!ini |
| 46 | [repositories] |
| 47 | project.dir = /var/repos/project |
| 48 | project.description = This is the ''main'' project repository. |
| 49 | project.type = svn |
| 50 | project.url = http://example.com/svn/project |
| 51 | lib.dir = /var/repos/lib |
| 52 | lib.description = This is the secondary library code. |
| 53 | lib.type = svn |
| 54 | lib.url = http://example.com/svn/lib |
| 55 | .alias = project |
| 56 | .hidden = true |
| 57 | }}} |
| 58 | Note: `name.alias = target` の場合、 `name` を `target` リポジトリへのエイリアスにします。他の方法がありません。 |
| 59 | |
| 60 | === データベースを使用した設定 === #ReposDatabase |
| 61 | リポジトリは (trac.ini ファイルではなく) データベース内でも設定することができます。 "バージョンコントロール" (英語版では "Version Control") 配下の "リポジトリ" 管理パネル、もしくは `trac-admin $ENV repository` コマンドを使用します。 |
| 62 | |
| 63 | 管理パネルは Trac Environment 内に定義されているすべてのリポジトリのリストを表示します。リポジトリ、エイリアスの追加、リポジトリの属性の編集、リポジトリの削除ができます。 `trac.ini` に定義されているリポジトリもまた表示されますが、編集はできません。 |
| 64 | |
| 65 | 以下の [wiki:TracAdmin trac-admin] コマンドはコマンドラインからリポジトリを操作する際に使用します。 |
| 66 | |
| 67 | `repository add <repos> <dir> [type]`:: |
| 68 | `<dir>` にあるリポジトリ `<repos>` を Trac に追加し、オプションとして、リポジトリのタイプを指定します。 |
| 69 | |
| 70 | `repository alias <name> <target>`:: |
| 71 | リポジトリ `<target>` のエイリアス `<name>` を設定します。 |
| 72 | |
| 73 | `repository remove <repos>`:: |
| 74 | リポジトリ `<repos>` を削除します。 |
| 75 | |
| 76 | `repository set <repos> <key> <value>`:: |
| 77 | リポジトリ `<repos>` の属性 `<key>` と `<value>` を設定します。 |
| 78 | |
| 79 | Note: デフォルトリポジトリはの名前は空文字列です。したがって、 `trac-admin` をシェルから起動させたときは、おそらくクオートする必要があるでしょう。代替手段として、例えば `trac-admin` を対話モードで起動しているときは、代わりに "`(default)`" を使用することができます。 |
| 80 | |
| 81 | |
| 82 | == リポジトリの同期 == #Synchronization |
| 83 | Trac 0.12 以前では、HTTP リクエストが発生するたびに Trac が持つキャッシュとリポジトリの同期処理を行なっていました。このアプローチは効果的ではなく、複数のリポジトリを扱う上ではもはや実用的ではありません。この理由から、 post-commit フックを利用した明示的な同期処理が追加されました。 |
| 84 | |
| 85 | リポジトリの変更を監視する拡張ポイントを定義するインタフェース ''(IRepositoryChangeListener)'' が追加されました。このインタフェースの呼び出しは、チェンジセットが追加または修正されたときの post-commit フックをトリガーとしています。コミット時に何かしらのアクションを実行するプラグインで使用することができます。 |
| 86 | |
| 87 | === 明示的な同期 === #ExplicitSync |
| 88 | これは推奨するリポジトリの同期方法です。 [wiki:TracIni#trac-section trac.ini] の `[trac] repository_sync_per_request` オプションを empty 値に設定する必要があります。そして、各リポジトリの post-commit フック内で `trac-admin` を呼び出すようにします。さらに、リポジトリでリビジョンのメタデータの変更することが許されているならば、 post-revprop-change フックにも同様に `trac-admin` を呼び出すように設定します。 |
| 89 | |
| 90 | `changeset added <repos> <rev> [...]`:: |
| 91 | Trac に 1 つ以上のチェンジセットがリポジトリに発生したことを知らせる。 |
| 92 | |
| 93 | `changeset modified <repos> <rev> [...]`:: |
| 94 | Trac に 1 つ以上のチェンジセットに対するメタデータの変更がリポジトリに加えられたことを知らせる。 |
| 95 | |
| 96 | 引数 `<repos>` にはリポジトリ名 ( デフォルトのリポジトリには "`(default)`" を使用する ) または、リポジトリへのパスを指定します。 |
| 97 | |
| 98 | 下記は、 Subversion の完璧な post-commit と post-revprop-change スクリプトの一例です。特定の環境用に編集、そして適切な実行権を付けて 各リポジトリの `hooks` ディレクトリにおいてください。 UNIX における (`post-commit`) 例: |
| 99 | {{{ |
| 100 | #!sh |
| 101 | #!/bin/sh |
| 102 | /usr/bin/trac-admin /path/to/env changeset added "$1" "$2" |
| 103 | }}} |
| 104 | Windows における (`post-commit.cmd`) の例: |
| 105 | {{{ |
| 106 | #!application/x-dos-batch |
| 107 | @C:\Python26\Scripts\trac-admin.exe C:\path\to\env changeset added "%1" "%2" |
| 108 | }}} |
| 109 | |
| 110 | Subversion の post-revprop-change フックはとても似たものになります。 UNIX における (`post-revprop-change`) の例: |
| 111 | {{{ |
| 112 | #!sh |
| 113 | #!/bin/sh |
| 114 | /usr/bin/trac-admin /path/to/env changeset modified "$1" "$2" |
| 115 | }}} |
| 116 | Windows における (`post-revprop-change.cmd`) の例: |
| 117 | {{{ |
| 118 | #!application/x-dos-batch |
| 119 | @C:\Python26\Scripts\trac-admin.exe C:\path\to\env changeset modified "%1" "%2" |
| 120 | }}} |
| 121 | |
| 122 | Note: Subversion のフックで `trac-admin` を呼び出すことは、クライアントサイドにおいては、コミットとログの編集操作に時間がかかってしまうことになります。非同期な方法で行なうために、 `trac-admin` で始まる [http://trac.edgewall.org/browser/trunk/contrib/trac-svn-hook contrib/trac-svn-hook] を使いたいと思うかもしれません。スクリプトもまた何回もの安全性のチェックと使い方のアドバイスを行なっているので、フックを設定したりテストするのはずっと簡単なことかもしれません。まだ Windows 用の `trac-svn-hook.bat` に匹敵するものはありませんが、スクリプトは Cygwin の bash で起動することができます。 |
| 123 | |
| 124 | Subversion についてのより詳しい情報は、Subversion 本の [http://svnbook.red-bean.com/en/1.5/svn.reposadmin.create.html#svn.reposadmin.create.hooks フックについて] を参照して下さい。他のリポジトリのタイプでは異なったフックの設定が必要です。操作手順については、プラグインのドキュメントを参照して下さい。 |
| 125 | |
| 126 | === リクエスト毎の同期処理 === #PerRequestSync |
| 127 | もし post-commit フックが使用できないならば、その環境ではリクエスト毎の同期処理を設定することができます。この場合、 [wiki:TracIni#trac-section trac.ini] のオプション `[trac] repository_sync_per_request` に同期対象のリポジトリをカンマ区切りでリストしなければなりません。 |
| 128 | |
| 129 | Note: この場合、チェンジセットのリスナの拡張ポイントは呼び出されません。それゆえ、使用しているプラグインは正しく動かないかもしれません。 |
| 130 | |
| 131 | |
| 132 | == 単一リポジトリからの移行手順 == #Migration |
| 133 | 下記の手順は、単一リポジトリから複数のリポジトリの設定へ変更するための典型的な移行方法になります。 |
| 134 | |
| 135 | 1. `[trac] repository_dir` オプションからリポジトリのデフォルトの設定を削除する。 |
| 136 | 1. "メイン" となるリポジトリを名前付きのリポジトリとして登録する。 |
| 137 | 1. メインのリポジトリを再同期する。 |
| 138 | 1. post-commit フックと post-revprop-change フックをメインのリポジトリに設定し、 `[trac] repository_sync_per_request` オプションに empty 値を設定します。 |
| 139 | 1. メインリポジトリをデフォルトのリポジトリとして、 hidden 属性と alias 属性を追加します。これは移行前に作成されたすべてのリンクがメインリポジトリを解決できることを保証します。 |
| 140 | 1. ステップ 2,3,4 を他の ( 名前付きの ) リポジトリに対して必要に応じて繰り返します。 |
| 141 | |
| 142 | == トラブルシューティング == |
| 143 | |
| 144 | === trac-post-commit-hook はもはや機能しません === #trac-post-commit-hook |
| 145 | |
| 146 | 今では、 `tracopt.ticket.commit_updater.*` のオプションのコンポーネントを使用しなければなりません。 Web からの管理の一般設定配下のプラグインパネルか trac.ini の [TracIni#components-section "[components]"] セクションを直接編集することによって有効にすることができます。上記で説明している [#ExplicitSync 明示的な同期] 確実に行なってください。 |