404

[ Avaa Bypassed ]




Upload:

Command:

elspacio@3.145.112.178: ~ $
from __future__ import absolute_import

import os
import time

from . import (LockBase, NotLocked, NotMyLock, LockTimeout,
               AlreadyLocked)


class SymlinkLockFile(LockBase):
    """Lock access to a file using symlink(2)."""

    def __init__(self, path, threaded=True, timeout=None):
        # super(SymlinkLockFile).__init(...)
        LockBase.__init__(self, path, threaded, timeout)
        # split it back!
        self.unique_name = os.path.split(self.unique_name)[1]

    def acquire(self, timeout=None):
        # Hopefully unnecessary for symlink.
        # try:
        #     open(self.unique_name, "wb").close()
        # except IOError:
        #     raise LockFailed("failed to create %s" % self.unique_name)
        timeout = timeout if timeout is not None else self.timeout
        end_time = time.time()
        if timeout is not None and timeout > 0:
            end_time += timeout

        while True:
            # Try and create a symbolic link to it.
            try:
                os.symlink(self.unique_name, self.lock_file)
            except OSError:
                # Link creation failed.  Maybe we've double-locked?
                if self.i_am_locking():
                    # Linked to out unique name. Proceed.
                    return
                else:
                    # Otherwise the lock creation failed.
                    if timeout is not None and time.time() > end_time:
                        if timeout > 0:
                            raise LockTimeout("Timeout waiting to acquire"
                                              " lock for %s" %
                                              self.path)
                        else:
                            raise AlreadyLocked("%s is already locked" %
                                                self.path)
                    time.sleep(timeout / 10 if timeout is not None else 0.1)
            else:
                # Link creation succeeded.  We're good to go.
                return

    def release(self):
        if not self.is_locked():
            raise NotLocked("%s is not locked" % self.path)
        elif not self.i_am_locking():
            raise NotMyLock("%s is locked, but not by me" % self.path)
        os.unlink(self.lock_file)

    def is_locked(self):
        return os.path.islink(self.lock_file)

    def i_am_locking(self):
        return (os.path.islink(self.lock_file)
                and os.readlink(self.lock_file) == self.unique_name)

    def break_lock(self):
        if os.path.islink(self.lock_file):  # exists && link
            os.unlink(self.lock_file)

Filemanager

Name Type Size Permission Actions
__init__.py File 9.15 KB 0644
__init__.pyc File 11.83 KB 0644
__init__.pyo File 11.83 KB 0644
linklockfile.py File 2.59 KB 0644
linklockfile.pyc File 2.84 KB 0644
linklockfile.pyo File 2.84 KB 0644
mkdirlockfile.py File 3.02 KB 0644
mkdirlockfile.pyc File 3.35 KB 0644
mkdirlockfile.pyo File 3.35 KB 0644
pidlockfile.py File 5.95 KB 0644
pidlockfile.pyc File 5.77 KB 0644
pidlockfile.pyo File 5.77 KB 0644
sqlitelockfile.py File 5.38 KB 0644
sqlitelockfile.pyc File 4.59 KB 0644
sqlitelockfile.pyo File 4.59 KB 0644
symlinklockfile.py File 2.55 KB 0644
symlinklockfile.pyc File 2.76 KB 0644
symlinklockfile.pyo File 2.76 KB 0644