From 0dc342de848a642ecce8db697b8fecd83a63e117 Mon Sep 17 00:00:00 2001 From: yugui Date: Mon, 25 Aug 2008 15:02:05 +0000 Subject: added tag v1_9_0_4 git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/tags/v1_9_0_4@18845 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- trunk/lib/webrick/httpauth.rb | 45 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 45 insertions(+) create mode 100644 trunk/lib/webrick/httpauth.rb (limited to 'trunk/lib/webrick/httpauth.rb') diff --git a/trunk/lib/webrick/httpauth.rb b/trunk/lib/webrick/httpauth.rb new file mode 100644 index 0000000000..147c04021c --- /dev/null +++ b/trunk/lib/webrick/httpauth.rb @@ -0,0 +1,45 @@ +# +# httpauth.rb -- HTTP access authentication +# +# Author: IPR -- Internet Programming with Ruby -- writers +# Copyright (c) 2000, 2001 TAKAHASHI Masayoshi, GOTOU Yuuzou +# Copyright (c) 2002 Internet Programming with Ruby writers. All rights +# reserved. +# +# $IPR: httpauth.rb,v 1.14 2003/07/22 19:20:42 gotoyuzo Exp $ + +require 'webrick/httpauth/basicauth' +require 'webrick/httpauth/digestauth' +require 'webrick/httpauth/htpasswd' +require 'webrick/httpauth/htdigest' +require 'webrick/httpauth/htgroup' + +module WEBrick + module HTTPAuth + module_function + + def _basic_auth(req, res, realm, req_field, res_field, err_type, block) + user = pass = nil + if /^Basic\s+(.*)/o =~ req[req_field] + userpass = $1 + user, pass = userpass.unpack("m*")[0].split(":", 2) + end + if block.call(user, pass) + req.user = user + return + end + res[res_field] = "Basic realm=\"#{realm}\"" + raise err_type + end + + def basic_auth(req, res, realm, &block) + _basic_auth(req, res, realm, "Authorization", "WWW-Authenticate", + HTTPStatus::Unauthorized, block) + end + + def proxy_basic_auth(req, res, realm, &block) + _basic_auth(req, res, realm, "Proxy-Authorization", "Proxy-Authenticate", + HTTPStatus::ProxyAuthenticationRequired, block) + end + end +end -- cgit v1.2.3