Linux premium71.web-hosting.com 4.18.0-513.11.1.lve.el8.x86_64 #1 SMP Thu Jan 18 16:21:02 UTC 2024 x86_64
LiteSpeed
Server IP : 198.187.29.8 & Your IP : 3.148.212.53
Domains :
Cant Read [ /etc/named.conf ]
User : cleahvkv
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
opt /
alt /
ruby19 /
lib64 /
ruby /
1.9.1 /
Delete
Unzip
Name
Size
Permission
Date
Action
cgi
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
date
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
digest
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
dl
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
drb
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
fiddle
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
irb
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
json
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
matrix
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
net
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
openssl
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
optparse
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
psych
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
racc
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
rake
[ DIR ]
drwxr-xr-x
2024-03-03 22:50
rbconfig
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
rdoc
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
rexml
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
rinda
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
ripper
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
rss
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
rubygems
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
shell
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
syck
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
test
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
uri
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
webrick
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
x86_64-linux
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
xmlrpc
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
yaml
[ DIR ]
drwxr-xr-x
2024-03-03 22:48
English.rb
5.59
KB
-rw-r--r--
2009-10-02 10:45
abbrev.rb
2.57
KB
-rw-r--r--
2011-05-18 21:19
base64.rb
2.63
KB
-rw-r--r--
2009-10-02 10:45
benchmark.rb
18
KB
-rw-r--r--
2011-06-28 06:09
cgi.rb
9.3
KB
-rw-r--r--
2011-05-16 21:21
cmath.rb
7.22
KB
-rw-r--r--
2011-07-30 14:53
complex.rb
380
B
-rw-r--r--
2009-08-16 15:34
csv.rb
82.66
KB
-rw-r--r--
2011-07-21 21:40
date.rb
946
B
-rw-r--r--
2011-05-21 12:25
debug.rb
23.23
KB
-rw-r--r--
2011-06-28 11:45
delegate.rb
9.74
KB
-rw-r--r--
2011-07-27 19:56
digest.rb
2.24
KB
-rw-r--r--
2011-05-16 20:52
dl.rb
176
B
-rw-r--r--
2010-06-12 15:28
drb.rb
19
B
-rw-r--r--
2009-10-02 10:45
e2mmap.rb
3.8
KB
-rw-r--r--
2011-05-19 00:07
erb.rb
25.72
KB
-rw-r--r--
2012-12-13 05:24
expect.rb
1.33
KB
-rw-r--r--
2011-08-26 23:54
fiddle.rb
928
B
-rw-r--r--
2011-08-16 00:51
fileutils.rb
45.32
KB
-rw-r--r--
2012-02-25 08:11
find.rb
2.03
KB
-rw-r--r--
2011-05-18 21:19
forwardable.rb
7.64
KB
-rw-r--r--
2011-05-22 02:14
getoptlong.rb
15.38
KB
-rw-r--r--
2011-05-19 00:07
gserver.rb
8.83
KB
-rw-r--r--
2013-10-31 14:40
ipaddr.rb
24.92
KB
-rw-r--r--
2013-04-11 02:31
irb.rb
8.34
KB
-rw-r--r--
2011-05-19 00:07
json.rb
1.74
KB
-rw-r--r--
2011-08-30 02:25
kconv.rb
5.74
KB
-rw-r--r--
2010-12-07 11:47
logger.rb
20.85
KB
-rw-r--r--
2011-05-19 00:07
mathn.rb
6.52
KB
-rw-r--r--
2011-08-26 23:54
matrix.rb
47.65
KB
-rw-r--r--
2011-07-09 19:11
mkmf.rb
68.9
KB
-rw-r--r--
2014-02-06 05:20
monitor.rb
6.94
KB
-rw-r--r--
2011-06-17 22:33
mutex_m.rb
1.61
KB
-rw-r--r--
2011-05-19 00:07
observer.rb
5.69
KB
-rw-r--r--
2011-05-16 21:53
open-uri.rb
25.84
KB
-rw-r--r--
2014-02-24 03:43
open3.rb
20.64
KB
-rw-r--r--
2011-05-18 21:19
openssl.rb
547
B
-rw-r--r--
2011-07-25 06:38
optparse.rb
51.13
KB
-rw-r--r--
2014-02-14 04:52
ostruct.rb
6.49
KB
-rw-r--r--
2012-02-24 14:49
pathname.rb
14.21
KB
-rw-r--r--
2011-08-26 23:54
pp.rb
13.31
KB
-rw-r--r--
2010-08-01 14:09
prettyprint.rb
9.63
KB
-rw-r--r--
2011-08-02 15:25
prime.rb
13.98
KB
-rw-r--r--
2011-06-01 00:21
profile.rb
205
B
-rw-r--r--
2009-10-02 10:45
profiler.rb
1.59
KB
-rw-r--r--
2009-10-02 10:45
pstore.rb
15.81
KB
-rw-r--r--
2011-10-10 23:14
psych.rb
9.82
KB
-rw-r--r--
2012-08-07 20:50
rake.rb
2.02
KB
-rw-r--r--
2011-06-29 03:09
rational.rb
308
B
-rw-r--r--
2009-09-24 00:42
rdoc.rb
4.29
KB
-rw-r--r--
2013-02-06 08:00
resolv-replace.rb
1.74
KB
-rw-r--r--
2010-10-29 22:02
resolv.rb
59.91
KB
-rw-r--r--
2014-02-14 06:56
ripper.rb
91
B
-rw-r--r--
2009-10-02 10:45
rss.rb
2.84
KB
-rw-r--r--
2011-05-11 10:22
rubygems.rb
34.13
KB
-rw-r--r--
2013-12-22 04:38
scanf.rb
23.53
KB
-rw-r--r--
2011-05-20 12:22
securerandom.rb
8.46
KB
-rw-r--r--
2012-05-07 11:25
set.rb
29.91
KB
-rw-r--r--
2012-02-10 08:28
shell.rb
5.9
KB
-rw-r--r--
2011-05-19 00:07
shellwords.rb
3.88
KB
-rw-r--r--
2012-02-12 07:51
singleton.rb
4.02
KB
-rw-r--r--
2011-05-18 14:09
socket.rb
23.22
KB
-rw-r--r--
2014-01-30 12:04
syck.rb
13.91
KB
-rw-r--r--
2010-07-19 04:54
sync.rb
6.87
KB
-rw-r--r--
2011-06-29 03:09
tempfile.rb
10.42
KB
-rw-r--r--
2013-10-31 14:44
thread.rb
6.59
KB
-rw-r--r--
2014-02-14 03:48
thwait.rb
3.38
KB
-rw-r--r--
2011-06-29 03:09
time.rb
17.03
KB
-rw-r--r--
2013-10-31 14:06
timeout.rb
3.26
KB
-rw-r--r--
2013-04-02 04:09
tmpdir.rb
3.72
KB
-rw-r--r--
2011-05-18 21:19
tracer.rb
6.63
KB
-rw-r--r--
2011-06-29 13:19
tsort.rb
6.79
KB
-rw-r--r--
2009-03-06 04:23
ubygems.rb
268
B
-rw-r--r--
2009-10-02 10:45
un.rb
8.32
KB
-rw-r--r--
2011-05-19 00:07
uri.rb
3.07
KB
-rw-r--r--
2011-05-13 20:03
weakref.rb
2.29
KB
-rw-r--r--
2011-08-26 23:54
webrick.rb
6.8
KB
-rw-r--r--
2011-05-10 23:37
yaml.rb
2.58
KB
-rw-r--r--
2013-05-29 12:00
Save
Rename
# = PStore -- Transactional File Storage for Ruby Objects # # pstore.rb - # originally by matz # documentation by Kev Jackson and James Edward Gray II # improved by Hongli Lai # # See PStore for documentation. require "fileutils" require "digest/md5" require "thread" # # PStore implements a file based persistence mechanism based on a Hash. User # code can store hierarchies of Ruby objects (values) into the data store file # by name (keys). An object hierarchy may be just a single object. User code # may later read values back from the data store or even update data, as needed. # # The transactional behavior ensures that any changes succeed or fail together. # This can be used to ensure that the data store is not left in a transitory # state, where some values were updated but others were not. # # Behind the scenes, Ruby objects are stored to the data store file with # Marshal. That carries the usual limitations. Proc objects cannot be # marshalled, for example. # # == Usage example: # # require "pstore" # # # a mock wiki object... # class WikiPage # def initialize( page_name, author, contents ) # @page_name = page_name # @revisions = Array.new # # add_revision(author, contents) # end # # attr_reader :page_name # # def add_revision( author, contents ) # @revisions << { :created => Time.now, # :author => author, # :contents => contents } # end # # def wiki_page_references # [@page_name] + @revisions.last[:contents].scan(/\b(?:[A-Z]+[a-z]+){2,}/) # end # # # ... # end # # # create a new page... # home_page = WikiPage.new( "HomePage", "James Edward Gray II", # "A page about the JoysOfDocumentation..." ) # # # then we want to update page data and the index together, or not at all... # wiki = PStore.new("wiki_pages.pstore") # wiki.transaction do # begin transaction; do all of this or none of it # # store page... # wiki[home_page.page_name] = home_page # # ensure that an index has been created... # wiki[:wiki_index] ||= Array.new # # update wiki index... # wiki[:wiki_index].push(*home_page.wiki_page_references) # end # commit changes to wiki data store file # # ### Some time later... ### # # # read wiki data... # wiki.transaction(true) do # begin read-only transaction, no changes allowed # wiki.roots.each do |data_root_name| # p data_root_name # p wiki[data_root_name] # end # end # # == Transaction modes # # By default, file integrity is only ensured as long as the operating system # (and the underlying hardware) doesn't raise any unexpected I/O errors. If an # I/O error occurs while PStore is writing to its file, then the file will # become corrupted. # # You can prevent this by setting <em>pstore.ultra_safe = true</em>. # However, this results in a minor performance loss, and only works on platforms # that support atomic file renames. Please consult the documentation for # +ultra_safe+ for details. # # Needless to say, if you're storing valuable data with PStore, then you should # backup the PStore files from time to time. class PStore RDWR_ACCESS = {mode: IO::RDWR | IO::CREAT | IO::BINARY, encoding: Encoding::ASCII_8BIT}.freeze RD_ACCESS = {mode: IO::RDONLY | IO::BINARY, encoding: Encoding::ASCII_8BIT}.freeze WR_ACCESS = {mode: IO::WRONLY | IO::CREAT | IO::TRUNC | IO::BINARY, encoding: Encoding::ASCII_8BIT}.freeze # The error type thrown by all PStore methods. class Error < StandardError end # Whether PStore should do its best to prevent file corruptions, even when under # unlikely-to-occur error conditions such as out-of-space conditions and other # unusual OS filesystem errors. Setting this flag comes at the price in the form # of a performance loss. # # This flag only has effect on platforms on which file renames are atomic (e.g. # all POSIX platforms: Linux, MacOS X, FreeBSD, etc). The default value is false. attr_accessor :ultra_safe # # To construct a PStore object, pass in the _file_ path where you would like # the data to be stored. # # PStore objects are always reentrant. But if _thread_safe_ is set to true, # then it will become thread-safe at the cost of a minor performance hit. # def initialize(file, thread_safe = false) dir = File::dirname(file) unless File::directory? dir raise PStore::Error, format("directory %s does not exist", dir) end if File::exist? file and not File::readable? file raise PStore::Error, format("file %s not readable", file) end @filename = file @abort = false @ultra_safe = false @thread_safe = thread_safe @lock = Mutex.new end # Raises PStore::Error if the calling code is not in a PStore#transaction. def in_transaction raise PStore::Error, "not in transaction" unless @lock.locked? end # # Raises PStore::Error if the calling code is not in a PStore#transaction or # if the code is in a read-only PStore#transaction. # def in_transaction_wr() in_transaction() raise PStore::Error, "in read-only transaction" if @rdonly end private :in_transaction, :in_transaction_wr # # Retrieves a value from the PStore file data, by _name_. The hierarchy of # Ruby objects stored under that root _name_ will be returned. # # *WARNING*: This method is only valid in a PStore#transaction. It will # raise PStore::Error if called at any other time. # def [](name) in_transaction @table[name] end # # This method is just like PStore#[], save that you may also provide a # _default_ value for the object. In the event the specified _name_ is not # found in the data store, your _default_ will be returned instead. If you do # not specify a default, PStore::Error will be raised if the object is not # found. # # *WARNING*: This method is only valid in a PStore#transaction. It will # raise PStore::Error if called at any other time. # def fetch(name, default=PStore::Error) in_transaction unless @table.key? name if default == PStore::Error raise PStore::Error, format("undefined root name `%s'", name) else return default end end @table[name] end # # Stores an individual Ruby object or a hierarchy of Ruby objects in the data # store file under the root _name_. Assigning to a _name_ already in the data # store clobbers the old data. # # == Example: # # require "pstore" # # store = PStore.new("data_file.pstore") # store.transaction do # begin transaction # # load some data into the store... # store[:single_object] = "My data..." # store[:obj_heirarchy] = { "Kev Jackson" => ["rational.rb", "pstore.rb"], # "James Gray" => ["erb.rb", "pstore.rb"] } # end # commit changes to data store file # # *WARNING*: This method is only valid in a PStore#transaction and it cannot # be read-only. It will raise PStore::Error if called at any other time. # def []=(name, value) in_transaction_wr() @table[name] = value end # # Removes an object hierarchy from the data store, by _name_. # # *WARNING*: This method is only valid in a PStore#transaction and it cannot # be read-only. It will raise PStore::Error if called at any other time. # def delete(name) in_transaction_wr() @table.delete name end # # Returns the names of all object hierarchies currently in the store. # # *WARNING*: This method is only valid in a PStore#transaction. It will # raise PStore::Error if called at any other time. # def roots in_transaction @table.keys end # # Returns true if the supplied _name_ is currently in the data store. # # *WARNING*: This method is only valid in a PStore#transaction. It will # raise PStore::Error if called at any other time. # def root?(name) in_transaction @table.key? name end # Returns the path to the data store file. def path @filename end # # Ends the current PStore#transaction, committing any changes to the data # store immediately. # # == Example: # # require "pstore" # # store = PStore.new("data_file.pstore") # store.transaction do # begin transaction # # load some data into the store... # store[:one] = 1 # store[:two] = 2 # # store.commit # end transaction here, committing changes # # store[:three] = 3 # this change is never reached # end # # *WARNING*: This method is only valid in a PStore#transaction. It will # raise PStore::Error if called at any other time. # def commit in_transaction @abort = false throw :pstore_abort_transaction end # # Ends the current PStore#transaction, discarding any changes to the data # store. # # == Example: # # require "pstore" # # store = PStore.new("data_file.pstore") # store.transaction do # begin transaction # store[:one] = 1 # this change is not applied, see below... # store[:two] = 2 # this change is not applied, see below... # # store.abort # end transaction here, discard all changes # # store[:three] = 3 # this change is never reached # end # # *WARNING*: This method is only valid in a PStore#transaction. It will # raise PStore::Error if called at any other time. # def abort in_transaction @abort = true throw :pstore_abort_transaction end # # Opens a new transaction for the data store. Code executed inside a block # passed to this method may read and write data to and from the data store # file. # # At the end of the block, changes are committed to the data store # automatically. You may exit the transaction early with a call to either # PStore#commit or PStore#abort. See those methods for details about how # changes are handled. Raising an uncaught Exception in the block is # equivalent to calling PStore#abort. # # If _read_only_ is set to +true+, you will only be allowed to read from the # data store during the transaction and any attempts to change the data will # raise a PStore::Error. # # Note that PStore does not support nested transactions. # def transaction(read_only = false, &block) # :yields: pstore value = nil raise PStore::Error, "nested transaction" if !@thread_safe && @lock.locked? @lock.synchronize do @rdonly = read_only @abort = false file = open_and_lock_file(@filename, read_only) if file begin @table, checksum, original_data_size = load_data(file, read_only) catch(:pstore_abort_transaction) do value = yield(self) end if !@abort && !read_only save_data(checksum, original_data_size, file) end ensure file.close if !file.closed? end else # This can only occur if read_only == true. @table = {} catch(:pstore_abort_transaction) do value = yield(self) end end end value rescue ThreadError raise PStore::Error, "nested transaction" end private # Constant for relieving Ruby's garbage collector. EMPTY_STRING = "" EMPTY_MARSHAL_DATA = Marshal.dump({}) EMPTY_MARSHAL_CHECKSUM = Digest::MD5.digest(EMPTY_MARSHAL_DATA) # # Open the specified filename (either in read-only mode or in # read-write mode) and lock it for reading or writing. # # The opened File object will be returned. If _read_only_ is true, # and the file does not exist, then nil will be returned. # # All exceptions are propagated. # def open_and_lock_file(filename, read_only) if read_only begin file = File.new(filename, RD_ACCESS) begin file.flock(File::LOCK_SH) return file rescue file.close raise end rescue Errno::ENOENT return nil end else file = File.new(filename, RDWR_ACCESS) file.flock(File::LOCK_EX) return file end end # Load the given PStore file. # If +read_only+ is true, the unmarshalled Hash will be returned. # If +read_only+ is false, a 3-tuple will be returned: the unmarshalled # Hash, an MD5 checksum of the data, and the size of the data. def load_data(file, read_only) if read_only begin table = load(file) if !table.is_a?(Hash) raise Error, "PStore file seems to be corrupted." end rescue EOFError # This seems to be a newly-created file. table = {} end table else data = file.read if data.empty? # This seems to be a newly-created file. table = {} checksum = empty_marshal_checksum size = empty_marshal_data.size else table = load(data) checksum = Digest::MD5.digest(data) size = data.size if !table.is_a?(Hash) raise Error, "PStore file seems to be corrupted." end end data.replace(EMPTY_STRING) [table, checksum, size] end end def on_windows? is_windows = RUBY_PLATFORM =~ /mswin/ || RUBY_PLATFORM =~ /mingw/ || RUBY_PLATFORM =~ /bccwin/ || RUBY_PLATFORM =~ /wince/ self.class.__send__(:define_method, :on_windows?) do is_windows end is_windows end # Check whether Marshal.dump supports the 'canonical' option. This option # makes sure that Marshal.dump always dumps data structures in the same order. # This is important because otherwise, the checksums that we generate may differ. def marshal_dump_supports_canonical_option? begin Marshal.dump(nil, -1, true) result = true rescue result = false end self.class.instance_method(:marshal_dump_supports_canonical_option?) self.class.__send__(:define_method, :marshal_dump_supports_canonical_option?) do result end result end def save_data(original_checksum, original_file_size, file) # We only want to save the new data if the size or checksum has changed. # This results in less filesystem calls, which is good for performance. if marshal_dump_supports_canonical_option? new_data = Marshal.dump(@table, -1, true) else new_data = dump(@table) end new_checksum = Digest::MD5.digest(new_data) if new_data.size != original_file_size || new_checksum != original_checksum if @ultra_safe && !on_windows? # Windows doesn't support atomic file renames. save_data_with_atomic_file_rename_strategy(new_data, file) else save_data_with_fast_strategy(new_data, file) end end new_data.replace(EMPTY_STRING) end def save_data_with_atomic_file_rename_strategy(data, file) temp_filename = "#{@filename}.tmp.#{Process.pid}.#{rand 1000000}" temp_file = File.new(temp_filename, WR_ACCESS) begin temp_file.flock(File::LOCK_EX) temp_file.write(data) temp_file.flush File.rename(temp_filename, @filename) rescue File.unlink(temp_file) rescue nil raise ensure temp_file.close end end def save_data_with_fast_strategy(data, file) file.rewind file.truncate(0) file.write(data) end # This method is just a wrapped around Marshal.dump # to allow subclass overriding used in YAML::Store. def dump(table) # :nodoc: Marshal::dump(table) end # This method is just a wrapped around Marshal.load. # to allow subclass overriding used in YAML::Store. def load(content) # :nodoc: Marshal::load(content) end def empty_marshal_data EMPTY_MARSHAL_DATA end def empty_marshal_checksum EMPTY_MARSHAL_CHECKSUM end end # :enddoc: if __FILE__ == $0 db = PStore.new("/tmp/foo") db.transaction do p db.roots ary = db["root"] = [1,2,3,4] ary[1] = [1,1.5] end 1000.times do db.transaction do db["root"][0] += 1 p db["root"][0] end end db.transaction(true) do p db["root"] end end