Source code for dfvfs.vfs.sqlite_blob_file_entry

"""The SQLite blob file entry implementation."""

from dfvfs.lib import definitions
from dfvfs.lib import errors
from dfvfs.path import sqlite_blob_path_spec
from dfvfs.vfs import file_entry
from dfvfs.vfs import sqlite_blob_directory


[docs] class SQLiteBlobFileEntry(file_entry.FileEntry): """SQLite blob file entry.""" TYPE_INDICATOR = definitions.TYPE_INDICATOR_SQLITE_BLOB
[docs] def __init__( self, resolver_context, file_system, path_spec, is_root=False, is_virtual=False ): """Initializes a file entry. Args: resolver_context (Context): resolver context. file_system (FileSystem): file system. path_spec (PathSpec): path specification. is_root (Optional[bool]): True if the file entry is the root file entry of the corresponding file system. is_virtual (Optional[bool]): True if the file entry is a virtual file entry emulated by the corresponding file system. """ super().__init__( resolver_context, file_system, path_spec, is_root=is_root, is_virtual=is_virtual, ) self._number_of_entries = None if is_virtual: self.entry_type = definitions.FILE_ENTRY_TYPE_DIRECTORY else: self.entry_type = definitions.FILE_ENTRY_TYPE_FILE
def _GetDirectory(self): """Retrieves a directory. Returns: SQLiteBlobDirectory: a directory. """ if self.entry_type != definitions.FILE_ENTRY_TYPE_DIRECTORY: return None return sqlite_blob_directory.SQLiteBlobDirectory( self._file_system, self.path_spec ) def _GetSubFileEntries(self): """Retrieves sub file entries. Yields: SQLiteBlobFileEntry: a sub file entry. """ if self._directory is None: self._directory = self._GetDirectory() if self._directory: for path_spec in self._directory.entries: yield SQLiteBlobFileEntry( self._resolver_context, self._file_system, path_spec ) @property def name(self): """str: name of the file entry, which does not include the full path.""" row_index = getattr(self.path_spec, "row_index", None) if row_index is not None: return f"OFFSET {row_index:d}" row_condition = getattr(self.path_spec, "row_condition", None) if row_condition is not None and len(row_condition) == 3: column_name, operator, value = row_condition if isinstance(value, str): value = f"'{value:s}'" return f"WHERE {column_name:s} {operator:s} {value!s}" # Directory name is full name of column: <table>.<column> table_name = getattr(self.path_spec, "table_name", None) column_name = getattr(self.path_spec, "column_name", None) if table_name and column_name: return f"{table_name:s}.{column_name:s}" return "" @property def size(self): """int: size of the file entry in bytes or None if not available.""" size = None if not self._is_virtual: file_object = self.GetFileObject() if file_object: size = file_object.get_size() return size
[docs] def GetNumberOfRows(self): """Retrieves the number of rows in the table. Returns: int: number of rows. Raises: BackEndError: when the SQLite blob file-like object is missing. """ file_object = self.GetFileObject() if not file_object: raise errors.BackEndError( "Unable to retrieve SQLite blob file-like object." ) # TODO: move this function out of SQLiteBlobFile. self._number_of_entries = file_object.GetNumberOfRows() return self._number_of_entries
[docs] def GetParentFileEntry(self): """Retrieves the parent file entry. Returns: SQLiteBlobFileEntry: parent file entry or None if not available. """ # If the file entry is a sub entry, return the SQLite blob directory. if self._is_virtual: return None path_spec = sqlite_blob_path_spec.SQLiteBlobPathSpec( table_name=self.path_spec.table_name, column_name=self.path_spec.column_name, parent=self.path_spec.parent, ) return SQLiteBlobFileEntry( self._resolver_context, self._file_system, path_spec, is_root=True, is_virtual=True, )