====== Mac OS X v10.6でSubversionリポジトリのパスベース認証を行う ======
Snow Leopardからmod_dav_svnが標準で入たようで、WebDAVを用いたSubversion環境を作りやすくなったっぽいので挑戦してみたメモ。
===== 前提条件 =====
* Mac OS X v10.6.6(試した環境)
* Subversion 1.6.5(システム標準)
* Apache 2.2.15(システム標準)
* プロジェクトごとにリポジトリを作り、プロジェクトごとにアクセス制御出来るようにする。
* リポジトリ置き場:/doko/soko/svn/repos/
* SVNサーバアドレス:mysvn.info
===== httpd.confの編集 =====
''/etc/apache2/httpd.conf''のLoadModuleの最後に以下を追加。
LoadModule dav_svn_module libexec/apache2/mod_dav_svn.so
LoadModule authz_svn_module libexec/apache2/mod_authz_svn.so
===== mod_dav_svnの設定 =====
''/etc/apache2/other/subversion.conf''でmod_dav_svnの設定をする。拡張子が.confならファイル名は何でもおk。
# リポジトリにアクセスする際のURL(http://mysvn.info/svn-repos)の一部になる
DAV svn
SVNListParentPath on
SVNParentPath /doko/soko/svn/repos # リポジトリの実際のパス
===== リポジトリの所有者の変更 =====
$ sudo chown -R _www:_www /doko/soko/svn/repos
==== 確認 ====
ここまでで問題なく設定出来ていれば、apacheを再起動後、チェックアウトやブラウザからリポジトリの表示が出来るようになっているはず。
現段階では、Subversionサーバにアクセス出来る人なら誰でも、無制限でリポジトリを操作出来るので要注意。
===== アクセス制御 =====
''subversion.conf''を再度開き、認証に必要なの設定を追加する。
DAV svn
SVNListParentPath on
SVNParentPath /doko/soko/svn/repos
Satisfy Any # 匿名ユーザーを許可
Require valid-user # 匿名ユーザーが許可されてない操作は正規ユーザーを要求
AuthType Basic # ベーシック認証を使う
AuthName "Subversion Authorization" # 認証領域の設定。設定を忘れると500エラーで小一時間苦しむことになるので注意。
AuthUserFile /doko/soko/svn/htpasswd # ベーシック認証のユーザーとパスワードファイル
AuthzSVNAccessFile /doko/soko/svn/authz # リポジトリのアクセス制御情報ファイル
==== 正規ユーザーの設定 ====
''AuthUserFile''で指定したファイルにベーシック認証ユーザーを追加する。
$ sudo htpasswd -c /doko/soko/svn/htpasswd Decomo
New password:
Re-type new password:
Adding password for user Decomo
2人目以降、つまりhtpasswdが既にある場合は-cオプションは付けない。さもないと上書きされる。
==== リポジトリのアクセス制御の設定 ====
''AuthzSVNAccessFile''で指定したファイルにアクセス制御情報を書く。
[groups]
admins = Decomo
[/]
* = r
[Project1:/]
@admins = rw
[Project2:/]
@admins = rw
[secret:/]
Decomo = rw
* =
===== SSLの設定 =====
ここからSSLに関する設定。HTTPのままで良ければ以下は設定する必要はない。
==== 秘密鍵の生成 ====
sudoだと上手く行かなかったのでsuする。
$ cd /etc/apache2/other
$ su
# openssl genrsa -aes256 2048 > server.key
Generating RSA private key, 2048 bit long modulus
..................................................................................................+++
..............+++
e is 65537 (0x10001)
Enter pass phrase:
Verifying - Enter pass phrase:
==== 公開鍵の生成 ====
# openssl req -new -key server.key >server.csr
Enter pass phrase for server.key:
You are about to be asked to enter information that will be incorporated
into your certificate request.
What you are about to enter is what is called a Distinguished Name or a DN.
There are quite a few fields but you can leave some blank
For some fields there will be a default value,
If you enter '.', the field will be left blank.
-----
Country Name (2 letter code) [AU]:JP
State or Province Name (full name) [Some-State]:Kanagawa
Locality Name (eg, city) []:Yokohama-shi
Organization Name (eg, company) [Internet Widgits Pty Ltd]:PRODUCTION KusoGA
Organizational Unit Name (eg, section) []:CA
Common Name (eg, YOUR name) []:ホスト名
Email Address []:メールアドレス
Please enter the following 'extra' attributes
to be sent with your certificate request
A challenge password []: 空白
An optional company name []: 空白
==== 自己証明書の生成 ====
# # openssl x509 -in server.csr -days 3650 -req -signkey server.key > server.crt
Signature ok
subject=/C=JP/ST=Kanagawa/L=Yokohama-shi/O=PRODUCTION KusoGA/OU=CA/CN=ホスト名/emailAddress=メールアドレス
Getting Private key
Enter pass phrase for server.key:
==== 秘密鍵のパスワードの解除 ====
上記方法で生成したキーだとApacheの起動時にパスワードの入力を求められるらしいが、Mac OS Xだと何それ美味しいの状態なのでパスワードを解除しておく。
# mv server.key server.key.bak
# openssl rsa -in server.key.bak -out server.key
Enter pass phrase for server.key.bak:
writing RSA key
==== subversion.confの編集====
subversion.conf.incにリネームし、''SSLRequireSSL''を追加する。
# mv subversion.conf subversion.conf.inc
# emacs subversion.conf.inc
DAV svn
SVNListParentPath on
SVNParentPath /doko/soko/svn/repos
SSLRequireSSL # SSLを必須にする
Satisfy Any # 匿名ユーザーを許可
Require valid-user # 匿名ユーザーが許可されてない操作は正規ユーザーを要求
AuthType Basic # ベーシック認証を使う
AuthName "Subversion Authorization" # 認証領域の設定。設定を忘れると500エラーで小一時間苦しむことになるので注意。
AuthUserFile /doko/soko/svn/htpasswd # ベーシック認証のユーザーとパスワードファイル
AuthzSVNAccessFile /doko/soko/svn/authz # リポジトリのアクセス制御情報ファイル
==== mod_sslの設定 ====
/etc/apache2/extra/にmod_ssl用の設定サンプルがあるのでコピーしておく。
$ cd /etc/apache2/other
$ sudo cp ../extra/httpd-ssl.conf ./ssl.conf
$ sudo mv subversion.conf subversion.conf.inc
ssl.confで必要な箇所だけ抜粋。
SSLRandomSeed startup file:/dev/urandom 512
SSLRandomSeed connect file:/dev/urandom 512
Listen 443
AddType application/x-x509-ca-cert .crt
AddType application/x-pkcs7-crl .crl
SSLPassPhraseDialog builtin
SSLSessionCache "shmcb:/private/var/run/ssl_scache(512000)"
SSLSessionCacheTimeout 300
SSLMutex "file:/private/var/run/ssl_mutex"
DocumentRoot "/Library/WebServer/Documents"
ServerName mysvn.info:443
ServerAdmin メールアドレス
ErrorLog "/private/var/log/apache2/error_log"
TransferLog "/private/var/log/apache2/access_log"
SSLEngine on
SSLCipherSuite ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP:+eNULL
SSLCertificateFile "/private/etc/apache2/other/server.crt"
SSLCertificateKeyFile "/private/etc/apache2/other/server.key"
SSLOptions +StdEnvVars
SSLOptions +StdEnvVars
BrowserMatch ".*MSIE.*" \
nokeepalive ssl-unclean-shutdown \
downgrade-1.0 force-response-1.0
CustomLog "/private/var/log/apache2/ssl_request_log" \
"%t %h %{SSL_PROTOCOL}x %{SSL_CIPHER}x \"%r\" %b"
Include /private/etc/apache2/other/subversion.conf.inc
''<VirtualHost>''の最後でsubversion.conf.incを取り込んでSSL接続時にBasic認証を有効にするとともに、非SSL時はリポジトリにアクセス出来ないようにする。
===== 参考サイト =====
* [[http://www.maruko2.com/mw/Apache/SSL%E8%87%AA%E5%B7%B1%E8%A8%BC%E6%98%8E%E6%9B%B8%E3%81%AE%E4%BD%9C%E6%88%90%E3%81%A8mod_ssl%E3%81%AE%E8%A8%AD%E5%AE%9A|Apache/SSL自己証明書の作成とmod sslの設定 - maruko2 Note.]]
* [[http://www.makies.com/2008/03/44/|家XenでTracを使えるようにしたよ « わすれないように.]]
* [[http://blog.livedoor.jp/knaka01/archives/51410971.html|酔いどれ日誌:Subversion + AuthzSVNAccessFile = Forbidden 403 Error]]
* [[http://www.caldron.jp/~nabetaro/svn/svnbook-1.5-final/html-chunk/svn.serverconfig.httpd.html#svn.serverconfig.httpd.authz.perdir.ex-1|第6章 サーバの設定httpd (Apache HTTP サーバ)]]
* [[http://memo.kappa-lab.com/2007/06/svnwebdavssl.html|SVN+WebDAV+SSLをポートを分けて設定 (memo.kappa-lab.com)]]
* [[http://kay.air-nifty.com/art/2008/09/sslbasic-77ec.html|SSL+Basic認証の設定で意外に苦労しました(技術的な話題): ITスペシャリストが語る芸術]]
~~DISCUSSION~~