GRAYBYTE WORDPRESS FILE MANAGER9287

Server IP : 198.54.121.189 / Your IP : 216.73.216.140
System : Linux premium69.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
PHP Version : 7.4.33
Disable Function : NONE
cURL : ON | WGET : ON | Sudo : OFF | Pkexec : OFF
Directory : /lib/python3.6/site-packages/dnf/
Upload Files :
Current_dir [ Not Writeable ] Document_root [ Writeable ]

Command :


Current File : /lib/python3.6/site-packages/dnf//lock.py
# lock.py
# DNF Locking Subsystem.
#
# Copyright (C) 2013-2016 Red Hat, Inc.
#
# This copyrighted material is made available to anyone wishing to use,
# modify, copy, or redistribute it subject to the terms and conditions of
# the GNU General Public License v.2, or (at your option) any later version.
# This program is distributed in the hope that it will be useful, but WITHOUT
# ANY WARRANTY expressed or implied, including the implied warranties of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General
# Public License for more details.  You should have received a copy of the
# GNU General Public License along with this program; if not, write to the
# Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
# 02110-1301, USA.  Any Red Hat trademarks that are incorporated in the
# source code or documentation are not subject to the GNU General Public
# License and may only be used or replicated with the express permission of
# Red Hat, Inc.
#

from __future__ import absolute_import
from __future__ import unicode_literals
from dnf.exceptions import ProcessLockError, ThreadLockError, LockError
from dnf.i18n import _
from dnf.yum import misc
import dnf.logging
import dnf.util
import errno
import fcntl
import hashlib
import logging
import os
import threading
import time

logger = logging.getLogger("dnf")

def _fit_lock_dir(dir_):
    if not dnf.util.am_i_root():
        # for regular users the best we currently do is not to clash with
        # another DNF process of the same user. Since dir_ is quite definitely
        # not writable for us, yet significant, use its hash:
        hexdir = hashlib.sha1(dir_.encode('utf-8')).hexdigest()
        dir_ = os.path.join(misc.getCacheDir(), 'locks', hexdir)
    return dir_

def build_download_lock(cachedir, exit_on_lock):
    return ProcessLock(os.path.join(_fit_lock_dir(cachedir), 'download_lock.pid'),
                       'cachedir', not exit_on_lock)

def build_metadata_lock(cachedir, exit_on_lock):
    return ProcessLock(os.path.join(_fit_lock_dir(cachedir), 'metadata_lock.pid'),
                       'metadata', not exit_on_lock)


def build_rpmdb_lock(persistdir, exit_on_lock):
    return ProcessLock(os.path.join(_fit_lock_dir(persistdir), 'rpmdb_lock.pid'),
                       'RPMDB', not exit_on_lock)


def build_log_lock(logdir, exit_on_lock):
    return ProcessLock(os.path.join(_fit_lock_dir(logdir), 'log_lock.pid'),
                       'log', not exit_on_lock)


class ProcessLock(object):
    def __init__(self, target, description, blocking=False):
        self.blocking = blocking
        self.count = 0
        self.description = description
        self.target = target
        self.thread_lock = threading.RLock()

    def _lock_thread(self):
        if not self.thread_lock.acquire(blocking=False):
            msg = '%s already locked by a different thread' % self.description
            raise ThreadLockError(msg)
        self.count += 1

    def _try_lock(self, pid):
        fd = os.open(self.target, os.O_CREAT | os.O_RDWR, 0o644)

        try:
            try:
                fcntl.flock(fd, fcntl.LOCK_EX | fcntl.LOCK_NB)
            except OSError as e:
                if e.errno == errno.EWOULDBLOCK:
                    return -1
                raise

            old_pid = os.read(fd, 20)
            if len(old_pid) == 0:
                # empty file, write our pid
                os.write(fd, str(pid).encode('utf-8'))
                return pid

            try:
                old_pid = int(old_pid)
            except ValueError:
                msg = _('Malformed lock file found: %s.\n'
                        'Ensure no other dnf/yum process is running and '
                        'remove the lock file manually or run '
                        'systemd-tmpfiles --remove dnf.conf.') % (self.target)
                raise LockError(msg)

            if old_pid == pid:
                # already locked by this process
                return pid

            if not os.access('/proc/%d/stat' % old_pid, os.F_OK):
                # locked by a dead process, write our pid
                os.lseek(fd, 0, os.SEEK_SET)
                os.ftruncate(fd, 0)
                os.write(fd, str(pid).encode('utf-8'))
                return pid

            return old_pid

        finally:
            os.close(fd)

    def _unlock_thread(self):
        self.count -= 1
        self.thread_lock.release()

    def __enter__(self):
        dnf.util.ensure_dir(os.path.dirname(self.target))
        self._lock_thread()
        prev_pid = -1
        my_pid = os.getpid()
        pid = self._try_lock(my_pid)
        while pid != my_pid:
            if pid != -1:
                if not self.blocking:
                    self._unlock_thread()
                    msg = '%s already locked by %d' % (self.description, pid)
                    raise ProcessLockError(msg, pid)
                if prev_pid != pid:
                    msg = _('Waiting for process with pid %d to finish.') % (pid)
                    logger.info(msg)
                    prev_pid = pid
            time.sleep(1)
            pid = self._try_lock(my_pid)

    def __exit__(self, *exc_args):
        if self.count == 1:
            os.unlink(self.target)
        self._unlock_thread()

[ Back ]
Name
Size
Last Modified
Owner / Group
Permissions
Options
..
--
July 01 2025 22:14:40
root / root
0755
__pycache__
--
March 13 2025 08:41:20
root / root
0755
cli
--
March 13 2025 08:41:20
root / root
0755
conf
--
March 13 2025 08:41:20
root / root
0755
db
--
March 13 2025 08:41:20
root / root
0755
module
--
March 13 2025 08:41:20
root / root
0755
rpm
--
March 13 2025 08:41:20
root / root
0755
yum
--
March 13 2025 08:41:20
root / root
0755
__init__.py
1.356 KB
April 12 2021 15:26:33
root / root
0644
base.py
114.739 KB
March 11 2025 09:47:56
root / root
0644
callback.py
3.637 KB
April 12 2021 15:26:33
root / root
0644
comps.py
24.238 KB
March 11 2025 09:47:56
root / root
0644
const.py
2.313 KB
March 11 2025 09:47:56
root / root
0644
crypto.py
5.979 KB
April 12 2021 15:26:33
root / root
0644
dnssec.py
11.058 KB
April 12 2021 15:26:33
root / root
0644
drpm.py
6.203 KB
April 12 2021 15:26:33
root / root
0644
exceptions.py
5.712 KB
April 12 2021 15:26:33
root / root
0644
goal.py
1.075 KB
April 12 2021 15:26:33
root / root
0644
history.py
1.123 KB
April 12 2021 15:26:33
root / root
0644
i18n.py
12.032 KB
April 12 2021 15:26:33
root / root
0644
lock.py
5.197 KB
April 12 2021 15:26:33
root / root
0644
logging.py
10.111 KB
April 12 2021 15:26:33
root / root
0644
match_counter.py
3.832 KB
April 12 2021 15:26:33
root / root
0644
package.py
10.941 KB
April 12 2021 15:26:33
root / root
0644
persistor.py
4.608 KB
April 12 2021 15:26:33
root / root
0644
plugin.py
9.334 KB
March 11 2025 09:47:56
root / root
0644
pycomp.py
3.52 KB
April 12 2021 15:26:33
root / root
0644
query.py
1.55 KB
April 12 2021 15:26:33
root / root
0644
repo.py
20.324 KB
March 11 2025 09:47:56
root / root
0644
repodict.py
5.037 KB
March 11 2025 09:47:56
root / root
0644
sack.py
2.972 KB
April 12 2021 15:26:33
root / root
0644
selector.py
1.099 KB
April 12 2021 15:26:33
root / root
0644
subject.py
1.123 KB
April 12 2021 15:26:33
root / root
0644
transaction.py
4.294 KB
April 12 2021 15:26:33
root / root
0644
transaction_sr.py
25.595 KB
March 11 2025 09:47:56
root / root
0644
util.py
19.897 KB
April 12 2021 15:26:33
root / root
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2025
CONTACT ME
Static GIF