X7ROOT File Manager
Current Path:
/opt/alt/ruby22/lib64/ruby/2.2.0
opt
/
alt
/
ruby22
/
lib64
/
ruby
/
2.2.0
/
??
..
??
English.rb
(6.42 KB)
??
abbrev.rb
(3.46 KB)
??
base64.rb
(2.63 KB)
??
benchmark.rb
(17.73 KB)
??
cgi
??
cgi.rb
(9.77 KB)
??
cmath.rb
(9.34 KB)
??
csv.rb
(82.45 KB)
??
date.rb
(980 B)
??
debug.rb
(29.08 KB)
??
delegate.rb
(10.71 KB)
??
digest
??
digest.rb
(2.79 KB)
??
drb
??
drb.rb
(19 B)
??
e2mmap.rb
(3.77 KB)
??
erb.rb
(26.35 KB)
??
expect.rb
(2.14 KB)
??
fiddle
??
fiddle.rb
(1.65 KB)
??
fileutils.rb
(47.46 KB)
??
find.rb
(2.48 KB)
??
forwardable.rb
(8.22 KB)
??
getoptlong.rb
(15.38 KB)
??
io
??
ipaddr.rb
(17.06 KB)
??
irb
??
irb.rb
(20.03 KB)
??
json
??
json.rb
(1.74 KB)
??
kconv.rb
(5.74 KB)
??
logger.rb
(20.33 KB)
??
mathn.rb
(3.84 KB)
??
matrix
??
matrix.rb
(53.14 KB)
??
mkmf.rb
(82.59 KB)
??
monitor.rb
(6.93 KB)
??
mutex_m.rb
(2 KB)
??
net
??
observer.rb
(5.8 KB)
??
open-uri.rb
(24.58 KB)
??
open3.rb
(20.55 KB)
??
openssl
??
openssl.rb
(528 B)
??
optionparser.rb
(28 B)
??
optparse
??
optparse.rb
(52.05 KB)
??
ostruct.rb
(8.66 KB)
??
pathname.rb
(15.58 KB)
??
pp.rb
(14.16 KB)
??
prettyprint.rb
(15.85 KB)
??
prime.rb
(13.11 KB)
??
profile.rb
(205 B)
??
profiler.rb
(4.51 KB)
??
pstore.rb
(14.55 KB)
??
psych
??
psych.rb
(14.88 KB)
??
racc
??
rake
??
rake.rb
(2.23 KB)
??
rbconfig
??
rdoc
??
rdoc.rb
(4.96 KB)
??
resolv-replace.rb
(1.73 KB)
??
resolv.rb
(72.06 KB)
??
rexml
??
rinda
??
ripper
??
ripper.rb
(2.53 KB)
??
rss
??
rss.rb
(2.84 KB)
??
rubygems
??
rubygems.rb
(31.85 KB)
??
scanf.rb
(23.54 KB)
??
securerandom.rb
(9.2 KB)
??
set.rb
(19.15 KB)
??
shell
??
shell.rb
(11.3 KB)
??
shellwords.rb
(5.96 KB)
??
singleton.rb
(4.02 KB)
??
socket.rb
(25.6 KB)
??
sync.rb
(7.25 KB)
??
syslog
??
tempfile.rb
(11.11 KB)
??
thwait.rb
(3.31 KB)
??
time.rb
(22.25 KB)
??
timeout.rb
(3.64 KB)
??
tmpdir.rb
(4.13 KB)
??
tracer.rb
(6.4 KB)
??
tsort.rb
(14.27 KB)
??
ubygems.rb
(268 B)
??
un.rb
(8.87 KB)
??
unicode_normalize
??
unicode_normalize.rb
(3.16 KB)
??
uri
??
uri.rb
(3.07 KB)
??
weakref.rb
(2.92 KB)
??
webrick
??
webrick.rb
(6.69 KB)
??
x86_64-linux
??
xmlrpc
??
xmlrpc.rb
(8.49 KB)
??
yaml
??
yaml.rb
(1.7 KB)
Editing: securerandom.rb
# -*- coding: us-ascii -*- begin require 'openssl' rescue LoadError end # == Secure random number generator interface. # # This library is an interface for secure random number generator which is # suitable for generating session key in HTTP cookies, etc. # # You can use this library in your application by requiring it: # # require 'securerandom' # # It supports following secure random number generators. # # * openssl # * /dev/urandom # * Win32 # # === Examples # # Hexadecimal string. # # require 'securerandom' # # p SecureRandom.hex(10) #=> "52750b30ffbc7de3b362" # p SecureRandom.hex(10) #=> "92b15d6c8dc4beb5f559" # p SecureRandom.hex(13) #=> "39b290146bea6ce975c37cfc23" # # Base64 string. # # p SecureRandom.base64(10) #=> "EcmTPZwWRAozdA==" # p SecureRandom.base64(10) #=> "KO1nIU+p9DKxGg==" # p SecureRandom.base64(12) #=> "7kJSM/MzBJI+75j8" # # Binary string. # # p SecureRandom.random_bytes(10) #=> "\016\t{\370g\310pbr\301" # p SecureRandom.random_bytes(10) #=> "\323U\030TO\234\357\020\a\337" module SecureRandom if /mswin|mingw/ =~ RUBY_PLATFORM require "fiddle/import" module AdvApi32 # :nodoc: extend Fiddle::Importer dlload "advapi32" extern "int CryptAcquireContext(void*, void*, void*, unsigned long, unsigned long)" extern "int CryptGenRandom(void*, unsigned long, void*)" def self.get_provider hProvStr = " " * Fiddle::SIZEOF_VOIDP prov_rsa_full = 1 crypt_verifycontext = 0xF0000000 if CryptAcquireContext(hProvStr, nil, nil, prov_rsa_full, crypt_verifycontext) == 0 raise SystemCallError, "CryptAcquireContext failed: #{lastWin32ErrorMessage}" end type = Fiddle::SIZEOF_VOIDP == Fiddle::SIZEOF_LONG_LONG ? 'q' : 'l' hProv, = hProvStr.unpack(type) hProv end def self.gen_random(n) @hProv ||= get_provider bytes = " ".force_encoding("ASCII-8BIT") * n if CryptGenRandom(@hProv, bytes.size, bytes) == 0 raise SystemCallError, "CryptGenRandom failed: #{Kernel32.last_error_message}" end bytes end end module Kernel32 # :nodoc: extend Fiddle::Importer dlload "kernel32" extern "unsigned long GetLastError()" extern "unsigned long FormatMessageA(unsigned long, void*, unsigned long, unsigned long, void*, unsigned long, void*)" # Following code is based on David Garamond's GUID library for Ruby. def self.last_error_message format_message_ignore_inserts = 0x00000200 format_message_from_system = 0x00001000 code = GetLastError() msg = "\0" * 1024 len = FormatMessageA(format_message_ignore_inserts + format_message_from_system, 0, code, 0, msg, 1024, nil) msg[0, len].force_encoding("filesystem").tr("\r", '').chomp end end end # SecureRandom.random_bytes generates a random binary string. # # The argument _n_ specifies the length of the result string. # # If _n_ is not specified or is nil, 16 is assumed. # It may be larger in future. # # The result may contain any byte: "\x00" - "\xff". # # p SecureRandom.random_bytes #=> "\xD8\\\xE0\xF4\r\xB2\xFC*WM\xFF\x83\x18\xF45\xB6" # p SecureRandom.random_bytes #=> "m\xDC\xFC/\a\x00Uf\xB2\xB2P\xBD\xFF6S\x97" # # If secure random number generator is not available, # NotImplementedError is raised. def self.random_bytes(n=nil) n = n ? n.to_int : 16 gen_random(n) end if defined?(OpenSSL::Random) && !defined?(AdvApi32) def self.gen_random(n) @pid = 0 unless defined?(@pid) pid = $$ unless @pid == pid now = Process.clock_gettime(Process::CLOCK_REALTIME, :nanosecond) ary = [now, @pid, pid] OpenSSL::Random.random_add(ary.join("").to_s, 0.0) @pid = pid end return OpenSSL::Random.random_bytes(n) end elsif defined?(AdvApi32) def self.gen_random(n) return AdvApi32.gen_random(n) end def self.lastWin32ErrorMessage # :nodoc: # for compatibility return Kernel32.last_error_message end else def self.gen_random(n) flags = File::RDONLY flags |= File::NONBLOCK if defined? File::NONBLOCK flags |= File::NOCTTY if defined? File::NOCTTY begin File.open("/dev/urandom", flags) {|f| unless f.stat.chardev? break end ret = f.read(n) unless ret.length == n raise NotImplementedError, "Unexpected partial read from random device: only #{ret.length} for #{n} bytes" end return ret } rescue Errno::ENOENT end raise NotImplementedError, "No random device" end end # SecureRandom.hex generates a random hexadecimal string. # # The argument _n_ specifies the length, in bytes, of the random number to be generated. # The length of the resulting hexadecimal string is twice _n_. # # If _n_ is not specified or is nil, 16 is assumed. # It may be larger in future. # # The result may contain 0-9 and a-f. # # p SecureRandom.hex #=> "eb693ec8252cd630102fd0d0fb7c3485" # p SecureRandom.hex #=> "91dc3bfb4de5b11d029d376634589b61" # # If secure random number generator is not available, # NotImplementedError is raised. def self.hex(n=nil) random_bytes(n).unpack("H*")[0] end # SecureRandom.base64 generates a random base64 string. # # The argument _n_ specifies the length, in bytes, of the random number # to be generated. The length of the result string is about 4/3 of _n_. # # If _n_ is not specified or is nil, 16 is assumed. # It may be larger in future. # # The result may contain A-Z, a-z, 0-9, "+", "/" and "=". # # p SecureRandom.base64 #=> "/2BuBuLf3+WfSKyQbRcc/A==" # p SecureRandom.base64 #=> "6BbW0pxO0YENxn38HMUbcQ==" # # If secure random number generator is not available, # NotImplementedError is raised. # # See RFC 3548 for the definition of base64. def self.base64(n=nil) [random_bytes(n)].pack("m*").delete("\n") end # SecureRandom.urlsafe_base64 generates a random URL-safe base64 string. # # The argument _n_ specifies the length, in bytes, of the random number # to be generated. The length of the result string is about 4/3 of _n_. # # If _n_ is not specified or is nil, 16 is assumed. # It may be larger in future. # # The boolean argument _padding_ specifies the padding. # If it is false or nil, padding is not generated. # Otherwise padding is generated. # By default, padding is not generated because "=" may be used as a URL delimiter. # # The result may contain A-Z, a-z, 0-9, "-" and "_". # "=" is also used if _padding_ is true. # # p SecureRandom.urlsafe_base64 #=> "b4GOKm4pOYU_-BOXcrUGDg" # p SecureRandom.urlsafe_base64 #=> "UZLdOkzop70Ddx-IJR0ABg" # # p SecureRandom.urlsafe_base64(nil, true) #=> "i0XQ-7gglIsHGV2_BNPrdQ==" # p SecureRandom.urlsafe_base64(nil, true) #=> "-M8rLhr7JEpJlqFGUMmOxg==" # # If secure random number generator is not available, # NotImplementedError is raised. # # See RFC 3548 for the definition of URL-safe base64. def self.urlsafe_base64(n=nil, padding=false) s = [random_bytes(n)].pack("m*") s.delete!("\n") s.tr!("+/", "-_") s.delete!("=") unless padding s end # SecureRandom.random_number generates a random number. # # If a positive integer is given as _n_, # SecureRandom.random_number returns an integer: # 0 <= SecureRandom.random_number(n) < n. # # p SecureRandom.random_number(100) #=> 15 # p SecureRandom.random_number(100) #=> 88 # # If 0 is given or an argument is not given, # SecureRandom.random_number returns a float: # 0.0 <= SecureRandom.random_number() < 1.0. # # p SecureRandom.random_number #=> 0.596506046187744 # p SecureRandom.random_number #=> 0.350621695741409 # def self.random_number(n=0) if 0 < n if defined? OpenSSL::BN OpenSSL::BN.rand_range(n).to_i else hex = n.to_s(16) hex = '0' + hex if (hex.length & 1) == 1 bin = [hex].pack("H*") mask = bin[0].ord mask |= mask >> 1 mask |= mask >> 2 mask |= mask >> 4 begin rnd = SecureRandom.random_bytes(bin.length) rnd[0] = (rnd[0].ord & mask).chr end until rnd < bin rnd.unpack("H*")[0].hex end else # assumption: Float::MANT_DIG <= 64 if defined? OpenSSL::BN i64 = OpenSSL::BN.rand(64, -1).to_i else i64 = SecureRandom.random_bytes(8).unpack("Q")[0] end Math.ldexp(i64 >> (64-Float::MANT_DIG), -Float::MANT_DIG) end end # SecureRandom.uuid generates a v4 random UUID (Universally Unique IDentifier). # # p SecureRandom.uuid #=> "2d931510-d99f-494a-8c67-87feb05e1594" # p SecureRandom.uuid #=> "bad85eb9-0713-4da7-8d36-07a8e4b00eab" # p SecureRandom.uuid #=> "62936e70-1815-439b-bf89-8492855a7e6b" # # The version 4 UUID is purely random (except the version). # It doesn't contain meaningful information such as MAC address, time, etc. # # See RFC 4122 for details of UUID. # def self.uuid ary = self.random_bytes(16).unpack("NnnnnN") ary[2] = (ary[2] & 0x0fff) | 0x4000 ary[3] = (ary[3] & 0x3fff) | 0x8000 "%08x-%04x-%04x-%04x-%04x%08x" % ary end end
Upload File
Create Folder