Uname:
Linux yisu-647059427c03a 3.10.0-862.14.4.el7.x86_64 #1 SMP Wed Sep 26 15:12:11 UTC 2018 x86_64
Software:
nginx/1.22.1
PHP version:
7.3.31 [ PHP INFO ] PHP os:
Linux
Server Ip:
103.146.158.90
Your Ip:
216.73.216.141
User:
www (1000) | Group:
www (1000)
Safe Mode:
OFF
Disable Function:
passthru,exec,system,putenv,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv
import interfaces
import tuned.logs
import pickle
import os
import tuned.consts as consts
log = tuned.logs.get()
class PickleProvider(interfaces.Provider):
__slots__ = ["_path", "_data"]
def __init__(self, path=None):
if path is None:
path = consts.DEFAULT_STORAGE_FILE
self._path = path
self._data = {}
def set(self, namespace, option, value):
self._data.setdefault(namespace, {})
self._data[namespace][option] = value
def get(self, namespace, option, default=None):
self._data.setdefault(namespace, {})
return self._data[namespace].get(option, default)
def unset(self, namespace, option):
self._data.setdefault(namespace, {})
if option in self._data[namespace]:
del self._data[namespace][option]
def save(self):
try:
log.debug("Saving %s" % str(self._data))
with open(self._path, "w") as f:
pickle.dump(self._data, f)
except (OSError, IOError) as e:
log.error("Error saving storage file '%s': %s" % (self._path, e))
def load(self):
try:
with open(self._path, "r") as f:
self._data = pickle.load(f)
except (OSError, IOError) as e:
log.debug("Error loading storage file '%s': %s" % (self._path, e))
self._data = {}
except EOFError:
self._data = {}
def clear(self):
self._data.clear()
try:
os.unlink(self._path)
except (OSError, IOError) as e:
log.debug("Error removing storage file '%s': %s" % (self._path, e))