dissect.target 3.20.2.dev43__tar.gz → 3.20.2.dev45__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (698) hide show
  1. {dissect_target-3.20.2.dev43/dissect.target.egg-info → dissect_target-3.20.2.dev45}/PKG-INFO +1 -1
  2. dissect_target-3.20.2.dev43/dissect/target/plugins/os/windows/defender.py → dissect_target-3.20.2.dev45/dissect/target/plugins/os/windows/defender/_plugin.py +14 -287
  3. dissect_target-3.20.2.dev43/dissect/target/plugins/os/windows/defender_helpers/defender_patterns.py → dissect_target-3.20.2.dev45/dissect/target/plugins/os/windows/defender/mplog.py +190 -15
  4. dissect_target-3.20.2.dev45/dissect/target/plugins/os/windows/defender/quarantine.py +287 -0
  5. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/sru.py +18 -3
  6. dissect_target-3.20.2.dev43/dissect/target/plugins/os/windows/tasks.py → dissect_target-3.20.2.dev45/dissect/target/plugins/os/windows/tasks/_plugin.py +2 -2
  7. dissect_target-3.20.2.dev43/dissect/target/plugins/os/windows/task_helpers/tasks_job.py → dissect_target-3.20.2.dev45/dissect/target/plugins/os/windows/tasks/job.py +1 -1
  8. dissect_target-3.20.2.dev43/dissect/target/plugins/os/windows/task_helpers/tasks_xml.py → dissect_target-3.20.2.dev45/dissect/target/plugins/os/windows/tasks/xml.py +1 -1
  9. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45/dissect.target.egg-info}/PKG-INFO +1 -1
  10. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect.target.egg-info/SOURCES.txt +9 -9
  11. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/test_defender.py +6 -6
  12. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/test_tasks.py +1 -1
  13. dissect_target-3.20.2.dev43/dissect/target/plugins/os/windows/defender_helpers/defender_records.py +0 -191
  14. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/COPYRIGHT +0 -0
  15. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/LICENSE +0 -0
  16. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/MANIFEST.in +0 -0
  17. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/README.md +0 -0
  18. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/__init__.py +0 -0
  19. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/container.py +0 -0
  20. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/containers/__init__.py +0 -0
  21. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/containers/asdf.py +0 -0
  22. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/containers/ewf.py +0 -0
  23. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/containers/fortifw.py +0 -0
  24. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/containers/hdd.py +0 -0
  25. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/containers/hds.py +0 -0
  26. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/containers/qcow2.py +0 -0
  27. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/containers/raw.py +0 -0
  28. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/containers/split.py +0 -0
  29. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/containers/vdi.py +0 -0
  30. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/containers/vhd.py +0 -0
  31. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/containers/vhdx.py +0 -0
  32. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/containers/vmdk.py +0 -0
  33. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/data/autocompletion/target_bash_completion.sh +0 -0
  34. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/exceptions.py +0 -0
  35. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/filesystem.py +0 -0
  36. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/filesystems/__init__.py +0 -0
  37. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/filesystems/ad1.py +0 -0
  38. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/filesystems/btrfs.py +0 -0
  39. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/filesystems/cb.py +0 -0
  40. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/filesystems/config.py +0 -0
  41. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/filesystems/cpio.py +0 -0
  42. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/filesystems/dir.py +0 -0
  43. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/filesystems/exfat.py +0 -0
  44. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/filesystems/extfs.py +0 -0
  45. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/filesystems/fat.py +0 -0
  46. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/filesystems/ffs.py +0 -0
  47. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/filesystems/itunes.py +0 -0
  48. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/filesystems/jffs.py +0 -0
  49. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/filesystems/ntfs.py +0 -0
  50. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/filesystems/overlay.py +0 -0
  51. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/filesystems/smb.py +0 -0
  52. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/filesystems/squashfs.py +0 -0
  53. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/filesystems/tar.py +0 -0
  54. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/filesystems/vmfs.py +0 -0
  55. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/filesystems/vmtar.py +0 -0
  56. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/filesystems/xfs.py +0 -0
  57. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/filesystems/zip.py +0 -0
  58. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/__init__.py +0 -0
  59. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/cache.py +0 -0
  60. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/compat/__init__.py +0 -0
  61. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/compat/path_310.py +0 -0
  62. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/compat/path_311.py +0 -0
  63. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/compat/path_312.py +0 -0
  64. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/compat/path_39.py +0 -0
  65. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/compat/path_common.py +0 -0
  66. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/config.py +0 -0
  67. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/configutil.py +0 -0
  68. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/cyber.py +0 -0
  69. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/data/windowsZones.xml +0 -0
  70. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/descriptor_extensions.py +0 -0
  71. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/docs.py +0 -0
  72. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/fsutil.py +0 -0
  73. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/hashutil.py +0 -0
  74. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/keychain.py +0 -0
  75. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/lazy.py +0 -0
  76. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/loaderutil.py +0 -0
  77. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/localeutil.py +0 -0
  78. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/mount.py +0 -0
  79. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/mui.py +0 -0
  80. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/nfs/__init__.py +0 -0
  81. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/nfs/client.py +0 -0
  82. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/nfs/demo.py +0 -0
  83. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/nfs/nfs3.py +0 -0
  84. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/nfs/serializer.py +0 -0
  85. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/polypath.py +0 -0
  86. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/protobuf.py +0 -0
  87. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/record.py +0 -0
  88. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/record_modifier.py +0 -0
  89. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/regutil.py +0 -0
  90. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/shell_application_ids.py +0 -0
  91. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/shell_folder_ids.py +0 -0
  92. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/sunrpc/__init__.py +0 -0
  93. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/sunrpc/client.py +0 -0
  94. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/sunrpc/serializer.py +0 -0
  95. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/sunrpc/sunrpc.py +0 -0
  96. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/helpers/utils.py +0 -0
  97. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loader.py +0 -0
  98. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/__init__.py +0 -0
  99. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/ab.py +0 -0
  100. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/ad1.py +0 -0
  101. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/asdf.py +0 -0
  102. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/cb.py +0 -0
  103. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/cyber.py +0 -0
  104. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/dir.py +0 -0
  105. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/hyperv.py +0 -0
  106. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/itunes.py +0 -0
  107. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/kape.py +0 -0
  108. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/libvirt.py +0 -0
  109. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/local.py +0 -0
  110. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/log.py +0 -0
  111. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/mqtt.py +0 -0
  112. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/multiraw.py +0 -0
  113. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/ova.py +0 -0
  114. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/overlay.py +0 -0
  115. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/ovf.py +0 -0
  116. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/phobos.py +0 -0
  117. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/profile.py +0 -0
  118. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/proxmox.py +0 -0
  119. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/pvm.py +0 -0
  120. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/pvs.py +0 -0
  121. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/raw.py +0 -0
  122. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/remote.py +0 -0
  123. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/res.py +0 -0
  124. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/smb.py +0 -0
  125. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/tanium.py +0 -0
  126. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/tar.py +0 -0
  127. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/target.py +0 -0
  128. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/utm.py +0 -0
  129. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/vb.py +0 -0
  130. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/vbox.py +0 -0
  131. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/velociraptor.py +0 -0
  132. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/vma.py +0 -0
  133. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/vmwarevm.py +0 -0
  134. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/vmx.py +0 -0
  135. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/loaders/xva.py +0 -0
  136. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugin.py +0 -0
  137. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/__init__.py +0 -0
  138. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/__init__.py +0 -0
  139. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/av/__init__.py +0 -0
  140. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/av/mcafee.py +0 -0
  141. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/av/sophos.py +0 -0
  142. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/av/symantec.py +0 -0
  143. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/av/trendmicro.py +0 -0
  144. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/browser/__init__.py +0 -0
  145. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/browser/brave.py +0 -0
  146. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/browser/browser.py +0 -0
  147. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/browser/chrome.py +0 -0
  148. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/browser/chromium.py +0 -0
  149. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/browser/edge.py +0 -0
  150. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/browser/firefox.py +0 -0
  151. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/browser/iexplore.py +0 -0
  152. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/container/__init__.py +0 -0
  153. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/container/docker.py +0 -0
  154. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/database/__init__.py +0 -0
  155. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/editor/__init__.py +0 -0
  156. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/editor/editor.py +0 -0
  157. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/editor/windowsnotepad.py +0 -0
  158. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/other/__init__.py +0 -0
  159. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/other/env.py +0 -0
  160. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/productivity/__init__.py +0 -0
  161. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/productivity/msoffice.py +0 -0
  162. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/productivity/sevenzip.py +0 -0
  163. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/productivity/winrar.py +0 -0
  164. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/remoteaccess/__init__.py +0 -0
  165. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/remoteaccess/anydesk.py +0 -0
  166. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/remoteaccess/remoteaccess.py +0 -0
  167. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/remoteaccess/teamviewer.py +0 -0
  168. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/shell/__init__.py +0 -0
  169. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/shell/powershell.py +0 -0
  170. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/shell/wget.py +0 -0
  171. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/ssh/__init__.py +0 -0
  172. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/ssh/openssh.py +0 -0
  173. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/ssh/opensshd.py +0 -0
  174. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/ssh/putty.py +0 -0
  175. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/ssh/ssh.py +0 -0
  176. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/virtualization/__init__.py +0 -0
  177. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/virtualization/vmware_workstation.py +0 -0
  178. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/vpn/__init__.py +0 -0
  179. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/vpn/openvpn.py +0 -0
  180. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/vpn/wireguard.py +0 -0
  181. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/webhosting/__init__.py +0 -0
  182. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/webhosting/cpanel.py +0 -0
  183. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/webserver/__init__.py +0 -0
  184. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/webserver/apache.py +0 -0
  185. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/webserver/caddy.py +0 -0
  186. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/webserver/citrix.py +0 -0
  187. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/webserver/iis.py +0 -0
  188. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/webserver/nginx.py +0 -0
  189. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/apps/webserver/webserver.py +0 -0
  190. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/child/__init__.py +0 -0
  191. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/child/docker.py +0 -0
  192. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/child/esxi.py +0 -0
  193. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/child/hyperv.py +0 -0
  194. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/child/parallels.py +0 -0
  195. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/child/proxmox.py +0 -0
  196. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/child/qemu.py +0 -0
  197. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/child/virtuozzo.py +0 -0
  198. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/child/vmware_workstation.py +0 -0
  199. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/child/wsl.py +0 -0
  200. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/filesystem/__init__.py +0 -0
  201. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/filesystem/acquire_handles.py +0 -0
  202. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/filesystem/acquire_hash.py +0 -0
  203. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/filesystem/icat.py +0 -0
  204. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/filesystem/ntfs/__init__.py +0 -0
  205. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/filesystem/ntfs/mft.py +0 -0
  206. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/filesystem/ntfs/mft_timeline.py +0 -0
  207. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/filesystem/ntfs/usnjrnl.py +0 -0
  208. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/filesystem/ntfs/utils.py +0 -0
  209. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/filesystem/resolver.py +0 -0
  210. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/filesystem/unix/__init__.py +0 -0
  211. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/filesystem/unix/capability.py +0 -0
  212. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/filesystem/unix/suid.py +0 -0
  213. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/filesystem/walkfs.py +0 -0
  214. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/filesystem/yara.py +0 -0
  215. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/general/__init__.py +0 -0
  216. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/general/config.py +0 -0
  217. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/general/example.py +0 -0
  218. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/general/loaders.py +0 -0
  219. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/general/osinfo.py +0 -0
  220. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/general/plugins.py +0 -0
  221. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/general/scrape.py +0 -0
  222. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/general/users.py +0 -0
  223. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/__init__.py +0 -0
  224. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/default/__init__.py +0 -0
  225. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/default/_os.py +0 -0
  226. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/default/network.py +0 -0
  227. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/__init__.py +0 -0
  228. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/_os.py +0 -0
  229. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/applications.py +0 -0
  230. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/bsd/__init__.py +0 -0
  231. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/bsd/_os.py +0 -0
  232. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/bsd/citrix/__init__.py +0 -0
  233. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/bsd/citrix/_os.py +0 -0
  234. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/bsd/citrix/history.py +0 -0
  235. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/bsd/freebsd/__init__.py +0 -0
  236. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/bsd/freebsd/_os.py +0 -0
  237. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/bsd/ios/__init__.py +0 -0
  238. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/bsd/ios/_os.py +0 -0
  239. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/bsd/openbsd/__init__.py +0 -0
  240. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/bsd/openbsd/_os.py +0 -0
  241. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/bsd/osx/__init__.py +0 -0
  242. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/bsd/osx/_os.py +0 -0
  243. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/bsd/osx/network.py +0 -0
  244. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/bsd/osx/user.py +0 -0
  245. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/cronjobs.py +0 -0
  246. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/datetime.py +0 -0
  247. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/esxi/__init__.py +0 -0
  248. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/esxi/_os.py +0 -0
  249. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/etc/__init__.py +0 -0
  250. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/etc/etc.py +0 -0
  251. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/generic.py +0 -0
  252. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/history.py +0 -0
  253. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/__init__.py +0 -0
  254. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/_os.py +0 -0
  255. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/android/__init__.py +0 -0
  256. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/android/_os.py +0 -0
  257. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/cmdline.py +0 -0
  258. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/debian/__init__.py +0 -0
  259. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/debian/_os.py +0 -0
  260. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/debian/apt.py +0 -0
  261. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/debian/dpkg.py +0 -0
  262. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/debian/proxmox/__init__.py +0 -0
  263. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/debian/proxmox/_os.py +0 -0
  264. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/debian/proxmox/vm.py +0 -0
  265. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/debian/snap.py +0 -0
  266. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/debian/vyos/__init__.py +0 -0
  267. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/debian/vyos/_os.py +0 -0
  268. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/environ.py +0 -0
  269. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/fortios/__init__.py +0 -0
  270. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/fortios/_keys.py +0 -0
  271. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/fortios/_os.py +0 -0
  272. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/fortios/generic.py +0 -0
  273. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/fortios/locale.py +0 -0
  274. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/iptables.py +0 -0
  275. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/modules.py +0 -0
  276. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/netstat.py +0 -0
  277. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/network.py +0 -0
  278. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/network_managers.py +0 -0
  279. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/proc.py +0 -0
  280. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/processes.py +0 -0
  281. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/redhat/__init__.py +0 -0
  282. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/redhat/_os.py +0 -0
  283. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/redhat/yum.py +0 -0
  284. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/services.py +0 -0
  285. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/sockets.py +0 -0
  286. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/suse/__init__.py +0 -0
  287. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/suse/_os.py +0 -0
  288. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/linux/suse/zypper.py +0 -0
  289. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/locale.py +0 -0
  290. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/locate/__init__.py +0 -0
  291. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/locate/gnulocate.py +0 -0
  292. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/locate/locate.py +0 -0
  293. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/locate/mlocate.py +0 -0
  294. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/locate/plocate.py +0 -0
  295. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/log/__init__.py +0 -0
  296. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/log/atop.py +0 -0
  297. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/log/audit.py +0 -0
  298. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/log/auth.py +0 -0
  299. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/log/helpers.py +0 -0
  300. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/log/journal.py +0 -0
  301. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/log/lastlog.py +0 -0
  302. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/log/messages.py +0 -0
  303. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/log/utmp.py +0 -0
  304. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/packagemanager.py +0 -0
  305. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/shadow.py +0 -0
  306. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/unix/trash.py +0 -0
  307. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/__init__.py +0 -0
  308. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/_os.py +0 -0
  309. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/activitiescache.py +0 -0
  310. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/adpolicy.py +0 -0
  311. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/amcache.py +0 -0
  312. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/catroot.py +0 -0
  313. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/cim.py +0 -0
  314. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/clfs.py +0 -0
  315. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/credential/__init__.py +0 -0
  316. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/credential/credhist.py +0 -0
  317. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/credential/lsa.py +0 -0
  318. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/credential/sam.py +0 -0
  319. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/datetime.py +0 -0
  320. {dissect_target-3.20.2.dev43/dissect/target/plugins/os/windows/defender_helpers → dissect_target-3.20.2.dev45/dissect/target/plugins/os/windows/defender}/__init__.py +0 -0
  321. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/dpapi/__init__.py +0 -0
  322. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/dpapi/blob.py +0 -0
  323. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/dpapi/crypto.py +0 -0
  324. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/dpapi/dpapi.py +0 -0
  325. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/dpapi/keyprovider/__init__.py +0 -0
  326. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/dpapi/keyprovider/credhist.py +0 -0
  327. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/dpapi/keyprovider/empty.py +0 -0
  328. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/dpapi/keyprovider/keychain.py +0 -0
  329. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/dpapi/keyprovider/keyprovider.py +0 -0
  330. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/dpapi/keyprovider/lsa.py +0 -0
  331. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/dpapi/master_key.py +0 -0
  332. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/env.py +0 -0
  333. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/exchange/__init__.py +0 -0
  334. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/exchange/exchange.py +0 -0
  335. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/generic.py +0 -0
  336. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/jumplist.py +0 -0
  337. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/lnk.py +0 -0
  338. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/locale.py +0 -0
  339. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/log/__init__.py +0 -0
  340. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/log/amcache.py +0 -0
  341. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/log/etl.py +0 -0
  342. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/log/evt.py +0 -0
  343. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/log/evtx.py +0 -0
  344. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/log/mssql.py +0 -0
  345. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/log/pfro.py +0 -0
  346. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/log/schedlgu.py +0 -0
  347. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/network.py +0 -0
  348. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/notifications.py +0 -0
  349. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/prefetch.py +0 -0
  350. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/recyclebin.py +0 -0
  351. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/regf/__init__.py +0 -0
  352. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/regf/applications.py +0 -0
  353. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/regf/appxdebugkeys.py +0 -0
  354. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/regf/auditpol.py +0 -0
  355. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/regf/bam.py +0 -0
  356. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/regf/cam.py +0 -0
  357. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/regf/cit.py +0 -0
  358. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/regf/clsid.py +0 -0
  359. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/regf/firewall.py +0 -0
  360. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/regf/mru.py +0 -0
  361. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/regf/muicache.py +0 -0
  362. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/regf/nethist.py +0 -0
  363. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/regf/recentfilecache.py +0 -0
  364. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/regf/regf.py +0 -0
  365. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/regf/runkeys.py +0 -0
  366. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/regf/shellbags.py +0 -0
  367. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/regf/shimcache.py +0 -0
  368. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/regf/trusteddocs.py +0 -0
  369. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/regf/usb.py +0 -0
  370. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/regf/userassist.py +0 -0
  371. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/registry.py +0 -0
  372. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/services.py +0 -0
  373. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/startupinfo.py +0 -0
  374. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/syscache.py +0 -0
  375. {dissect_target-3.20.2.dev43/dissect/target/plugins/os/windows/task_helpers → dissect_target-3.20.2.dev45/dissect/target/plugins/os/windows/tasks}/__init__.py +0 -0
  376. /dissect_target-3.20.2.dev43/dissect/target/plugins/os/windows/task_helpers/tasks_records.py → /dissect_target-3.20.2.dev45/dissect/target/plugins/os/windows/tasks/records.py +0 -0
  377. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/thumbcache.py +0 -0
  378. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/ual.py +0 -0
  379. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/wer.py +0 -0
  380. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/plugins/os/windows/wua_history.py +0 -0
  381. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/report.py +0 -0
  382. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/target.py +0 -0
  383. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/tools/__init__.py +0 -0
  384. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/tools/build_pluginlist.py +0 -0
  385. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/tools/dd.py +0 -0
  386. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/tools/diff.py +0 -0
  387. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/tools/dump/__init__.py +0 -0
  388. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/tools/dump/run.py +0 -0
  389. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/tools/dump/state.py +0 -0
  390. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/tools/dump/utils.py +0 -0
  391. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/tools/fs.py +0 -0
  392. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/tools/fsutils.py +0 -0
  393. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/tools/info.py +0 -0
  394. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/tools/logging.py +0 -0
  395. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/tools/mount.py +0 -0
  396. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/tools/query.py +0 -0
  397. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/tools/reg.py +0 -0
  398. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/tools/shell.py +0 -0
  399. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/tools/utils.py +0 -0
  400. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/tools/yara.py +0 -0
  401. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/volume.py +0 -0
  402. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/volumes/__init__.py +0 -0
  403. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/volumes/bde.py +0 -0
  404. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/volumes/ddf.py +0 -0
  405. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/volumes/disk.py +0 -0
  406. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/volumes/luks.py +0 -0
  407. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/volumes/lvm.py +0 -0
  408. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/volumes/md.py +0 -0
  409. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect/target/volumes/vmfs.py +0 -0
  410. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect.target.egg-info/dependency_links.txt +0 -0
  411. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect.target.egg-info/entry_points.txt +0 -0
  412. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect.target.egg-info/requires.txt +0 -0
  413. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/dissect.target.egg-info/top_level.txt +0 -0
  414. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/pyproject.toml +0 -0
  415. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/setup.cfg +0 -0
  416. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/__init__.py +0 -0
  417. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/_docs/Makefile +0 -0
  418. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/_docs/conf.py +0 -0
  419. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/_docs/index.rst +0 -0
  420. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/_utils.py +0 -0
  421. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/conftest.py +0 -0
  422. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/containers/__init__.py +0 -0
  423. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/containers/test_fortifw.py +0 -0
  424. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/containers/test_split.py +0 -0
  425. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/filesystems/__init__.py +0 -0
  426. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/filesystems/test_btrfs.py +0 -0
  427. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/filesystems/test_cb.py +0 -0
  428. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/filesystems/test_config.py +0 -0
  429. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/filesystems/test_cpio.py +0 -0
  430. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/filesystems/test_dir.py +0 -0
  431. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/filesystems/test_exfat.py +0 -0
  432. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/filesystems/test_extfs.py +0 -0
  433. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/filesystems/test_fat.py +0 -0
  434. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/filesystems/test_ffs.py +0 -0
  435. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/filesystems/test_jffs2.py +0 -0
  436. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/filesystems/test_ntfs.py +0 -0
  437. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/filesystems/test_overlay.py +0 -0
  438. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/filesystems/test_smb.py +0 -0
  439. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/filesystems/test_tar.py +0 -0
  440. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/filesystems/test_vmtar.py +0 -0
  441. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/filesystems/test_xfs.py +0 -0
  442. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/filesystems/test_zip.py +0 -0
  443. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/helpers/__init__.py +0 -0
  444. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/helpers/sunrpc/test_client.py +0 -0
  445. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/helpers/test_cache.py +0 -0
  446. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/helpers/test_config.py +0 -0
  447. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/helpers/test_configutil.py +0 -0
  448. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/helpers/test_docs.py +0 -0
  449. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/helpers/test_fsutil.py +0 -0
  450. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/helpers/test_hashutil.py +0 -0
  451. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/helpers/test_keychain.py +0 -0
  452. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/helpers/test_loaderutil.py +0 -0
  453. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/helpers/test_localeutil.py +0 -0
  454. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/helpers/test_modifier.py +0 -0
  455. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/helpers/test_protobuf.py +0 -0
  456. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/helpers/test_record.py +0 -0
  457. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/helpers/test_regutil.py +0 -0
  458. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/helpers/test_utils.py +0 -0
  459. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/loaders/__init__.py +0 -0
  460. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/loaders/test_ab.py +0 -0
  461. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/loaders/test_asdf.py +0 -0
  462. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/loaders/test_cb.py +0 -0
  463. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/loaders/test_dir.py +0 -0
  464. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/loaders/test_hyperv.py +0 -0
  465. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/loaders/test_itunes.py +0 -0
  466. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/loaders/test_kape.py +0 -0
  467. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/loaders/test_libvirt.py +0 -0
  468. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/loaders/test_local.py +0 -0
  469. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/loaders/test_log.py +0 -0
  470. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/loaders/test_mqtt.py +0 -0
  471. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/loaders/test_multiraw.py +0 -0
  472. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/loaders/test_ova.py +0 -0
  473. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/loaders/test_overlay.py +0 -0
  474. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/loaders/test_ovf.py +0 -0
  475. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/loaders/test_phobos.py +0 -0
  476. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/loaders/test_pvm.py +0 -0
  477. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/loaders/test_pvs.py +0 -0
  478. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/loaders/test_remote.py +0 -0
  479. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/loaders/test_smb.py +0 -0
  480. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/loaders/test_tanium.py +0 -0
  481. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/loaders/test_tar.py +0 -0
  482. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/loaders/test_utm.py +0 -0
  483. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/loaders/test_vbox.py +0 -0
  484. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/loaders/test_velociraptor.py +0 -0
  485. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/loaders/test_vmwarevm.py +0 -0
  486. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/loaders/test_vmx.py +0 -0
  487. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/__init__.py +0 -0
  488. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/__init__.py +0 -0
  489. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/av/__init__.py +0 -0
  490. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/av/test_mcafee.py +0 -0
  491. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/av/test_sophos.py +0 -0
  492. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/av/test_symantec.py +0 -0
  493. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/av/test_trendmicro.py +0 -0
  494. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/browser/__init__.py +0 -0
  495. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/browser/test_brave.py +0 -0
  496. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/browser/test_chrome.py +0 -0
  497. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/browser/test_chromium.py +0 -0
  498. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/browser/test_edge.py +0 -0
  499. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/browser/test_firefox.py +0 -0
  500. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/browser/test_iexplore.py +0 -0
  501. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/container/__init__.py +0 -0
  502. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/container/test_docker.py +0 -0
  503. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/editor/__init__.py +0 -0
  504. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/editor/test_windowsnotepad.py +0 -0
  505. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/other/__init__.py +0 -0
  506. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/other/test_envfile.py +0 -0
  507. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/productivity/__init__.py +0 -0
  508. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/productivity/test_msoffice.py +0 -0
  509. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/productivity/test_sevenzip.py +0 -0
  510. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/productivity/test_winrar.py +0 -0
  511. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/remoteaccess/__init__.py +0 -0
  512. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/remoteaccess/test_anydesk.py +0 -0
  513. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/remoteaccess/test_teamviewer.py +0 -0
  514. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/shell/__init__.py +0 -0
  515. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/shell/test_powershell.py +0 -0
  516. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/shell/test_wget.py +0 -0
  517. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/ssh/__init__.py +0 -0
  518. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/ssh/test_openssh.py +0 -0
  519. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/ssh/test_opensshd.py +0 -0
  520. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/ssh/test_putty.py +0 -0
  521. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/virtualization/__init__.py +0 -0
  522. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/virtualization/test_vmware_workstation.py +0 -0
  523. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/vpn/__init__.py +0 -0
  524. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/vpn/test_openvpn.py +0 -0
  525. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/vpn/test_wireguard.py +0 -0
  526. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/webhosting/__init__.py +0 -0
  527. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/webhosting/test_cpanel.py +0 -0
  528. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/webserver/__init__.py +0 -0
  529. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/webserver/test_apache.py +0 -0
  530. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/webserver/test_caddy.py +0 -0
  531. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/webserver/test_citrix.py +0 -0
  532. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/webserver/test_iis.py +0 -0
  533. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/webserver/test_nginx.py +0 -0
  534. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/apps/webserver/test_webserver.py +0 -0
  535. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/child/__init__.py +0 -0
  536. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/child/test_docker.py +0 -0
  537. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/child/test_hyperv.py +0 -0
  538. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/child/test_parallels.py +0 -0
  539. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/child/test_qemu.py +0 -0
  540. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/child/test_virtuozzo.py +0 -0
  541. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/child/test_vmware_workstation.py +0 -0
  542. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/child/test_wsl.py +0 -0
  543. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/filesystem/__init__.py +0 -0
  544. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/filesystem/ntfs/__init__.py +0 -0
  545. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/filesystem/ntfs/test_mft.py +0 -0
  546. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/filesystem/ntfs/test_usnjrnl.py +0 -0
  547. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/filesystem/test_acquire_handles.py +0 -0
  548. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/filesystem/test_acquire_hash.py +0 -0
  549. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/filesystem/test_icat.py +0 -0
  550. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/filesystem/test_resolver.py +0 -0
  551. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/filesystem/test_walkfs.py +0 -0
  552. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/filesystem/test_yara.py +0 -0
  553. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/filesystem/unix/__init__.py +0 -0
  554. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/filesystem/unix/test_capability.py +0 -0
  555. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/filesystem/unix/test_suid.py +0 -0
  556. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/general/__init__.py +0 -0
  557. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/general/test_config.py +0 -0
  558. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/general/test_default.py +0 -0
  559. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/general/test_network.py +0 -0
  560. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/general/test_plugins.py +0 -0
  561. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/general/test_scrape.py +0 -0
  562. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/general/test_users.py +0 -0
  563. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/__init__.py +0 -0
  564. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/__init__.py +0 -0
  565. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/bsd/__init__.py +0 -0
  566. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/bsd/citrix/__init__.py +0 -0
  567. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/bsd/citrix/test__os.py +0 -0
  568. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/bsd/citrix/test_history.py +0 -0
  569. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/bsd/osx/__init__.py +0 -0
  570. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/bsd/osx/test__os.py +0 -0
  571. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/bsd/osx/test_network.py +0 -0
  572. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/bsd/osx/test_user.py +0 -0
  573. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/esxi/__init__.py +0 -0
  574. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/esxi/test__os.py +0 -0
  575. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/linux/__init__.py +0 -0
  576. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/linux/android/__init__.py +0 -0
  577. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/linux/android/test__os.py +0 -0
  578. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/linux/debian/__init__.py +0 -0
  579. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/linux/debian/proxmox/__init__.py +0 -0
  580. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/linux/debian/proxmox/test__os.py +0 -0
  581. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/linux/debian/test_apt.py +0 -0
  582. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/linux/debian/test_dpkg.py +0 -0
  583. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/linux/debian/test_snap.py +0 -0
  584. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/linux/fortios/__init__.py +0 -0
  585. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/linux/fortios/test__os.py +0 -0
  586. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/linux/fortios/test_keys.py +0 -0
  587. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/linux/redhat/__init__.py +0 -0
  588. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/linux/redhat/test_yum.py +0 -0
  589. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/linux/suse/__init__.py +0 -0
  590. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/linux/suse/test_zypper.py +0 -0
  591. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/linux/test__os.py +0 -0
  592. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/linux/test_cmdline.py +0 -0
  593. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/linux/test_environ.py +0 -0
  594. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/linux/test_iptables.py +0 -0
  595. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/linux/test_modules.py +0 -0
  596. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/linux/test_netstat.py +0 -0
  597. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/linux/test_network.py +0 -0
  598. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/linux/test_proc.py +0 -0
  599. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/linux/test_processes.py +0 -0
  600. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/linux/test_services.py +0 -0
  601. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/linux/test_sockets.py +0 -0
  602. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/locate/__init__.py +0 -0
  603. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/locate/test_gnulocate.py +0 -0
  604. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/locate/test_mlocate.py +0 -0
  605. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/locate/test_plocate.py +0 -0
  606. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/log/__init__.py +0 -0
  607. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/log/test_atop.py +0 -0
  608. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/log/test_audit.py +0 -0
  609. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/log/test_auth.py +0 -0
  610. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/log/test_helpers.py +0 -0
  611. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/log/test_journal.py +0 -0
  612. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/log/test_lastlog.py +0 -0
  613. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/log/test_messages.py +0 -0
  614. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/log/test_utmp.py +0 -0
  615. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/test__os.py +0 -0
  616. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/test_applications.py +0 -0
  617. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/test_generic.py +0 -0
  618. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/test_history.py +0 -0
  619. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/test_ips.py +0 -0
  620. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/test_locale.py +0 -0
  621. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/test_packagemanager.py +0 -0
  622. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/test_shadow.py +0 -0
  623. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/test_trash.py +0 -0
  624. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/test_users.py +0 -0
  625. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/unix/test_version.py +0 -0
  626. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/__init__.py +0 -0
  627. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/credential/__init__.py +0 -0
  628. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/credential/test_credhist.py +0 -0
  629. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/credential/test_lsa.py +0 -0
  630. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/credential/test_sam.py +0 -0
  631. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/log/test_amcache.py +0 -0
  632. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/log/test_etl.py +0 -0
  633. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/log/test_evt.py +0 -0
  634. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/log/test_evtx.py +0 -0
  635. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/log/test_mssql.py +0 -0
  636. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/log/test_schedlgu.py +0 -0
  637. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/regf/__init__.py +0 -0
  638. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/regf/test_applications.py +0 -0
  639. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/regf/test_appxdebugkeys.py +0 -0
  640. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/regf/test_cam.py +0 -0
  641. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/regf/test_cit.py +0 -0
  642. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/regf/test_clsid.py +0 -0
  643. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/regf/test_muicache.py +0 -0
  644. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/regf/test_shellbags.py +0 -0
  645. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/regf/test_trusteddocs.py +0 -0
  646. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/regf/test_usb.py +0 -0
  647. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/regf/test_userassist.py +0 -0
  648. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/test__os.py +0 -0
  649. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/test_adpolicy.py +0 -0
  650. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/test_catroot.py +0 -0
  651. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/test_clfs.py +0 -0
  652. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/test_datetime.py +0 -0
  653. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/test_dpapi.py +0 -0
  654. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/test_env.py +0 -0
  655. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/test_generic.py +0 -0
  656. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/test_jumplist.py +0 -0
  657. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/test_lnk.py +0 -0
  658. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/test_locale.py +0 -0
  659. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/test_mru.py +0 -0
  660. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/test_network.py +0 -0
  661. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/test_notifications.py +0 -0
  662. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/test_prefetch.py +0 -0
  663. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/test_recyclebin.py +0 -0
  664. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/test_registry.py +0 -0
  665. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/test_shimcache.py +0 -0
  666. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/test_sru.py +0 -0
  667. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/test_syscache.py +0 -0
  668. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/test_thumbcache.py +0 -0
  669. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/test_ual.py +0 -0
  670. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/test_wer.py +0 -0
  671. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/plugins/os/windows/test_wua_history.py +0 -0
  672. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/test_container.py +0 -0
  673. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/test_exceptions.py +0 -0
  674. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/test_filesystem.py +0 -0
  675. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/test_plugin.py +0 -0
  676. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/test_registration.py +0 -0
  677. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/test_report.py +0 -0
  678. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/test_target.py +0 -0
  679. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/test_tests.py +0 -0
  680. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/test_volume.py +0 -0
  681. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/tools/__init__.py +0 -0
  682. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/tools/conftest.py +0 -0
  683. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/tools/test_build_pluginlist.py +0 -0
  684. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/tools/test_diff.py +0 -0
  685. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/tools/test_dump.py +0 -0
  686. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/tools/test_fs.py +0 -0
  687. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/tools/test_fsutils.py +0 -0
  688. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/tools/test_info.py +0 -0
  689. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/tools/test_mount.py +0 -0
  690. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/tools/test_query.py +0 -0
  691. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/tools/test_reg.py +0 -0
  692. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/tools/test_shell.py +0 -0
  693. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/tools/test_utils.py +0 -0
  694. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/tools/test_yara.py +0 -0
  695. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/volumes/__init__.py +0 -0
  696. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/volumes/test_bde.py +0 -0
  697. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tests/volumes/test_md.py +0 -0
  698. {dissect_target-3.20.2.dev43 → dissect_target-3.20.2.dev45}/tox.ini +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.2
2
2
  Name: dissect.target
3
- Version: 3.20.2.dev43
3
+ Version: 3.20.2.dev45
4
4
  Summary: This module ties all other Dissect modules together, it provides a programming API and command line tools which allow easy access to various data sources inside disk images or file collections (a.k.a. targets)
5
5
  Author-email: Dissect Team <dissect@fox-it.com>
6
6
  License: Affero General Public License v3
@@ -2,23 +2,18 @@ from __future__ import annotations
2
2
 
3
3
  import re
4
4
  from datetime import datetime, timezone
5
- from io import BytesIO
6
5
  from pathlib import Path
7
- from typing import Any, BinaryIO, Iterable, Iterator, TextIO
6
+ from typing import Any, Iterable, Iterator, TextIO
8
7
 
9
- import dissect.util.ts as ts
10
- from dissect.cstruct import cstruct
11
8
  from flow.record import Record
12
9
 
13
10
  from dissect.target import plugin
14
11
  from dissect.target.exceptions import UnsupportedPluginError
15
12
  from dissect.target.helpers.record import TargetRecordDescriptor
16
- from dissect.target.plugins.os.windows.defender_helpers.defender_patterns import (
13
+ from dissect.target.plugins.os.windows.defender.mplog import (
17
14
  DEFENDER_MPLOG_BLOCK_PATTERNS,
18
15
  DEFENDER_MPLOG_LINE,
19
16
  DEFENDER_MPLOG_PATTERNS,
20
- )
21
- from dissect.target.plugins.os.windows.defender_helpers.defender_records import (
22
17
  DefenderMPLogBMTelemetryRecord,
23
18
  DefenderMPLogDetectionAddRecord,
24
19
  DefenderMPLogDetectionEventRecord,
@@ -34,6 +29,12 @@ from dissect.target.plugins.os.windows.defender_helpers.defender_records import
34
29
  DefenderMPLogThreatActionRecord,
35
30
  DefenderMPLogThreatRecord,
36
31
  )
32
+ from dissect.target.plugins.os.windows.defender.quarantine import (
33
+ DefenderFileQuarantineRecord,
34
+ DefenderQuarantineRecord,
35
+ QuarantineEntry,
36
+ recover_quarantined_file_streams,
37
+ )
37
38
 
38
39
  DEFENDER_EVTX_FIELDS = [
39
40
  ("datetime", "ts"),
@@ -116,158 +117,6 @@ DefenderExclusionRecord = TargetRecordDescriptor(
116
117
  ],
117
118
  )
118
119
 
119
- DefenderQuarantineRecord = TargetRecordDescriptor(
120
- "filesystem/windows/defender/quarantine",
121
- [
122
- ("datetime", "ts"),
123
- ("bytes", "quarantine_id"),
124
- ("bytes", "scan_id"),
125
- ("varint", "threat_id"),
126
- ("string", "detection_type"),
127
- ("string", "detection_name"),
128
- ],
129
- )
130
-
131
- DefenderFileQuarantineRecord = TargetRecordDescriptor(
132
- "filesystem/windows/defender/quarantine/file",
133
- [
134
- ("datetime", "ts"),
135
- ("bytes", "quarantine_id"),
136
- ("bytes", "scan_id"),
137
- ("varint", "threat_id"),
138
- ("string", "detection_type"),
139
- ("string", "detection_name"),
140
- ("string", "detection_path"),
141
- ("datetime", "creation_time"),
142
- ("datetime", "last_write_time"),
143
- ("datetime", "last_accessed_time"),
144
- ("string", "resource_id"),
145
- ],
146
- )
147
-
148
- # Source: https://github.com/brad-sp/cuckoo-modified/blob/master/lib/cuckoo/common/quarantine.py#L188
149
- # fmt: off
150
- DEFENDER_QUARANTINE_RC4_KEY = [
151
- 0x1E, 0x87, 0x78, 0x1B, 0x8D, 0xBA, 0xA8, 0x44, 0xCE, 0x69, 0x70, 0x2C, 0x0C, 0x78, 0xB7, 0x86, 0xA3, 0xF6, 0x23,
152
- 0xB7, 0x38, 0xF5, 0xED, 0xF9, 0xAF, 0x83, 0x53, 0x0F, 0xB3, 0xFC, 0x54, 0xFA, 0xA2, 0x1E, 0xB9, 0xCF, 0x13, 0x31,
153
- 0xFD, 0x0F, 0x0D, 0xA9, 0x54, 0xF6, 0x87, 0xCB, 0x9E, 0x18, 0x27, 0x96, 0x97, 0x90, 0x0E, 0x53, 0xFB, 0x31, 0x7C,
154
- 0x9C, 0xBC, 0xE4, 0x8E, 0x23, 0xD0, 0x53, 0x71, 0xEC, 0xC1, 0x59, 0x51, 0xB8, 0xF3, 0x64, 0x9D, 0x7C, 0xA3, 0x3E,
155
- 0xD6, 0x8D, 0xC9, 0x04, 0x7E, 0x82, 0xC9, 0xBA, 0xAD, 0x97, 0x99, 0xD0, 0xD4, 0x58, 0xCB, 0x84, 0x7C, 0xA9, 0xFF,
156
- 0xBE, 0x3C, 0x8A, 0x77, 0x52, 0x33, 0x55, 0x7D, 0xDE, 0x13, 0xA8, 0xB1, 0x40, 0x87, 0xCC, 0x1B, 0xC8, 0xF1, 0x0F,
157
- 0x6E, 0xCD, 0xD0, 0x83, 0xA9, 0x59, 0xCF, 0xF8, 0x4A, 0x9D, 0x1D, 0x50, 0x75, 0x5E, 0x3E, 0x19, 0x18, 0x18, 0xAF,
158
- 0x23, 0xE2, 0x29, 0x35, 0x58, 0x76, 0x6D, 0x2C, 0x07, 0xE2, 0x57, 0x12, 0xB2, 0xCA, 0x0B, 0x53, 0x5E, 0xD8, 0xF6,
159
- 0xC5, 0x6C, 0xE7, 0x3D, 0x24, 0xBD, 0xD0, 0x29, 0x17, 0x71, 0x86, 0x1A, 0x54, 0xB4, 0xC2, 0x85, 0xA9, 0xA3, 0xDB,
160
- 0x7A, 0xCA, 0x6D, 0x22, 0x4A, 0xEA, 0xCD, 0x62, 0x1D, 0xB9, 0xF2, 0xA2, 0x2E, 0xD1, 0xE9, 0xE1, 0x1D, 0x75, 0xBE,
161
- 0xD7, 0xDC, 0x0E, 0xCB, 0x0A, 0x8E, 0x68, 0xA2, 0xFF, 0x12, 0x63, 0x40, 0x8D, 0xC8, 0x08, 0xDF, 0xFD, 0x16, 0x4B,
162
- 0x11, 0x67, 0x74, 0xCD, 0x0B, 0x9B, 0x8D, 0x05, 0x41, 0x1E, 0xD6, 0x26, 0x2E, 0x42, 0x9B, 0xA4, 0x95, 0x67, 0x6B,
163
- 0x83, 0x98, 0xDB, 0x2F, 0x35, 0xD3, 0xC1, 0xB9, 0xCE, 0xD5, 0x26, 0x36, 0xF2, 0x76, 0x5E, 0x1A, 0x95, 0xCB, 0x7C,
164
- 0xA4, 0xC3, 0xDD, 0xAB, 0xDD, 0xBF, 0xF3, 0x82, 0x53
165
- ]
166
- # fmt: on
167
-
168
- defender_def = """
169
- /* ======== Generic Windows ======== */
170
- /* https://learn.microsoft.com/en-us/windows/win32/api/winbase/ns-winbase-win32_stream_id */
171
-
172
- enum STREAM_ID {
173
- DATA = 0x00000001,
174
- EA_DATA = 0x00000002,
175
- SECURITY_DATA = 0x00000003,
176
- ALTERNATE_DATA = 0x00000004,
177
- LINK = 0x00000005,
178
- PROPERTY_DATA = 0x00000006,
179
- OBJECT_ID = 0x00000007,
180
- REPARSE_DATA = 0x00000008,
181
- SPARSE_BLOCK = 0x00000009,
182
- TXFS_DATA = 0x0000000A,
183
- GHOSTED_FILE_EXTENTS = 0x0000000B,
184
- };
185
-
186
- flag STREAM_ATTRIBUTES {
187
- STREAM_NORMAL_ATTRIBUTE = 0x00000000,
188
- STREAM_MODIFIED_WHEN_READ = 0x00000001,
189
- STREAM_CONTAINS_SECURITY = 0x00000002,
190
- STREAM_CONTAINS_PROPERTIES = 0x00000004,
191
- STREAM_SPARSE_ATTRIBUTE = 0x00000008,
192
- STREAM_CONTAINS_GHOSTED_FILE_EXTENTS = 0x00000010,
193
- };
194
-
195
- typedef struct _WIN32_STREAM_ID {
196
- STREAM_ID StreamId;
197
- STREAM_ATTRIBUTES StreamAttributes;
198
- QWORD Size;
199
- DWORD StreamNameSize;
200
- WCHAR StreamName[StreamNameSize / 2];
201
- } WIN32_STREAM_ID;
202
-
203
- /* ======== Defender Specific ======== */
204
-
205
- enum FIELD_IDENTIFIER : WORD {
206
- CQuaResDataID_File = 0x02,
207
- CQuaResDataID_Registry = 0x03,
208
- Flags = 0x0A,
209
- PhysicalPath = 0x0C,
210
- DetectionContext = 0x0D,
211
- Unknown = 0x0E,
212
- CreationTime = 0x0F,
213
- LastAccessTime = 0x10,
214
- LastWriteTime = 0x11
215
- };
216
-
217
- enum FIELD_TYPE : WORD {
218
- STRING = 0x1,
219
- WSTRING = 0x2,
220
- DWORD = 0x3,
221
- RESOURCE_DATA = 0x4,
222
- BYTES = 0x5,
223
- QWORD = 0x6,
224
- };
225
-
226
- struct QuarantineEntryFileHeader {
227
- CHAR MagicHeader[4];
228
- CHAR Unknown[4];
229
- CHAR _Padding[32];
230
- DWORD Section1Size;
231
- DWORD Section2Size;
232
- DWORD Section1CRC;
233
- DWORD Section2CRC;
234
- CHAR MagicFooter[4];
235
- };
236
-
237
- struct QuarantineEntrySection1 {
238
- CHAR Id[16];
239
- CHAR ScanId[16];
240
- QWORD Timestamp;
241
- QWORD ThreatId;
242
- DWORD One;
243
- CHAR DetectionName[];
244
- };
245
-
246
- struct QuarantineEntrySection2 {
247
- DWORD EntryCount;
248
- DWORD EntryOffsets[EntryCount];
249
- };
250
-
251
- struct QuarantineEntryResource {
252
- WCHAR DetectionPath[];
253
- WORD FieldCount;
254
- CHAR DetectionType[];
255
- };
256
-
257
- struct QuarantineEntryResourceField {
258
- WORD Size;
259
- WORD Identifier:12;
260
- FIELD_TYPE Type:4;
261
- CHAR Data[Size];
262
- };
263
- """
264
-
265
- c_defender = cstruct().load(defender_def)
266
-
267
- STREAM_ID = c_defender.STREAM_ID
268
- STREAM_ATTRIBUTES = c_defender.STREAM_ATTRIBUTES
269
- FIELD_IDENTIFIER = c_defender.FIELD_IDENTIFIER
270
-
271
120
 
272
121
  def parse_iso_datetime(datetime_value: str) -> datetime:
273
122
  """Parse ISO8601 serialized datetime with `Z` ending."""
@@ -286,129 +135,6 @@ def filter_records(records: Iterable, field_name: str, field_value: Any) -> Iter
286
135
  return filter(filter_func, records)
287
136
 
288
137
 
289
- def rc4_crypt(data: bytes) -> bytes:
290
- """RC4 encrypt / decrypt using the Defender Quarantine RC4 Key."""
291
- sbox = list(range(256))
292
- j = 0
293
- for i in range(256):
294
- j = (j + sbox[i] + DEFENDER_QUARANTINE_RC4_KEY[i]) % 256
295
- tmp = sbox[i]
296
- sbox[i] = sbox[j]
297
- sbox[j] = tmp
298
-
299
- out = bytearray(len(data))
300
- i = 0
301
- j = 0
302
- for k in range(len(data)):
303
- i = (i + 1) % 256
304
- j = (j + sbox[i]) % 256
305
- tmp = sbox[i]
306
- sbox[i] = sbox[j]
307
- sbox[j] = tmp
308
- val = sbox[(sbox[i] + sbox[j]) % 256]
309
- out[k] = val ^ data[k]
310
-
311
- return bytes(out)
312
-
313
-
314
- def recover_quarantined_file_streams(fh: BinaryIO, filename: str) -> Iterator[tuple[str, bytes]]:
315
- """Recover the various data streams present in a quarantined file.
316
-
317
- Yields tuples of the output filename and the corresponding output data.
318
- """
319
-
320
- buf = BytesIO(rc4_crypt(fh.read()))
321
-
322
- while True:
323
- try:
324
- stream = c_defender.WIN32_STREAM_ID(buf)
325
- except EOFError:
326
- break
327
- data = buf.read(stream.Size)
328
- if stream.StreamId == STREAM_ID.SECURITY_DATA:
329
- yield (f"{filename}.security_descriptor", data)
330
- elif stream.StreamId == STREAM_ID.DATA:
331
- yield (filename, data)
332
- elif stream.StreamId == STREAM_ID.ALTERNATE_DATA:
333
- sanitized_stream_name = "".join(x for x in stream.StreamName if x.isalnum())
334
- yield (f"{filename}.{sanitized_stream_name}", data)
335
- else:
336
- raise ValueError(f"Unexpected Stream ID {stream.StreamId}")
337
-
338
-
339
- class QuarantineEntry:
340
- def __init__(self, fh: BinaryIO):
341
- # Decrypt & Parse the header so that we know the section sizes
342
- self.header = c_defender.QuarantineEntryFileHeader(rc4_crypt(fh.read(60)))
343
-
344
- # Decrypt & Parse Section 1. This will tell us some information about this quarantine entry.
345
- # These properties are shared for all quarantine entry resources associated with this quarantine entry.
346
- self.metadata = c_defender.QuarantineEntrySection1(rc4_crypt(fh.read(self.header.Section1Size)))
347
-
348
- self.timestamp = ts.wintimestamp(self.metadata.Timestamp)
349
- self.quarantine_id = self.metadata.Id
350
- self.scan_id = self.metadata.ScanId
351
- self.threat_id = self.metadata.ThreatId
352
- self.detection_name = self.metadata.DetectionName
353
-
354
- # The second section contains the number of quarantine entry resources contained in this quarantine entry,
355
- # as well as their offsets. After that, the individal quarantine entry resources start.
356
- resource_buf = BytesIO(rc4_crypt(fh.read(self.header.Section2Size)))
357
- resource_info = c_defender.QuarantineEntrySection2(resource_buf)
358
-
359
- # List holding all quarantine entry resources that belong to this quarantine entry.
360
- self.resources: list[QuarantineEntryResource] = []
361
-
362
- for offset in resource_info.EntryOffsets:
363
- resource_buf.seek(offset)
364
- self.resources.append(QuarantineEntryResource(resource_buf))
365
-
366
-
367
- class QuarantineEntryResource:
368
- def __init__(self, fh: BinaryIO):
369
- self.metadata = c_defender.QuarantineEntryResource(fh)
370
- self.detection_path = self.metadata.DetectionPath
371
- self.field_count = self.metadata.FieldCount
372
- self.detection_type = self.metadata.DetectionType
373
-
374
- # It is possible that certain fields miss from a QuarantineEntryResource even though we expect them. Thus, we
375
- # initialize them in advance with a None value.
376
- self.resource_id = None
377
- self.creation_time = None
378
- self.last_access_time = None
379
- self.last_write_time = None
380
-
381
- self.unknown_fields = []
382
-
383
- # As the fields are aligned, we need to parse them individually
384
- offset = fh.tell()
385
- for _ in range(self.field_count):
386
- # Align
387
- offset = (offset + 3) & 0xFFFFFFFC
388
- fh.seek(offset)
389
- # Parse
390
- field = c_defender.QuarantineEntryResourceField(fh)
391
- self._add_field(field)
392
-
393
- # Move pointer
394
- offset += 4 + field.Size
395
-
396
- def _add_field(self, field: c_defender.QuarantineEntryResourceField) -> None:
397
- if field.Identifier == FIELD_IDENTIFIER.CQuaResDataID_File:
398
- self.resource_id = field.Data.hex().upper()
399
- elif field.Identifier == FIELD_IDENTIFIER.PhysicalPath:
400
- # Decoding as utf-16 leaves a trailing null-byte that we have to strip off.
401
- self.detection_path = field.Data.decode("utf-16").rstrip("\x00")
402
- elif field.Identifier == FIELD_IDENTIFIER.CreationTime:
403
- self.creation_time = ts.wintimestamp(int.from_bytes(field.Data, "little"))
404
- elif field.Identifier == FIELD_IDENTIFIER.LastAccessTime:
405
- self.last_access_time = ts.wintimestamp(int.from_bytes(field.Data, "little"))
406
- elif field.Identifier == FIELD_IDENTIFIER.LastWriteTime:
407
- self.last_write_time = ts.wintimestamp(int.from_bytes(field.Data, "little"))
408
- elif field.Identifier not in FIELD_IDENTIFIER:
409
- self.unknown_fields.append(field)
410
-
411
-
412
138
  class MicrosoftDefenderPlugin(plugin.Plugin):
413
139
  """Plugin that parses artifacts created by Microsoft Defender.
414
140
 
@@ -732,7 +458,8 @@ class MicrosoftDefenderPlugin(plugin.Plugin):
732
458
  information.
733
459
  """
734
460
  if not output_dir.exists():
735
- raise ValueError("Output directory does not exist.")
461
+ raise ValueError("Output directory does not exist")
462
+
736
463
  quarantine_directory = self.target.fs.path(DEFENDER_QUARANTINE_DIR)
737
464
  resourcedata_directory = quarantine_directory.joinpath("ResourceData")
738
465
  if resourcedata_directory.exists() and resourcedata_directory.is_dir():
@@ -746,10 +473,10 @@ class MicrosoftDefenderPlugin(plugin.Plugin):
746
473
  subdir = resource.resource_id[0:2]
747
474
  resourcedata_location = resourcedata_directory.joinpath(subdir).joinpath(resource.resource_id)
748
475
  if not resourcedata_location.exists():
749
- self.target.log.warning(f"Could not find a ResourceData file for {resource.resource_id}.")
476
+ self.target.log.warning("Could not find a ResourceData file for %s", resource.resource_id)
750
477
  continue
751
478
  if not resourcedata_location.is_file():
752
- self.target.log.warning(f"{resourcedata_location} is not a file!")
479
+ self.target.log.warning("%s is not a file!", resourcedata_location)
753
480
  continue
754
481
  if resourcedata_location in recovered_files:
755
482
  # We already recovered this file
@@ -761,7 +488,7 @@ class MicrosoftDefenderPlugin(plugin.Plugin):
761
488
  # reference.
762
489
  for dest_filename, dest_buf in recover_quarantined_file_streams(fh, resource.resource_id):
763
490
  output_filename = output_dir.joinpath(dest_filename)
764
- self.target.log.info(f"Saving {output_filename}")
491
+ self.target.log.info("Saving %s", output_filename)
765
492
  output_filename.write_bytes(dest_buf)
766
493
 
767
494
  # Make sure we do not recover the same file multiple times if it has multiple entries
@@ -783,5 +510,5 @@ class MicrosoftDefenderPlugin(plugin.Plugin):
783
510
  # Warn on discovery of fields that we do not have knowledge of what they are / do.
784
511
  for resource in entry.resources:
785
512
  for unknown_field in resource.unknown_fields:
786
- self.target.log.warning(f"Encountered an unknown field identifier: {unknown_field.Identifier}")
513
+ self.target.log.warning("Encountered an unknown field identifier: %s", unknown_field.Identifier)
787
514
  yield entry
@@ -1,20 +1,195 @@
1
1
  import re
2
2
 
3
- from dissect.target.plugins.os.windows.defender_helpers.defender_records import (
4
- DefenderMPLogBMTelemetryRecord,
5
- DefenderMPLogDetectionAddRecord,
6
- DefenderMPLogDetectionEventRecord,
7
- DefenderMPLogEMSRecord,
8
- DefenderMPLogExclusionRecord,
9
- DefenderMPLogLowfiRecord,
10
- DefenderMPLogMinFilBlockedFileRecord,
11
- DefenderMPLogMinFilUSSRecord,
12
- DefenderMPLogOriginalFileNameRecord,
13
- DefenderMPLogProcessImageRecord,
14
- DefenderMPLogResourceScanRecord,
15
- DefenderMPLogRTPRecord,
16
- DefenderMPLogThreatActionRecord,
17
- DefenderMPLogThreatRecord,
3
+ from dissect.target.helpers.record import TargetRecordDescriptor
4
+
5
+ DefenderMPLogProcessImageRecord = TargetRecordDescriptor(
6
+ "windows/defender/mplog/processimage",
7
+ [
8
+ ("datetime", "ts"),
9
+ ("path", "source_log"),
10
+ ("string", "process_image_name"),
11
+ ("varint", "pid"),
12
+ ("varint", "total_time"),
13
+ ("varint", "count"),
14
+ ("varint", "max_time"),
15
+ ("string", "max_time_file"),
16
+ ("varint", "estimated_impact"),
17
+ ],
18
+ )
19
+
20
+ DefenderMPLogMinFilUSSRecord = TargetRecordDescriptor(
21
+ "windows/defender/mplog/minfiluss",
22
+ [
23
+ ("datetime", "ts"),
24
+ ("path", "source_log"),
25
+ ("path", "path"),
26
+ ("string", "process"),
27
+ ("string", "status"),
28
+ ("string", "state"),
29
+ ("string", "scan_request"),
30
+ ("string", "file_id"),
31
+ ("string", "reason"),
32
+ ("string", "io_status_block_for_new_file"),
33
+ ("string", "desired_access"),
34
+ ("string", "file_attributes"),
35
+ ("string", "scan_attributes"),
36
+ ("string", "access_state_flags"),
37
+ ("string", "backing_file_info"),
38
+ ],
39
+ )
40
+
41
+ DefenderMPLogMinFilBlockedFileRecord = TargetRecordDescriptor(
42
+ "windows/defender/mplog/blockedfile",
43
+ [
44
+ ("datetime", "ts"),
45
+ ("path", "source_log"),
46
+ ("string", "blocked_file"),
47
+ ("string", "process"),
48
+ ("string", "status"),
49
+ ("string", "state"),
50
+ ("string", "scan_request"),
51
+ ("string", "file_id"),
52
+ ("string", "reason"),
53
+ ("string", "io_status_block_for_new_file"),
54
+ ("string", "desired_access"),
55
+ ("string", "file_attributes"),
56
+ ("string", "scan_attributes"),
57
+ ("string", "access_state_flags"),
58
+ ("string", "backing_file_info"),
59
+ ],
60
+ )
61
+
62
+
63
+ DefenderMPLogBMTelemetryRecord = TargetRecordDescriptor(
64
+ "windows/defender/mplog/bmtelemetry",
65
+ [
66
+ ("datetime", "ts"),
67
+ ("path", "source_log"),
68
+ ("string", "guid"),
69
+ ("varint", "signature_id"),
70
+ ("string", "sigsha"),
71
+ ("varint", "threat_level"),
72
+ ("varint", "process_id"),
73
+ ("varint", "process_creation_time"),
74
+ ("varint", "session_id"),
75
+ ("path", "image_path"),
76
+ ("string", "taint_info"),
77
+ ("string", "operations"),
78
+ ],
79
+ )
80
+
81
+ DefenderMPLogEMSRecord = TargetRecordDescriptor(
82
+ "windows/defender/mplog/ems",
83
+ [
84
+ ("datetime", "ts"),
85
+ ("path", "source_log"),
86
+ ("string", "process"),
87
+ ("varint", "pid"),
88
+ ("string", "sigseq"),
89
+ ("varint", "send_memory_scan_report"),
90
+ ("varint", "source"),
91
+ ],
92
+ )
93
+
94
+ DefenderMPLogOriginalFileNameRecord = TargetRecordDescriptor(
95
+ "windows/defender/mplog/originalfilename",
96
+ [
97
+ ("datetime", "ts"),
98
+ ("path", "source_log"),
99
+ ("string", "original_file_name"),
100
+ ("path", "full_path"),
101
+ ("string", "hr"),
102
+ ],
103
+ )
104
+
105
+ DefenderMPLogExclusionRecord = TargetRecordDescriptor(
106
+ "windows/defender/mplog/exclusion",
107
+ [
108
+ ("datetime", "ts"),
109
+ ("path", "source_log"),
110
+ ("path", "full_path_with_drive_letter"),
111
+ ("path", "full_path_with_device_path"),
112
+ ],
113
+ )
114
+
115
+ DefenderMPLogLowfiRecord = TargetRecordDescriptor(
116
+ "windows/defender/mplog/lowfi",
117
+ [
118
+ ("datetime", "ts"),
119
+ ("path", "source_log"),
120
+ ("command", "lowfi"),
121
+ ],
122
+ )
123
+
124
+ DefenderMPLogDetectionAddRecord = TargetRecordDescriptor(
125
+ "windows/defender/mplog/detectionadd",
126
+ [
127
+ ("datetime", "ts"),
128
+ ("path", "source_log"),
129
+ ("string", "detection"),
130
+ ],
131
+ )
132
+
133
+
134
+ DefenderMPLogThreatRecord = TargetRecordDescriptor(
135
+ "windows/defender/mplog/threat",
136
+ [
137
+ ("datetime", "ts"),
138
+ ("path", "source_log"),
139
+ ("command", "threat"),
140
+ ],
141
+ )
142
+
143
+ DefenderMPLogDetectionEventRecord = TargetRecordDescriptor(
144
+ "windows/defender/mplog/detectionevent",
145
+ [
146
+ ("datetime", "ts"),
147
+ ("path", "source_log"),
148
+ ("string", "threat_type"),
149
+ ("command", "command"),
150
+ ],
151
+ )
152
+
153
+ DefenderMPLogResourceScanRecord = TargetRecordDescriptor(
154
+ "windows/defender/mplog/resourcescan",
155
+ [
156
+ ("datetime", "ts"),
157
+ ("path", "source_log"),
158
+ ("string", "scan_id"),
159
+ ("varint", "scan_source"),
160
+ ("datetime", "start_time"),
161
+ ("datetime", "end_time"),
162
+ ("string", "resource_schema"),
163
+ ("path", "resource_path"),
164
+ ("varint", "result_count"),
165
+ ("string[]", "threats"),
166
+ ("path[]", "resources"),
167
+ ],
168
+ )
169
+
170
+ DefenderMPLogThreatActionRecord = TargetRecordDescriptor(
171
+ "windows/defender/mplog/threataction",
172
+ [
173
+ ("datetime", "ts"),
174
+ ("path", "source_log"),
175
+ ("string[]", "threats"),
176
+ ("path[]", "resources"),
177
+ ("string[]", "actions"),
178
+ ],
179
+ )
180
+
181
+ DefenderMPLogRTPRecord = TargetRecordDescriptor(
182
+ "windows/defender/mplog/rtp_log",
183
+ [
184
+ ("datetime", "ts"),
185
+ ("path", "source_log"),
186
+ ("datetime", "last_perf"),
187
+ ("datetime", "first_rtp_scan"),
188
+ ("string", "plugin_states"),
189
+ ("path[]", "process_exclusions"),
190
+ ("path[]", "path_exclusions"),
191
+ ("string[]", "ext_exclusions"),
192
+ ],
18
193
  )
19
194
 
20
195
  DEFENDER_MPLOG_TS_PATTERN = r"(?P<ts>[0-9]{4}-[0-9]{2}-[0-9]{2}T[0-9]{2}:[0-9]{2}:[0-9]{2}\.[0-9]{3}Z) "