/usr/lib/x86_64-linux-gnu/glusterfs/python/syncdaemon/libgfchangelog.py is in glusterfs-common 3.5.2-2+deb8u3.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 | import os
from ctypes import *
from ctypes.util import find_library
class Changes(object):
libgfc = CDLL(find_library("gfchangelog"), use_errno=True)
@classmethod
def geterrno(cls):
return get_errno()
@classmethod
def raise_oserr(cls):
errn = cls.geterrno()
raise OSError(errn, os.strerror(errn))
@classmethod
def _get_api(cls, call):
return getattr(cls.libgfc, call)
@classmethod
def cl_register(cls, brick, path, log_file, log_level, retries = 0):
ret = cls._get_api('gf_changelog_register')(brick, path,
log_file, log_level, retries)
if ret == -1:
cls.raise_oserr()
@classmethod
def cl_scan(cls):
ret = cls._get_api('gf_changelog_scan')()
if ret == -1:
cls.raise_oserr()
@classmethod
def cl_startfresh(cls):
ret = cls._get_api('gf_changelog_start_fresh')()
if ret == -1:
cls.raise_oserr()
@classmethod
def cl_getchanges(cls):
""" remove hardcoding for path name length """
def clsort(f):
return f.split('.')[-1]
changes = []
buf = create_string_buffer('\0', 4096)
call = cls._get_api('gf_changelog_next_change')
while True:
ret = call(buf, 4096)
if ret in (0, -1):
break;
changes.append(buf.raw[:ret-1])
if ret == -1:
cls.raise_oserr()
# cleanup tracker
cls.cl_startfresh()
return sorted(changes, key=clsort)
@classmethod
def cl_done(cls, clfile):
ret = cls._get_api('gf_changelog_done')(clfile)
if ret == -1:
cls.raise_oserr()
|