mirror of
				https://github.com/ruby/ruby.git
				synced 2022-11-09 12:17:21 -05:00 
			
		
		
		
	* lib/soap/header/* * lib/soap/rpc/httpserver.rb * lib/wsdl/soap/cgiStubCreator.rb * lib/wsdl/soap/classDefCreator.rb * lib/wsdl/soap/classDefCreatorSupport.rb * lib/wsdl/soap/clientSkeltonCreator.rb * lib/wsdl/soap/driverCreator.rb * lib/wsdl/soap/mappingRegistryCreator.rb * lib/wsdl/soap/methodDefCreator.rb * lib/wsdl/soap/servantSkeltonCreator.rb * lib/wsdl/soap/standaloneServerStubCreator.rb * lib/wsdl/xmlSchema/enumeration.rb * lib/wsdl/xmlSchema/simpleRestriction.rb * lib/wsdl/xmlSchema/simpleType.rb * lib/xsd/codegen/* * lib/xsd/codegen.rb * sample/soap/authheader/* * sample/soap/raa2.4/* * sample/soap/ssl/* * sample/soap/swa/* * sample/soap/whois.rb * sample/wsdl/raa2.4/* * test/soap/header/* * test/soap/ssl/* * test/soap/struct/* * test/soap/swa/* * test/soap/wsdlDriver/* * test/wsdl/multiplefault.wsdl * test/wsdl/simpletype/* * test/wsdl/test_multiplefault.rb * modified files: * lib/soap/baseData.rb * lib/soap/element.rb * lib/soap/generator.rb * lib/soap/netHttpClient.rb * lib/soap/parser.rb * lib/soap/property.rb * lib/soap/soap.rb * lib/soap/streamHandler.rb * lib/soap/wsdlDriver.rb * lib/soap/wsdlDriver.rb * lib/soap/encodingstyle/handler.rb * lib/soap/encodingstyle/literalHandler.rb * lib/soap/encodingstyle/soapHandler.rb * lib/soap/mapping/factory.rb * lib/soap/mapping/mapping.rb * lib/soap/mapping/registry.rb * lib/soap/mapping/rubytypeFactory.rb * lib/soap/mapping/wsdlRegistry.rb * lib/soap/rpc/cgistub.rb * lib/soap/rpc/driver.rb * lib/soap/rpc/proxy.rb * lib/soap/rpc/router.rb * lib/soap/rpc/soaplet.rb * lib/soap/rpc/standaloneServer.rb * lib/wsdl/data.rb * lib/wsdl/definitions.rb * lib/wsdl/operation.rb * lib/wsdl/parser.rb * lib/wsdl/soap/definitions.rb * lib/wsdl/xmlSchema/complexContent.rb * lib/wsdl/xmlSchema/complexType.rb * lib/wsdl/xmlSchema/data.rb * lib/wsdl/xmlSchema/parser.rb * lib/wsdl/xmlSchema/schema.rb * lib/xsd/datatypes.rb * lib/xsd/qname.rb * sample/soap/sampleStruct/server.rb * sample/wsdl/amazon/AmazonSearch.rb * sample/wsdl/amazon/AmazonSearchDriver.rb * test/soap/test_property.rb * test/soap/calc/test_calc_cgi.rb * test/wsdl/test_emptycomplextype.rb * summary * add SOAP Header mustUnderstand support. * add HTTP client SSL configuration and Cookies support (works completely with http-access2). * add header handler for handling sending/receiving SOAP Header. * map Ruby's anonymous Struct to common SOAP Struct in SOAP Object Model. it caused error. * add WSDL simpleType support to restrict lexical value space. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@6565 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
		
			
				
	
	
		
			119 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			Perl
		
	
	
	
	
	
			
		
		
	
	
			119 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			Perl
		
	
	
	
	
	
require 'pstore'
 | 
						|
require 'soap/rpc/cgistub'
 | 
						|
require 'soap/header/simplehandler'
 | 
						|
 | 
						|
 | 
						|
class AuthHeaderPortServer < SOAP::RPC::CGIStub
 | 
						|
  PortName = 'http://tempuri.org/authHeaderPort'
 | 
						|
  SupportPortName = 'http://tempuri.org/authHeaderSupportPort'
 | 
						|
  MyHeaderName = XSD::QName.new("http://tempuri.org/authHeader", "auth")
 | 
						|
  SessionDB = File.join(File.expand_path(File.dirname(__FILE__)), 'session.pstoredb')
 | 
						|
 | 
						|
  class AuthHeaderService
 | 
						|
    def self.create
 | 
						|
      new
 | 
						|
    end
 | 
						|
 | 
						|
    def deposit(amt)
 | 
						|
      "deposit #{amt} OK"
 | 
						|
    end
 | 
						|
 | 
						|
    def withdrawal(amt)
 | 
						|
      "withdrawal #{amt} OK"
 | 
						|
    end
 | 
						|
  end
 | 
						|
 | 
						|
  class AuthHeaderSupportService
 | 
						|
    def delete_sessiondb
 | 
						|
      File.unlink(SessionDB) if File.file?(SessionDB)
 | 
						|
      backup = SessionDB + "~"
 | 
						|
      File.unlink(backup) if File.file?(backup)
 | 
						|
    end
 | 
						|
  end
 | 
						|
 | 
						|
  def initialize(*arg)
 | 
						|
    super
 | 
						|
    add_rpc_servant(AuthHeaderService.new, PortName)
 | 
						|
    add_rpc_servant(AuthHeaderSupportService.new, SupportPortName)
 | 
						|
    add_rpc_headerhandler(ServerAuthHeaderHandler.new)
 | 
						|
  end
 | 
						|
 | 
						|
  class ServerAuthHeaderHandler < SOAP::Header::SimpleHandler
 | 
						|
    Users = {
 | 
						|
      'NaHi' => 'passwd',
 | 
						|
      'HiNa' => 'wspass'
 | 
						|
    }
 | 
						|
 | 
						|
    def initialize
 | 
						|
      super(MyHeaderName)
 | 
						|
      @db = PStore.new(SessionDB)
 | 
						|
      @db.transaction do
 | 
						|
	@db["root"] = {} unless @db.root?("root")
 | 
						|
      end
 | 
						|
      @userid = @sessionid = nil
 | 
						|
    end
 | 
						|
 | 
						|
    def login(userid, passwd)
 | 
						|
      userid and passwd and Users[userid] == passwd
 | 
						|
    end
 | 
						|
 | 
						|
    def auth(sessionid)
 | 
						|
      in_sessiondb do |root|
 | 
						|
	root[sessionid][0]
 | 
						|
      end
 | 
						|
    end
 | 
						|
 | 
						|
    def create_session(userid)
 | 
						|
      in_sessiondb do |root|
 | 
						|
	while true
 | 
						|
  	  key = create_sessionkey
 | 
						|
  	  break unless root[key]
 | 
						|
   	end
 | 
						|
    	root[key] = [userid]
 | 
						|
     	key
 | 
						|
      end
 | 
						|
    end
 | 
						|
 | 
						|
    def destroy_session(sessionkey)
 | 
						|
      in_sessiondb do |root|
 | 
						|
	root.delete(sessionkey)
 | 
						|
      end
 | 
						|
    end
 | 
						|
 | 
						|
    def on_simple_outbound
 | 
						|
      { "sessionid" => @sessionid }
 | 
						|
    end
 | 
						|
 | 
						|
    def on_simple_inbound(my_header, mu)
 | 
						|
      auth = false
 | 
						|
      userid = my_header["userid"]
 | 
						|
      passwd = my_header["passwd"]
 | 
						|
      if login(userid, passwd)
 | 
						|
	auth = true
 | 
						|
      elsif sessionid = my_header["sessionid"]
 | 
						|
	if userid = auth(sessionid)
 | 
						|
	  destroy_session(sessionid)
 | 
						|
	  auth = true
 | 
						|
	end
 | 
						|
      end
 | 
						|
      raise RuntimeError.new("authentication failed") unless auth
 | 
						|
      @userid = userid
 | 
						|
      @sessionid = create_session(userid)
 | 
						|
    end
 | 
						|
 | 
						|
  private
 | 
						|
 | 
						|
    def create_sessionkey
 | 
						|
      Time.now.usec.to_s
 | 
						|
    end
 | 
						|
 | 
						|
    def in_sessiondb
 | 
						|
      @db.transaction do
 | 
						|
	yield(@db["root"])
 | 
						|
      end
 | 
						|
    end
 | 
						|
  end
 | 
						|
end
 | 
						|
 | 
						|
 | 
						|
status = AuthHeaderPortServer.new('AuthHeaderPortServer', nil).start
 |