Source code for cybox.objects.file_object

# Copyright (c) 2017, The MITRE Corporation. All rights reserved.
# See LICENSE.txt for complete terms.

from mixbox import entities
from mixbox import fields

import cybox.bindings.file_object as file_binding
from cybox.common import (ByteRuns, DateTime, DigitalSignatureList, Double,
        ExtractedFeatures, HashList, HexBinary, ObjectProperties, String,
        UnsignedLong, Integer)


[docs]class FilePath(String): _binding = file_binding _binding_class = file_binding.FilePathType _namespace = 'http://cybox.mitre.org/objects#FileObject-2' fully_qualified = fields.TypedField("fully_qualified")
[docs] def is_plain(self): return (super(FilePath, self).is_plain() and self.fully_qualified is None)
[docs]class EPJumpCode(entities.Entity): _binding = file_binding _binding_class = file_binding.EPJumpCodeType _namespace = 'http://cybox.mitre.org/objects#FileObject-2' depth = fields.TypedField("Depth", Integer) opcodes = fields.TypedField("Opcodes", String)
[docs]class EntryPointSignature(entities.Entity): _binding = file_binding _binding_class = file_binding.EntryPointSignatureType _namespace = 'http://cybox.mitre.org/objects#FileObject-2' name = fields.TypedField("Name", String) type_ = fields.TypedField("Type")
[docs]class EntryPointSignatureList(entities.EntityList): _binding = file_binding _binding_class = file_binding.EntryPointSignatureListType _namespace = 'http://cybox.mitre.org/objects#FileObject-2' entry_point_signature = fields.TypedField("Entry_Point_Signature", EntryPointSignature, multiple=True)
[docs]class Packer(entities.Entity): _binding = file_binding _binding_class = file_binding.PackerType _namespace = 'http://cybox.mitre.org/objects#FileObject-2' name = fields.TypedField("Name", String) version = fields.TypedField("Version", String) entry_point = fields.TypedField("Entry_Point", HexBinary) signature = fields.TypedField("Signature", String) type_ = fields.TypedField("Type", String) detected_entrypoint_signatures = fields.TypedField("Detected_Entrypoint_Signatures", EntryPointSignatureList) ep_jump_codes = fields.TypedField("EP_Jump_Codes", EPJumpCode)
[docs]class PackerList(entities.EntityList): _binding = file_binding _binding_class = file_binding.PackerListType _namespace = 'http://cybox.mitre.org/objects#FileObject-2' packer = fields.TypedField("Packer", Packer, multiple=True)
[docs]class FileAttribute(entities.Entity): """An abstract class for file attributes.""" _namespace = 'http://cybox.mitre.org/objects#FileObject-2' _binding = file_binding _binding_class = _binding.FileAttributeType
[docs]class FilePermissions(entities.Entity): """An abstract class for file permissions.""" _namespace = 'http://cybox.mitre.org/objects#FileObject-2' _binding = file_binding _binding_class = _binding.FilePermissionsType
[docs]class File(ObjectProperties): _binding = file_binding _binding_class = file_binding.FileObjectType _namespace = 'http://cybox.mitre.org/objects#FileObject-2' _XSI_NS = "FileObj" _XSI_TYPE = "FileObjectType" is_packed = fields.TypedField("is_packed") is_masqueraded = fields.TypedField("is_masqueraded") file_name = fields.TypedField("File_Name", String) file_path = fields.TypedField("File_Path", FilePath) device_path = fields.TypedField("Device_Path", String) full_path = fields.TypedField("Full_Path", String) file_extension = fields.TypedField("File_Extension", String) size_in_bytes = fields.TypedField("Size_In_Bytes", UnsignedLong) magic_number = fields.TypedField("Magic_Number", HexBinary) file_format = fields.TypedField("File_Format", String) hashes = fields.TypedField("Hashes", HashList) digital_signatures = fields.TypedField("Digital_Signatures", DigitalSignatureList) modified_time = fields.TypedField("Modified_Time", DateTime) accessed_time = fields.TypedField("Accessed_Time", DateTime) created_time = fields.TypedField("Created_Time", DateTime) # Subclasses must redefine these, since the abstract types # cannot be instantiated. file_attributes_list = fields.TypedField("File_Attributes_List", FileAttribute) # abstract permissions = fields.TypedField("Permissions", FilePermissions) # abstract user_owner = fields.TypedField("User_Owner", String) packer_list = fields.TypedField("Packer_List", PackerList) peak_entropy = fields.TypedField("Peak_Entropy", Double) sym_links = fields.TypedField("Sym_Links", SymLinksList) byte_runs = fields.TypedField("Byte_Runs", ByteRuns) extracted_features = fields.TypedField("Extracted_Features", ExtractedFeatures) encryption_algorithm = fields.TypedField("Encryption_Algorithm", String) decryption_key = fields.TypedField("Decryption_Key", String) compression_method = fields.TypedField("Compression_Method", String) compression_version = fields.TypedField("Compression_Version", String) compression_comment = fields.TypedField("Compression_Comment", String) def __init__(self): super(File, self).__init__() self.is_packed = None @property def md5(self): if self.hashes is None: return None return self.hashes.md5 @md5.setter def md5(self, value): if self.hashes is None: self.hashes = HashList() self.hashes.md5 = value @property def sha1(self): if self.hashes is None: return None return self.hashes.sha1 @sha1.setter def sha1(self, value): if self.hashes is None: self.hashes = HashList() self.hashes.sha1 = value @property def sha224(self): if self.hashes is None: return None return self.hashes.sha224 @sha224.setter def sha224(self, value): if self.hashes is None: self.hashes = HashList() self.hashes.sha224 = value @property def sha256(self): if self.hashes is None: return None return self.hashes.sha256 @sha256.setter def sha256(self, value): if self.hashes is None: self.hashes = HashList() self.hashes.sha256 = value @property def sha384(self): if self.hashes is None: return None return self.hashes.sha384 @sha384.setter def sha384(self, value): if self.hashes is None: self.hashes = HashList() self.hashes.sha384 = value @property def sha512(self): if self.hashes is None: return None return self.hashes.sha512 @sha512.setter def sha512(self, value): if self.hashes is None: self.hashes = HashList() self.hashes.sha512 = value @property def ssdeep(self): if self.hashes is None: return None return self.hashes.ssdeep @ssdeep.setter def ssdeep(self, value): if self.hashes is None: self.hashes = HashList() self.hashes.ssdeep = value @property def size(self): """`size` is an alias for `size_in_bytes`""" return self.size_in_bytes @size.setter def size(self, value): """`size` is an alias for `size_in_bytes`""" self.size_in_bytes = value
[docs] def add_hash(self, hash_): if hash_ is not None: if self.hashes is None: self.hashes = HashList() self.hashes.append(hash_)