| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204 | #!/usr/bin/env python'''Python bindings for libmagic'''import ctypesfrom ctypes import *from ctypes.util import find_librarydef _init():    """    Loads the shared library through ctypes and returns a library    L{ctypes.CDLL} instance     """    return ctypes.cdll.LoadLibrary(find_library('magic'))_libraries = {}_libraries['magic'] = _init()# Flag constants for open and setflagsMAGIC_NONE = NONE = 0MAGIC_DEBUG = DEBUG = 1MAGIC_SYMLINK = SYMLINK = 2MAGIC_COMPRESS = COMPRESS = 4MAGIC_DEVICES = DEVICES = 8MAGIC_MIME_TYPE = MIME_TYPE = 16MAGIC_CONTINUE = CONTINUE = 32MAGIC_CHECK = CHECK = 64MAGIC_PRESERVE_ATIME = PRESERVE_ATIME = 128MAGIC_RAW = RAW = 256MAGIC_ERROR = ERROR = 512MAGIC_MIME_ENCODING = MIME_ENCODING = 1024MAGIC_MIME = MIME = 1040MAGIC_APPLE = APPLE = 2048MAGIC_NO_CHECK_COMPRESS = NO_CHECK_COMPRESS = 4096MAGIC_NO_CHECK_TAR = NO_CHECK_TAR = 8192MAGIC_NO_CHECK_SOFT = NO_CHECK_SOFT = 16384MAGIC_NO_CHECK_APPTYPE = NO_CHECK_APPTYPE = 32768MAGIC_NO_CHECK_ELF = NO_CHECK_ELF = 65536MAGIC_NO_CHECK_TEXT = NO_CHECK_TEXT = 131072MAGIC_NO_CHECK_CDF = NO_CHECK_CDF = 262144MAGIC_NO_CHECK_TOKENS = NO_CHECK_TOKENS = 1048576MAGIC_NO_CHECK_ENCODING = NO_CHECK_ENCODING = 2097152MAGIC_NO_CHECK_BUILTIN = NO_CHECK_BUILTIN = 4173824class magic_set(Structure):    passmagic_set._fields_ = []magic_t = POINTER(magic_set)_open = _libraries['magic'].magic_open_open.restype = magic_t_open.argtypes = [c_int]_close = _libraries['magic'].magic_close_close.restype = None_close.argtypes = [magic_t]_file = _libraries['magic'].magic_file_file.restype = c_char_p_file.argtypes = [magic_t, c_char_p]_descriptor = _libraries['magic'].magic_descriptor_descriptor.restype = c_char_p_descriptor.argtypes = [magic_t, c_int]_buffer = _libraries['magic'].magic_buffer_buffer.restype = c_char_p_buffer.argtypes = [magic_t, c_void_p, c_size_t]_error = _libraries['magic'].magic_error_error.restype = c_char_p_error.argtypes = [magic_t]_setflags = _libraries['magic'].magic_setflags_setflags.restype = c_int_setflags.argtypes = [magic_t, c_int]_load = _libraries['magic'].magic_load_load.restype = c_int_load.argtypes = [magic_t, c_char_p]_compile = _libraries['magic'].magic_compile_compile.restype = c_int_compile.argtypes = [magic_t, c_char_p]_check = _libraries['magic'].magic_check_check.restype = c_int_check.argtypes = [magic_t, c_char_p]_list = _libraries['magic'].magic_list_list.restype = c_int_list.argtypes = [magic_t, c_char_p]_errno = _libraries['magic'].magic_errno_errno.restype = c_int_errno.argtypes = [magic_t]class Magic(object):    def __init__(self, ms):        self._magic_t = ms    def close(self):        """        Closes the magic database and deallocates any resources used.        """        _close(self._magic_t)    def file(self, file):        """        Returns a textual description of the contents of the argument passed        as a filename or None if an error occurred and the MAGIC_ERROR flag        is set.  A call to errno() will return the numeric error code.        """        return _file(self._magic_t, file)    def descriptor(self, fd):        """        Like the file method, but the argument is a file descriptor.        """        return _descriptor(self._magic_t, fd)    def buffer(self, buf):        """        Returns a textual description of the contents of the argument passed        as a buffer or None if an error occurred and the MAGIC_ERROR flag        is set. A call to errno() will return the numeric error code.        """        return _buffer(self._magic_t, buf, len(buf))    def error(self):        """        Returns a textual explanation of the last error or None        if there was no error.        """        return _error(self._magic_t)      def setflags(self, flags):        """        Set flags on the magic object which determine how magic checking behaves;        a bitwise OR of the flags described in libmagic(3), but without the MAGIC_        prefix.        Returns -1 on systems that don't support utime(2) or utimes(2)        when PRESERVE_ATIME is set.        """        return _setflags(self._magic_t, flags)    def load(self, file=None):        """        Must be called to load entries in the colon separated list of database files        passed as argument or the default database file if no argument before        any magic queries can be performed.                Returns 0 on success and -1 on failure.        """        return _load(self._magic_t, file)    def compile(self, dbs):        """        Compile entries in the colon separated list of database files        passed as argument or the default database file if no argument.        Returns 0 on success and -1 on failure.        The compiled files created are named from the basename(1) of each file        argument with ".mgc" appended to it.        """        return _compile(self._magic_t, dbs)    def check(self, dbs):        """        Check the validity of entries in the colon separated list of        database files passed as argument or the default database file        if no argument.        Returns 0 on success and -1 on failure.        """        return _check(self._magic_t, dbs)    def list(self, dbs):        """        Check the validity of entries in the colon separated list of        database files passed as argument or the default database file        if no argument.        Returns 0 on success and -1 on failure.        """        return _list(self._magic_t, dbs)        def errno(self):        """        Returns a numeric error code. If return value is 0, an internal        magic error occurred. If return value is non-zero, the value is        an OS error code. Use the errno module or os.strerror() can be used        to provide detailed error information.        """        return _errno(self._magic_t)def open(flags):    """    Returns a magic object on success and None on failure.    Flags argument as for setflags.    """    return Magic(_open(flags))
 |