Class: XMLRPC::WEBrickServlet
Relationships & Source Files | |
Extension / Inclusion / Inheritance Descendants | |
Subclasses:
|
|
Super Chains via Extension / Inclusion / Inheritance | |
Class Chain:
self,
BasicServer
|
|
Instance Chain:
|
|
Inherits: |
XMLRPC::BasicServer
|
Defined in: | lib/xmlrpc/server.rb, lib/xmlrpc/server.rb |
Overview
Implements a servlet for use with WEBrick, a pure Ruby (HTTP) server framework.
require "webrick"
require "xmlrpc/server"
s = XMLRPC::WEBrickServlet.new
s.add_handler("michael.add") do |a,b|
a + b
end
s.add_handler("michael.div") do |a,b|
if b == 0
raise XMLRPC::FaultException.new(1, "division by zero")
else
a / b
end
end
s.set_default_handler do |name, *args|
raise XMLRPC::FaultException.new(-99, "Method #{name} missing" +
" or wrong number of parameters!")
end
httpserver = WEBrick::HTTPServer
.new(:Port => 8080) httpserver.mount(“/RPC2”, s)
trap("HUP") { httpserver.shutdown } # use 1 instead of "HUP" on Windows
httpserver.start
Constant Summary
BasicServer
- Inherited
ERR_MC_EXPECTED_STRUCT, ERR_MC_MISSING_METHNAME, ERR_MC_MISSING_PARAMS, ERR_MC_RECURSIVE_CALL, ERR_MC_WRONG_PARAM, ERR_MC_WRONG_PARAM_PARAMS, ERR_METHOD_MISSING, ERR_UNCAUGHT_EXCEPTION
Class Method Summary
- .new(*a) ⇒ WEBrickServlet constructor
BasicServer
- Inherited
.new | Creates a new |
Instance Attribute Summary
-
#require_path_info? ⇒ Boolean
readonly
Deprecated from WEBrick/1.2.2, but does not break anything.
Instance Method Summary
- #get_instance(config, *options)
-
#get_valid_ip
Return the valid IP addresses that are allowed to connect to the server.
- #service(request, response)
-
#set_valid_ip(*ip_addr)
Specifies the valid IP addresses that are allowed to connect to the server.
BasicServer
- Inherited
#add_handler | Adds |
#add_introspection | Adds the introspection handlers |
#add_multicall | Adds the multi-call handler |
#get_default_handler | Returns the default-handler, which is called when no handler for a method-name is found. |
#get_service_hook | Returns the service-hook, which is called on each service request (RPC) unless it’s |
#process, | |
#set_default_handler | Sets |
#set_service_hook | A service-hook is called for each service request (RPC). |
#call_method, | |
#check_arity | Returns |
#dispatch, #handle, #multicall_fault |
ParseContentType
- Included
ParserWriterChooseMixin
- Included
#set_parser | Sets the |
#set_writer | Sets the |
#create, #parser |
Constructor Details
.new(*a) ⇒ WEBrickServlet
# File 'lib/xmlrpc/server.rb', line 629
def initialize(*a) super require "webrick/httpstatus" @valid_ip = nil end
Instance Attribute Details
#require_path_info? ⇒ Boolean
(readonly)
Deprecated from WEBrick/1.2.2, but does not break anything.
# File 'lib/xmlrpc/server.rb', line 636
def require_path_info? false end
Instance Method Details
#get_instance(config, *options)
[ GitHub ]# File 'lib/xmlrpc/server.rb', line 640
def get_instance(config, * ) # TODO: set config & options self end
#get_valid_ip
Return the valid IP addresses that are allowed to connect to the server.
See also, XMLRPC::Server#set_valid_ip
# File 'lib/xmlrpc/server.rb', line 659
def get_valid_ip @valid_ip end
#service(request, response)
# File 'lib/xmlrpc/server.rb', line 663
def service(request, response) if @valid_ip raise WEBrick::HTTPStatus::Forbidden unless @valid_ip.any? { |ip| request.peeraddr[3] =~ ip } end if request.request_method != "POST" raise WEBrick::HTTPStatus::MethodNotAllowed, "unsupported method `#{request.request_method}'." end if parse_content_type(request['Content-type']).first != "text/xml" raise WEBrick::HTTPStatus::BadRequest end length = (request['Content-length'] || 0).to_i raise WEBrick::HTTPStatus::LengthRequired unless length > 0 data = request.body if data.nil? or data.bytesize != length raise WEBrick::HTTPStatus::BadRequest end resp = process(data) if resp.nil? or resp.bytesize <= 0 raise WEBrick::HTTPStatus::InternalServerError end response.status = 200 response['Content-Length'] = resp.bytesize response['Content-Type'] = "text/xml; charset=utf-8" response.body = resp end
#set_valid_ip(*ip_addr)
Specifies the valid IP addresses that are allowed to connect to the server.
Each IP is either a String or a Regexp.
# File 'lib/xmlrpc/server.rb', line 648
def set_valid_ip(*ip_addr) if ip_addr.size == 1 and ip_addr[0].nil? @valid_ip = nil else @valid_ip = ip_addr end end