SILENT KILLERPanel

Current Path: > > usr > lib64 > python2.7 > Demo > > > pdist


Operation   : Linux premium131.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
Software     : Apache
Server IP    : 162.0.232.56 | Your IP: 216.73.216.111
Domains      : 1034 Domain(s)
Permission   : [ 0755 ]

Files and Folders in: //usr/lib64/python2.7/Demo///pdist

NameTypeSizeLast ModifiedActions
FSProxy.py File 7828 bytes April 19 2020 21:13:39.
FSProxy.pyc File 12795 bytes April 10 2024 04:58:46.
FSProxy.pyo File 12795 bytes April 10 2024 04:58:46.
RCSProxy.py File 4723 bytes April 10 2024 04:57:37.
RCSProxy.pyc File 7751 bytes April 10 2024 04:58:46.
RCSProxy.pyo File 7751 bytes April 10 2024 04:58:46.
README File 4264 bytes April 19 2020 21:13:39.
client.py File 4708 bytes April 19 2020 21:13:39.
client.pyc File 6724 bytes April 10 2024 04:58:46.
client.pyo File 6724 bytes April 10 2024 04:58:46.
cmdfw.py File 4641 bytes April 19 2020 21:13:39.
cmdfw.pyc File 5239 bytes April 10 2024 04:58:46.
cmdfw.pyo File 5239 bytes April 10 2024 04:58:46.
cmptree.py File 5778 bytes April 19 2020 21:13:39.
cmptree.pyc File 6123 bytes April 10 2024 04:58:46.
cmptree.pyo File 6123 bytes April 10 2024 04:58:46.
cvslib.py File 10175 bytes April 19 2020 21:13:39.
cvslib.pyc File 13140 bytes April 10 2024 04:58:46.
cvslib.pyo File 13140 bytes April 10 2024 04:58:46.
cvslock.py File 6771 bytes April 19 2020 21:13:39.
cvslock.pyc File 8560 bytes April 10 2024 04:58:46.
cvslock.pyo File 8560 bytes April 10 2024 04:58:46.
mac.py File 352 bytes April 19 2020 21:13:39.
mac.pyc File 598 bytes April 10 2024 04:58:46.
mac.pyo File 598 bytes April 10 2024 04:58:46.
makechangelog.py File 2988 bytes April 10 2024 04:57:37.
makechangelog.pyc File 3122 bytes April 10 2024 04:58:46.
makechangelog.pyo File 3122 bytes April 10 2024 04:58:46.
rcsbump File 745 bytes April 10 2024 04:57:37.
rcsclient.py File 1803 bytes April 19 2020 21:13:39.
rcsclient.pyc File 2100 bytes April 10 2024 04:58:46.
rcsclient.pyo File 2100 bytes April 10 2024 04:58:46.
rcslib.py File 10318 bytes April 19 2020 21:13:39.
rcslib.pyc File 11548 bytes April 10 2024 04:58:46.
rcslib.pyo File 11548 bytes April 10 2024 04:58:46.
rcvs File 117 bytes April 10 2024 04:57:37.
rcvs.py File 13644 bytes April 10 2024 04:57:37.
rcvs.pyc File 14417 bytes April 10 2024 04:58:46.
rcvs.pyo File 14417 bytes April 10 2024 04:58:46.
rrcs File 117 bytes April 10 2024 04:57:37.
rrcs.py File 3992 bytes April 10 2024 04:57:37.
rrcs.pyc File 5629 bytes April 10 2024 04:58:46.
rrcs.pyo File 5629 bytes April 10 2024 04:58:46.
security.py File 1092 bytes April 19 2020 21:13:39.
security.pyc File 1681 bytes April 10 2024 04:58:46.
security.pyo File 1681 bytes April 10 2024 04:58:46.
server.py File 4581 bytes April 19 2020 21:13:39.
server.pyc File 5971 bytes April 10 2024 04:58:46.
server.pyo File 5971 bytes April 10 2024 04:58:46.
sumtree.py File 518 bytes April 19 2020 21:13:39.
sumtree.pyc File 903 bytes April 10 2024 04:58:46.
sumtree.pyo File 903 bytes April 10 2024 04:58:46.

Reading File: //usr/lib64/python2.7/Demo///pdist/FSProxy.py

"""File System Proxy.

Provide an OS-neutral view on a file system, locally or remotely.
The functionality is geared towards implementing some sort of
rdist-like utility between a Mac and a UNIX system.

The module defines three classes:

FSProxyLocal  -- used for local access
FSProxyServer -- used on the server side of remote access
FSProxyClient -- used on the client side of remote access

The remote classes are instantiated with an IP address and an optional
verbosity flag.
"""

import server
import client
import md5
import os
import fnmatch
from stat import *
import time
import fnmatch

maxnamelen = 255

skipnames = (os.curdir, os.pardir)


class FSProxyLocal:

    def __init__(self):
        self._dirstack = []
        self._ignore = ['*.pyc'] + self._readignore()

    def _close(self):
        while self._dirstack:
            self.back()

    def _readignore(self):
        file = self._hide('ignore')
        try:
            f = open(file)
        except IOError:
            file = self._hide('synctree.ignorefiles')
            try:
                f = open(file)
            except IOError:
                return []
        ignore = []
        while 1:
            line = f.readline()
            if not line: break
            if line[-1] == '\n': line = line[:-1]
            ignore.append(line)
        f.close()
        return ignore

    def _hidden(self, name):
        return name[0] == '.'

    def _hide(self, name):
        return '.%s' % name

    def visible(self, name):
        if len(name) > maxnamelen: return 0
        if name[-1] == '~': return 0
        if name in skipnames: return 0
        if self._hidden(name): return 0
        head, tail = os.path.split(name)
        if head or not tail: return 0
        if os.path.islink(name): return 0
        if '\0' in open(name, 'rb').read(512): return 0
        for ign in self._ignore:
            if fnmatch.fnmatch(name, ign): return 0
        return 1

    def check(self, name):
        if not self.visible(name):
            raise os.error, "protected name %s" % repr(name)

    def checkfile(self, name):
        self.check(name)
        if not os.path.isfile(name):
            raise os.error, "not a plain file %s" % repr(name)

    def pwd(self):
        return os.getcwd()

    def cd(self, name):
        self.check(name)
        save = os.getcwd(), self._ignore
        os.chdir(name)
        self._dirstack.append(save)
        self._ignore = self._ignore + self._readignore()

    def back(self):
        if not self._dirstack:
            raise os.error, "empty directory stack"
        dir, ignore = self._dirstack[-1]
        os.chdir(dir)
        del self._dirstack[-1]
        self._ignore = ignore

    def _filter(self, files, pat = None):
        if pat:
            def keep(name, pat = pat):
                return fnmatch.fnmatch(name, pat)
            files = filter(keep, files)
        files = filter(self.visible, files)
        files.sort()
        return files

    def list(self, pat = None):
        files = os.listdir(os.curdir)
        return self._filter(files, pat)

    def listfiles(self, pat = None):
        files = os.listdir(os.curdir)
        files = filter(os.path.isfile, files)
        return self._filter(files, pat)

    def listsubdirs(self, pat = None):
        files = os.listdir(os.curdir)
        files = filter(os.path.isdir, files)
        return self._filter(files, pat)

    def exists(self, name):
        return self.visible(name) and os.path.exists(name)

    def isdir(self, name):
        return self.visible(name) and os.path.isdir(name)

    def islink(self, name):
        return self.visible(name) and os.path.islink(name)

    def isfile(self, name):
        return self.visible(name) and os.path.isfile(name)

    def sum(self, name):
        self.checkfile(name)
        BUFFERSIZE = 1024*8
        f = open(name)
        sum = md5.new()
        while 1:
            buffer = f.read(BUFFERSIZE)
            if not buffer:
                break
            sum.update(buffer)
        return sum.digest()

    def size(self, name):
        self.checkfile(name)
        return os.stat(name)[ST_SIZE]

    def mtime(self, name):
        self.checkfile(name)
        return time.localtime(os.stat(name)[ST_MTIME])

    def stat(self, name):
        self.checkfile(name)
        size = os.stat(name)[ST_SIZE]
        mtime = time.localtime(os.stat(name)[ST_MTIME])
        return size, mtime

    def info(self, name):
        sum = self.sum(name)
        size = os.stat(name)[ST_SIZE]
        mtime = time.localtime(os.stat(name)[ST_MTIME])
        return sum, size, mtime

    def _list(self, function, list):
        if list is None:
            list = self.listfiles()
        res = []
        for name in list:
            try:
                res.append((name, function(name)))
            except (os.error, IOError):
                res.append((name, None))
        return res

    def sumlist(self, list = None):
        return self._list(self.sum, list)

    def statlist(self, list = None):
        return self._list(self.stat, list)

    def mtimelist(self, list = None):
        return self._list(self.mtime, list)

    def sizelist(self, list = None):
        return self._list(self.size, list)

    def infolist(self, list = None):
        return self._list(self.info, list)

    def _dict(self, function, list):
        if list is None:
            list = self.listfiles()
        dict = {}
        for name in list:
            try:
                dict[name] = function(name)
            except (os.error, IOError):
                pass
        return dict

    def sumdict(self, list = None):
        return self.dict(self.sum, list)

    def sizedict(self, list = None):
        return self.dict(self.size, list)

    def mtimedict(self, list = None):
        return self.dict(self.mtime, list)

    def statdict(self, list = None):
        return self.dict(self.stat, list)

    def infodict(self, list = None):
        return self._dict(self.info, list)

    def read(self, name, offset = 0, length = -1):
        self.checkfile(name)
        f = open(name)
        f.seek(offset)
        if length == 0:
            data = ''
        elif length < 0:
            data = f.read()
        else:
            data = f.read(length)
        f.close()
        return data

    def create(self, name):
        self.check(name)
        if os.path.exists(name):
            self.checkfile(name)
            bname = name + '~'
            try:
                os.unlink(bname)
            except os.error:
                pass
            os.rename(name, bname)
        f = open(name, 'w')
        f.close()

    def write(self, name, data, offset = 0):
        self.checkfile(name)
        f = open(name, 'r+')
        f.seek(offset)
        f.write(data)
        f.close()

    def mkdir(self, name):
        self.check(name)
        os.mkdir(name, 0777)

    def rmdir(self, name):
        self.check(name)
        os.rmdir(name)


class FSProxyServer(FSProxyLocal, server.Server):

    def __init__(self, address, verbose = server.VERBOSE):
        FSProxyLocal.__init__(self)
        server.Server.__init__(self, address, verbose)

    def _close(self):
        server.Server._close(self)
        FSProxyLocal._close(self)

    def _serve(self):
        server.Server._serve(self)
        # Retreat into start directory
        while self._dirstack: self.back()


class FSProxyClient(client.Client):

    def __init__(self, address, verbose = client.VERBOSE):
        client.Client.__init__(self, address, verbose)


def test():
    import string
    import sys
    if sys.argv[1:]:
        port = string.atoi(sys.argv[1])
    else:
        port = 4127
    proxy = FSProxyServer(('', port))
    proxy._serverloop()


if __name__ == '__main__':
    test()

SILENT KILLER Tool