dissect.target 3.19.dev13__tar.gz → 3.19.dev14__tar.gz

Sign up to get free protection for your applications and to get access to all the features.
Files changed (593) hide show
  1. {dissect_target-3.19.dev13/dissect.target.egg-info → dissect_target-3.19.dev14}/PKG-INFO +1 -1
  2. dissect_target-3.19.dev14/dissect/target/plugins/apps/remoteaccess/anydesk.py +111 -0
  3. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/remoteaccess/remoteaccess.py +8 -8
  4. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/remoteaccess/teamviewer.py +44 -31
  5. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14/dissect.target.egg-info}/PKG-INFO +1 -1
  6. dissect_target-3.19.dev14/tests/plugins/apps/remoteaccess/test_anydesk.py +84 -0
  7. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/remoteaccess/test_teamviewer.py +11 -11
  8. dissect_target-3.19.dev13/dissect/target/plugins/apps/remoteaccess/anydesk.py +0 -91
  9. dissect_target-3.19.dev13/tests/plugins/apps/remoteaccess/test_anydesk.py +0 -47
  10. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/COPYRIGHT +0 -0
  11. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/LICENSE +0 -0
  12. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/MANIFEST.in +0 -0
  13. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/README.md +0 -0
  14. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/__init__.py +0 -0
  15. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/container.py +0 -0
  16. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/containers/__init__.py +0 -0
  17. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/containers/asdf.py +0 -0
  18. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/containers/ewf.py +0 -0
  19. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/containers/fortifw.py +0 -0
  20. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/containers/hdd.py +0 -0
  21. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/containers/hds.py +0 -0
  22. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/containers/qcow2.py +0 -0
  23. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/containers/raw.py +0 -0
  24. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/containers/split.py +0 -0
  25. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/containers/vdi.py +0 -0
  26. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/containers/vhd.py +0 -0
  27. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/containers/vhdx.py +0 -0
  28. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/containers/vmdk.py +0 -0
  29. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/data/autocompletion/target_bash_completion.sh +0 -0
  30. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/exceptions.py +0 -0
  31. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/filesystem.py +0 -0
  32. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/filesystems/__init__.py +0 -0
  33. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/filesystems/ad1.py +0 -0
  34. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/filesystems/btrfs.py +0 -0
  35. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/filesystems/cb.py +0 -0
  36. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/filesystems/config.py +0 -0
  37. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/filesystems/cpio.py +0 -0
  38. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/filesystems/dir.py +0 -0
  39. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/filesystems/exfat.py +0 -0
  40. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/filesystems/extfs.py +0 -0
  41. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/filesystems/fat.py +0 -0
  42. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/filesystems/ffs.py +0 -0
  43. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/filesystems/itunes.py +0 -0
  44. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/filesystems/jffs.py +0 -0
  45. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/filesystems/ntfs.py +0 -0
  46. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/filesystems/overlay.py +0 -0
  47. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/filesystems/smb.py +0 -0
  48. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/filesystems/squashfs.py +0 -0
  49. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/filesystems/tar.py +0 -0
  50. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/filesystems/vmfs.py +0 -0
  51. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/filesystems/vmtar.py +0 -0
  52. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/filesystems/xfs.py +0 -0
  53. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/filesystems/zip.py +0 -0
  54. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/__init__.py +0 -0
  55. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/cache.py +0 -0
  56. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/compat/__init__.py +0 -0
  57. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/compat/path_310.py +0 -0
  58. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/compat/path_311.py +0 -0
  59. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/compat/path_312.py +0 -0
  60. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/compat/path_39.py +0 -0
  61. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/compat/path_common.py +0 -0
  62. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/config.py +0 -0
  63. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/configutil.py +0 -0
  64. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/cyber.py +0 -0
  65. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/data/windowsZones.xml +0 -0
  66. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/descriptor_extensions.py +0 -0
  67. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/docs.py +0 -0
  68. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/fsutil.py +0 -0
  69. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/hashutil.py +0 -0
  70. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/keychain.py +0 -0
  71. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/lazy.py +0 -0
  72. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/loaderutil.py +0 -0
  73. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/localeutil.py +0 -0
  74. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/mount.py +0 -0
  75. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/mui.py +0 -0
  76. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/network_managers.py +0 -0
  77. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/polypath.py +0 -0
  78. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/protobuf.py +0 -0
  79. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/record.py +0 -0
  80. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/record_modifier.py +0 -0
  81. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/regutil.py +0 -0
  82. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/shell_folder_ids.py +0 -0
  83. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/targetd.py +0 -0
  84. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/helpers/utils.py +0 -0
  85. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loader.py +0 -0
  86. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/__init__.py +0 -0
  87. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/ad1.py +0 -0
  88. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/asdf.py +0 -0
  89. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/cb.py +0 -0
  90. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/cyber.py +0 -0
  91. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/dir.py +0 -0
  92. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/hyperv.py +0 -0
  93. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/itunes.py +0 -0
  94. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/kape.py +0 -0
  95. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/local.py +0 -0
  96. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/log.py +0 -0
  97. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/mqtt.py +0 -0
  98. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/multiraw.py +0 -0
  99. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/ova.py +0 -0
  100. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/overlay.py +0 -0
  101. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/ovf.py +0 -0
  102. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/phobos.py +0 -0
  103. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/profile.py +0 -0
  104. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/pvm.py +0 -0
  105. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/pvs.py +0 -0
  106. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/raw.py +0 -0
  107. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/remote.py +0 -0
  108. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/res.py +0 -0
  109. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/smb.py +0 -0
  110. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/tanium.py +0 -0
  111. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/tar.py +0 -0
  112. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/target.py +0 -0
  113. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/targetd.py +0 -0
  114. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/utm.py +0 -0
  115. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/vb.py +0 -0
  116. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/vbox.py +0 -0
  117. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/velociraptor.py +0 -0
  118. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/vma.py +0 -0
  119. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/vmwarevm.py +0 -0
  120. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/vmx.py +0 -0
  121. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/loaders/xva.py +0 -0
  122. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugin.py +0 -0
  123. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/__init__.py +0 -0
  124. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/__init__.py +0 -0
  125. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/av/__init__.py +0 -0
  126. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/av/mcafee.py +0 -0
  127. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/av/sophos.py +0 -0
  128. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/av/symantec.py +0 -0
  129. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/av/trendmicro.py +0 -0
  130. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/browser/__init__.py +0 -0
  131. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/browser/brave.py +0 -0
  132. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/browser/browser.py +0 -0
  133. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/browser/chrome.py +0 -0
  134. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/browser/chromium.py +0 -0
  135. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/browser/edge.py +0 -0
  136. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/browser/firefox.py +0 -0
  137. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/browser/iexplore.py +0 -0
  138. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/container/__init__.py +0 -0
  139. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/container/docker.py +0 -0
  140. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/remoteaccess/__init__.py +0 -0
  141. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/shell/__init__.py +0 -0
  142. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/shell/powershell.py +0 -0
  143. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/ssh/__init__.py +0 -0
  144. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/ssh/openssh.py +0 -0
  145. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/ssh/opensshd.py +0 -0
  146. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/ssh/putty.py +0 -0
  147. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/ssh/ssh.py +0 -0
  148. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/vpn/__init__.py +0 -0
  149. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/vpn/openvpn.py +0 -0
  150. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/vpn/wireguard.py +0 -0
  151. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/webhosting/__init__.py +0 -0
  152. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/webhosting/cpanel.py +0 -0
  153. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/webserver/__init__.py +0 -0
  154. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/webserver/apache.py +0 -0
  155. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/webserver/caddy.py +0 -0
  156. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/webserver/citrix.py +0 -0
  157. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/webserver/iis.py +0 -0
  158. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/webserver/nginx.py +0 -0
  159. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/apps/webserver/webserver.py +0 -0
  160. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/child/__init__.py +0 -0
  161. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/child/docker.py +0 -0
  162. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/child/esxi.py +0 -0
  163. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/child/hyperv.py +0 -0
  164. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/child/virtuozzo.py +0 -0
  165. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/child/vmware_workstation.py +0 -0
  166. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/child/wsl.py +0 -0
  167. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/filesystem/__init__.py +0 -0
  168. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/filesystem/acquire_handles.py +0 -0
  169. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/filesystem/acquire_hash.py +0 -0
  170. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/filesystem/icat.py +0 -0
  171. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/filesystem/ntfs/__init__.py +0 -0
  172. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/filesystem/ntfs/mft.py +0 -0
  173. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/filesystem/ntfs/mft_timeline.py +0 -0
  174. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/filesystem/ntfs/usnjrnl.py +0 -0
  175. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/filesystem/ntfs/utils.py +0 -0
  176. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/filesystem/resolver.py +0 -0
  177. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/filesystem/unix/__init__.py +0 -0
  178. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/filesystem/unix/capability.py +0 -0
  179. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/filesystem/unix/suid.py +0 -0
  180. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/filesystem/walkfs.py +0 -0
  181. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/filesystem/yara.py +0 -0
  182. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/general/__init__.py +0 -0
  183. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/general/config.py +0 -0
  184. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/general/default.py +0 -0
  185. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/general/example.py +0 -0
  186. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/general/loaders.py +0 -0
  187. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/general/osinfo.py +0 -0
  188. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/general/plugins.py +0 -0
  189. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/general/scrape.py +0 -0
  190. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/general/users.py +0 -0
  191. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/__init__.py +0 -0
  192. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/__init__.py +0 -0
  193. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/_os.py +0 -0
  194. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/bsd/__init__.py +0 -0
  195. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/bsd/_os.py +0 -0
  196. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/bsd/citrix/__init__.py +0 -0
  197. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/bsd/citrix/_os.py +0 -0
  198. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/bsd/citrix/history.py +0 -0
  199. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/bsd/freebsd/__init__.py +0 -0
  200. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/bsd/freebsd/_os.py +0 -0
  201. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/bsd/ios/__init__.py +0 -0
  202. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/bsd/ios/_os.py +0 -0
  203. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/bsd/openbsd/__init__.py +0 -0
  204. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/bsd/openbsd/_os.py +0 -0
  205. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/bsd/osx/__init__.py +0 -0
  206. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/bsd/osx/_os.py +0 -0
  207. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/bsd/osx/user.py +0 -0
  208. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/cronjobs.py +0 -0
  209. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/datetime.py +0 -0
  210. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/esxi/__init__.py +0 -0
  211. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/esxi/_os.py +0 -0
  212. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/etc/__init__.py +0 -0
  213. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/etc/etc.py +0 -0
  214. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/etc.py +0 -0
  215. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/generic.py +0 -0
  216. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/history.py +0 -0
  217. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/__init__.py +0 -0
  218. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/_os.py +0 -0
  219. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/android/__init__.py +0 -0
  220. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/android/_os.py +0 -0
  221. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/cmdline.py +0 -0
  222. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/debian/__init__.py +0 -0
  223. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/debian/_os.py +0 -0
  224. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/debian/apt.py +0 -0
  225. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/debian/dpkg.py +0 -0
  226. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/debian/vyos/__init__.py +0 -0
  227. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/debian/vyos/_os.py +0 -0
  228. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/environ.py +0 -0
  229. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/fortios/__init__.py +0 -0
  230. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/fortios/_keys.py +0 -0
  231. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/fortios/_os.py +0 -0
  232. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/fortios/generic.py +0 -0
  233. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/fortios/locale.py +0 -0
  234. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/iptables.py +0 -0
  235. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/modules.py +0 -0
  236. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/netstat.py +0 -0
  237. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/proc.py +0 -0
  238. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/processes.py +0 -0
  239. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/redhat/__init__.py +0 -0
  240. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/redhat/_os.py +0 -0
  241. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/redhat/yum.py +0 -0
  242. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/services.py +0 -0
  243. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/sockets.py +0 -0
  244. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/suse/__init__.py +0 -0
  245. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/suse/_os.py +0 -0
  246. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/linux/suse/zypper.py +0 -0
  247. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/locale.py +0 -0
  248. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/locate/__init__.py +0 -0
  249. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/locate/gnulocate.py +0 -0
  250. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/locate/locate.py +0 -0
  251. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/locate/mlocate.py +0 -0
  252. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/locate/plocate.py +0 -0
  253. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/log/__init__.py +0 -0
  254. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/log/atop.py +0 -0
  255. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/log/audit.py +0 -0
  256. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/log/auth.py +0 -0
  257. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/log/journal.py +0 -0
  258. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/log/lastlog.py +0 -0
  259. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/log/messages.py +0 -0
  260. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/log/utmp.py +0 -0
  261. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/packagemanager.py +0 -0
  262. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/unix/shadow.py +0 -0
  263. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/__init__.py +0 -0
  264. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/_os.py +0 -0
  265. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/activitiescache.py +0 -0
  266. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/adpolicy.py +0 -0
  267. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/amcache.py +0 -0
  268. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/catroot.py +0 -0
  269. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/cim.py +0 -0
  270. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/clfs.py +0 -0
  271. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/credhist.py +0 -0
  272. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/datetime.py +0 -0
  273. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/defender.py +0 -0
  274. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/defender_helpers/__init__.py +0 -0
  275. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/defender_helpers/defender_patterns.py +0 -0
  276. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/defender_helpers/defender_records.py +0 -0
  277. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/dpapi/__init__.py +0 -0
  278. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/dpapi/blob.py +0 -0
  279. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/dpapi/crypto.py +0 -0
  280. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/dpapi/dpapi.py +0 -0
  281. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/dpapi/master_key.py +0 -0
  282. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/env.py +0 -0
  283. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/exchange/__init__.py +0 -0
  284. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/exchange/exchange.py +0 -0
  285. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/generic.py +0 -0
  286. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/lnk.py +0 -0
  287. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/locale.py +0 -0
  288. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/log/__init__.py +0 -0
  289. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/log/amcache.py +0 -0
  290. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/log/etl.py +0 -0
  291. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/log/evt.py +0 -0
  292. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/log/evtx.py +0 -0
  293. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/log/pfro.py +0 -0
  294. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/log/schedlgu.py +0 -0
  295. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/notifications.py +0 -0
  296. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/prefetch.py +0 -0
  297. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/recyclebin.py +0 -0
  298. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/regf/7zip.py +0 -0
  299. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/regf/__init__.py +0 -0
  300. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/regf/appxdebugkeys.py +0 -0
  301. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/regf/auditpol.py +0 -0
  302. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/regf/bam.py +0 -0
  303. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/regf/cit.py +0 -0
  304. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/regf/clsid.py +0 -0
  305. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/regf/firewall.py +0 -0
  306. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/regf/mru.py +0 -0
  307. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/regf/muicache.py +0 -0
  308. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/regf/nethist.py +0 -0
  309. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/regf/recentfilecache.py +0 -0
  310. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/regf/regf.py +0 -0
  311. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/regf/runkeys.py +0 -0
  312. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/regf/shellbags.py +0 -0
  313. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/regf/shimcache.py +0 -0
  314. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/regf/trusteddocs.py +0 -0
  315. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/regf/usb.py +0 -0
  316. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/regf/userassist.py +0 -0
  317. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/registry.py +0 -0
  318. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/sam.py +0 -0
  319. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/services.py +0 -0
  320. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/sru.py +0 -0
  321. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/startupinfo.py +0 -0
  322. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/syscache.py +0 -0
  323. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/task_helpers/__init__.py +0 -0
  324. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/task_helpers/tasks_job.py +0 -0
  325. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/task_helpers/tasks_records.py +0 -0
  326. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/task_helpers/tasks_xml.py +0 -0
  327. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/tasks.py +0 -0
  328. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/thumbcache.py +0 -0
  329. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/ual.py +0 -0
  330. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/plugins/os/windows/wer.py +0 -0
  331. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/report.py +0 -0
  332. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/target.py +0 -0
  333. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/tools/__init__.py +0 -0
  334. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/tools/build_pluginlist.py +0 -0
  335. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/tools/dd.py +0 -0
  336. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/tools/dump/__init__.py +0 -0
  337. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/tools/dump/run.py +0 -0
  338. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/tools/dump/state.py +0 -0
  339. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/tools/dump/utils.py +0 -0
  340. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/tools/fs.py +0 -0
  341. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/tools/info.py +0 -0
  342. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/tools/logging.py +0 -0
  343. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/tools/mount.py +0 -0
  344. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/tools/query.py +0 -0
  345. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/tools/reg.py +0 -0
  346. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/tools/shell.py +0 -0
  347. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/tools/utils.py +0 -0
  348. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/volume.py +0 -0
  349. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/volumes/__init__.py +0 -0
  350. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/volumes/bde.py +0 -0
  351. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/volumes/ddf.py +0 -0
  352. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/volumes/disk.py +0 -0
  353. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/volumes/luks.py +0 -0
  354. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/volumes/lvm.py +0 -0
  355. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/volumes/md.py +0 -0
  356. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect/target/volumes/vmfs.py +0 -0
  357. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect.target.egg-info/SOURCES.txt +0 -0
  358. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect.target.egg-info/dependency_links.txt +0 -0
  359. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect.target.egg-info/entry_points.txt +0 -0
  360. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect.target.egg-info/requires.txt +0 -0
  361. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/dissect.target.egg-info/top_level.txt +0 -0
  362. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/pyproject.toml +0 -0
  363. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/setup.cfg +0 -0
  364. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/__init__.py +0 -0
  365. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/_docs/Makefile +0 -0
  366. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/_docs/conf.py +0 -0
  367. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/_docs/index.rst +0 -0
  368. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/_utils.py +0 -0
  369. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/conftest.py +0 -0
  370. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/containers/__init__.py +0 -0
  371. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/containers/test_fortifw.py +0 -0
  372. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/containers/test_split.py +0 -0
  373. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/filesystems/__init__.py +0 -0
  374. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/filesystems/test_cb.py +0 -0
  375. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/filesystems/test_config.py +0 -0
  376. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/filesystems/test_cpio.py +0 -0
  377. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/filesystems/test_dir.py +0 -0
  378. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/filesystems/test_exfat.py +0 -0
  379. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/filesystems/test_fat.py +0 -0
  380. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/filesystems/test_ntfs.py +0 -0
  381. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/filesystems/test_overlay.py +0 -0
  382. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/filesystems/test_smb.py +0 -0
  383. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/filesystems/test_tar.py +0 -0
  384. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/filesystems/test_vmtar.py +0 -0
  385. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/filesystems/test_zip.py +0 -0
  386. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/helpers/__init__.py +0 -0
  387. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/helpers/test_cache.py +0 -0
  388. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/helpers/test_config.py +0 -0
  389. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/helpers/test_configutil.py +0 -0
  390. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/helpers/test_docs.py +0 -0
  391. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/helpers/test_fsutil.py +0 -0
  392. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/helpers/test_hashutil.py +0 -0
  393. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/helpers/test_keychain.py +0 -0
  394. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/helpers/test_loaderutil.py +0 -0
  395. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/helpers/test_localeutil.py +0 -0
  396. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/helpers/test_modifier.py +0 -0
  397. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/helpers/test_protobuf.py +0 -0
  398. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/helpers/test_record.py +0 -0
  399. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/helpers/test_regutil.py +0 -0
  400. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/helpers/test_utils.py +0 -0
  401. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/loaders/__init__.py +0 -0
  402. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/loaders/test_asdf.py +0 -0
  403. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/loaders/test_cb.py +0 -0
  404. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/loaders/test_dir.py +0 -0
  405. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/loaders/test_hyperv.py +0 -0
  406. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/loaders/test_kape.py +0 -0
  407. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/loaders/test_local.py +0 -0
  408. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/loaders/test_log.py +0 -0
  409. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/loaders/test_mqtt.py +0 -0
  410. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/loaders/test_multiraw.py +0 -0
  411. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/loaders/test_ova.py +0 -0
  412. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/loaders/test_overlay.py +0 -0
  413. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/loaders/test_ovf.py +0 -0
  414. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/loaders/test_phobos.py +0 -0
  415. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/loaders/test_pvm.py +0 -0
  416. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/loaders/test_pvs.py +0 -0
  417. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/loaders/test_remote.py +0 -0
  418. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/loaders/test_smb.py +0 -0
  419. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/loaders/test_tanium.py +0 -0
  420. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/loaders/test_tar.py +0 -0
  421. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/loaders/test_utm.py +0 -0
  422. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/loaders/test_vbox.py +0 -0
  423. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/loaders/test_velociraptor.py +0 -0
  424. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/loaders/test_vmwarevm.py +0 -0
  425. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/__init__.py +0 -0
  426. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/__init__.py +0 -0
  427. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/av/__init__.py +0 -0
  428. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/av/test_mcafee.py +0 -0
  429. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/av/test_sophos.py +0 -0
  430. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/av/test_symantec.py +0 -0
  431. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/av/test_trendmicro.py +0 -0
  432. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/browser/__init__.py +0 -0
  433. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/browser/test_brave.py +0 -0
  434. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/browser/test_chrome.py +0 -0
  435. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/browser/test_chromium.py +0 -0
  436. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/browser/test_edge.py +0 -0
  437. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/browser/test_firefox.py +0 -0
  438. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/browser/test_iexplore.py +0 -0
  439. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/container/__init__.py +0 -0
  440. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/container/test_docker.py +0 -0
  441. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/remoteaccess/__init__.py +0 -0
  442. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/shell/__init__.py +0 -0
  443. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/shell/test_powershell.py +0 -0
  444. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/ssh/__init__.py +0 -0
  445. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/ssh/test_openssh.py +0 -0
  446. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/ssh/test_opensshd.py +0 -0
  447. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/ssh/test_putty.py +0 -0
  448. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/vpn/__init__.py +0 -0
  449. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/vpn/test_openvpn.py +0 -0
  450. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/vpn/test_wireguard.py +0 -0
  451. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/webhosting/__init__.py +0 -0
  452. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/webhosting/test_cpanel.py +0 -0
  453. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/webserver/__init__.py +0 -0
  454. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/webserver/test_apache.py +0 -0
  455. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/webserver/test_caddy.py +0 -0
  456. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/webserver/test_citrix.py +0 -0
  457. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/webserver/test_iis.py +0 -0
  458. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/webserver/test_nginx.py +0 -0
  459. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/apps/webserver/test_webserver.py +0 -0
  460. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/child/__init__.py +0 -0
  461. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/child/test_docker.py +0 -0
  462. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/child/test_hyperv.py +0 -0
  463. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/child/test_virtuozzo.py +0 -0
  464. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/child/test_wsl.py +0 -0
  465. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/filesystem/__init__.py +0 -0
  466. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/filesystem/ntfs/__init__.py +0 -0
  467. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/filesystem/ntfs/test_mft.py +0 -0
  468. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/filesystem/ntfs/test_usnjrnl.py +0 -0
  469. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/filesystem/test_acquire_handles.py +0 -0
  470. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/filesystem/test_acquire_hash.py +0 -0
  471. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/filesystem/test_icat.py +0 -0
  472. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/filesystem/test_resolver.py +0 -0
  473. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/filesystem/test_walkfs.py +0 -0
  474. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/filesystem/test_yara.py +0 -0
  475. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/filesystem/unix/__init__.py +0 -0
  476. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/filesystem/unix/test_capability.py +0 -0
  477. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/filesystem/unix/test_suid.py +0 -0
  478. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/general/__init__.py +0 -0
  479. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/general/test_config.py +0 -0
  480. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/general/test_default.py +0 -0
  481. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/general/test_plugins.py +0 -0
  482. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/general/test_scrape.py +0 -0
  483. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/general/test_users.py +0 -0
  484. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/__init__.py +0 -0
  485. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/__init__.py +0 -0
  486. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/bsd/__init__.py +0 -0
  487. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/bsd/citrix/__init__.py +0 -0
  488. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/bsd/citrix/test__os.py +0 -0
  489. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/bsd/citrix/test_history.py +0 -0
  490. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/bsd/osx/__init__.py +0 -0
  491. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/bsd/osx/test__os.py +0 -0
  492. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/bsd/osx/test_user.py +0 -0
  493. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/esxi/__init__.py +0 -0
  494. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/esxi/test__os.py +0 -0
  495. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/linux/__init__.py +0 -0
  496. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/linux/android/__init__.py +0 -0
  497. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/linux/android/test__os.py +0 -0
  498. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/linux/debian/__init__.py +0 -0
  499. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/linux/debian/test_apt.py +0 -0
  500. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/linux/debian/test_dpkg.py +0 -0
  501. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/linux/fortios/test_keys.py +0 -0
  502. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/linux/redhat/__init__.py +0 -0
  503. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/linux/redhat/test_yum.py +0 -0
  504. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/linux/suse/__init__.py +0 -0
  505. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/linux/suse/test_zypper.py +0 -0
  506. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/linux/test_cmdline.py +0 -0
  507. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/linux/test_environ.py +0 -0
  508. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/linux/test_iptables.py +0 -0
  509. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/linux/test_modules.py +0 -0
  510. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/linux/test_netstat.py +0 -0
  511. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/linux/test_proc.py +0 -0
  512. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/linux/test_processes.py +0 -0
  513. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/linux/test_services.py +0 -0
  514. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/linux/test_sockets.py +0 -0
  515. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/locate/__init__.py +0 -0
  516. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/locate/test_gnulocate.py +0 -0
  517. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/locate/test_mlocate.py +0 -0
  518. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/locate/test_plocate.py +0 -0
  519. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/log/__init__.py +0 -0
  520. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/log/test_atop.py +0 -0
  521. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/log/test_audit.py +0 -0
  522. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/log/test_auth.py +0 -0
  523. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/log/test_lastlog.py +0 -0
  524. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/log/test_messages.py +0 -0
  525. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/log/test_utmp.py +0 -0
  526. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/test__os.py +0 -0
  527. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/test_generic.py +0 -0
  528. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/test_history.py +0 -0
  529. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/test_ips.py +0 -0
  530. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/test_journal.py +0 -0
  531. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/test_locale.py +0 -0
  532. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/test_packagemanager.py +0 -0
  533. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/test_shadow.py +0 -0
  534. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/test_users.py +0 -0
  535. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/unix/test_version.py +0 -0
  536. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/__init__.py +0 -0
  537. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/log/test_etl.py +0 -0
  538. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/log/test_evt.py +0 -0
  539. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/log/test_evtx.py +0 -0
  540. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/log/test_schedlgu.py +0 -0
  541. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/regf/__init__.py +0 -0
  542. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/regf/test_appxdebugkeys.py +0 -0
  543. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/regf/test_cit.py +0 -0
  544. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/regf/test_clsid.py +0 -0
  545. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/regf/test_muicache.py +0 -0
  546. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/regf/test_shellbags.py +0 -0
  547. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/regf/test_trusteddocs.py +0 -0
  548. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/regf/test_userassist.py +0 -0
  549. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/test__os.py +0 -0
  550. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/test_adpolicy.py +0 -0
  551. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/test_amcache.py +0 -0
  552. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/test_catroot.py +0 -0
  553. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/test_clfs.py +0 -0
  554. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/test_credhist.py +0 -0
  555. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/test_datetime.py +0 -0
  556. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/test_defender.py +0 -0
  557. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/test_dpapi.py +0 -0
  558. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/test_env.py +0 -0
  559. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/test_generic.py +0 -0
  560. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/test_lnk.py +0 -0
  561. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/test_locale.py +0 -0
  562. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/test_mru.py +0 -0
  563. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/test_notifications.py +0 -0
  564. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/test_prefetch.py +0 -0
  565. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/test_recyclebin.py +0 -0
  566. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/test_registry.py +0 -0
  567. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/test_sam.py +0 -0
  568. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/test_shimcache.py +0 -0
  569. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/test_sru.py +0 -0
  570. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/test_syscache.py +0 -0
  571. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/test_tasks.py +0 -0
  572. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/test_thumbcache.py +0 -0
  573. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/test_ual.py +0 -0
  574. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/plugins/os/windows/test_wer.py +0 -0
  575. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/test_container.py +0 -0
  576. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/test_filesystem.py +0 -0
  577. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/test_plugin.py +0 -0
  578. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/test_registration.py +0 -0
  579. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/test_report.py +0 -0
  580. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/test_target.py +0 -0
  581. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/test_volume.py +0 -0
  582. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/tools/__init__.py +0 -0
  583. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/tools/test_dump.py +0 -0
  584. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/tools/test_fs.py +0 -0
  585. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/tools/test_mount.py +0 -0
  586. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/tools/test_query.py +0 -0
  587. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/tools/test_reg.py +0 -0
  588. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/tools/test_shell.py +0 -0
  589. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/tools/test_utils.py +0 -0
  590. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/volumes/__init__.py +0 -0
  591. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/volumes/test_bde.py +0 -0
  592. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tests/volumes/test_md.py +0 -0
  593. {dissect_target-3.19.dev13 → dissect_target-3.19.dev14}/tox.ini +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: dissect.target
3
- Version: 3.19.dev13
3
+ Version: 3.19.dev14
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
@@ -0,0 +1,111 @@
1
+ import re
2
+ from datetime import datetime, timezone
3
+ from typing import Iterator
4
+
5
+ from dissect.target.exceptions import UnsupportedPluginError
6
+ from dissect.target.helpers.descriptor_extensions import UserRecordDescriptorExtension
7
+ from dissect.target.helpers.fsutil import TargetPath
8
+ from dissect.target.helpers.record import create_extended_descriptor
9
+ from dissect.target.plugin import export
10
+ from dissect.target.plugins.apps.remoteaccess.remoteaccess import (
11
+ GENERIC_LOG_RECORD_FIELDS,
12
+ RemoteAccessPlugin,
13
+ )
14
+ from dissect.target.plugins.general.users import UserDetails
15
+
16
+
17
+ class AnydeskPlugin(RemoteAccessPlugin):
18
+ """Anydesk plugin."""
19
+
20
+ __namespace__ = "anydesk"
21
+
22
+ # Anydesk logs when installed as a service
23
+ SERVICE_GLOBS = [
24
+ # Standard client >= Windows 7
25
+ "sysvol/ProgramData/AnyDesk/*.trace",
26
+ # Custom client >= Windows 7
27
+ "sysvol/ProgramData/AnyDesk/ad_*/*.trace",
28
+ # Windows XP / 2003
29
+ "sysvol/Documents and Settings/Public/AnyDesk/*.trace",
30
+ "sysvol/Documents and Settings/Public/AnyDesk/ad_*/*.trace",
31
+ # Standard/Custom client Linux/MacOS
32
+ "var/log/anydesk*/*.trace",
33
+ ]
34
+
35
+ # User specific Anydesk logs
36
+ USER_GLOBS = [
37
+ # Standard client Windows
38
+ "AppData/Roaming/AnyDesk/*.trace",
39
+ # Custom client Windows
40
+ "AppData/Roaming/AnyDesk/ad_*/*.trace",
41
+ # Windows XP / 2003
42
+ "AppData/AnyDesk/*.trace",
43
+ # Standard client Linux/MacOS
44
+ ".anydesk/*.trace",
45
+ # Custom client Linux/MacOS
46
+ ".anydesk_ad_*/*.trace",
47
+ ]
48
+
49
+ RemoteAccessLogRecord = create_extended_descriptor([UserRecordDescriptorExtension])(
50
+ "remoteaccess/anydesk/log", GENERIC_LOG_RECORD_FIELDS
51
+ )
52
+
53
+ def __init__(self, target):
54
+ super().__init__(target)
55
+
56
+ self.trace_files: set[tuple[TargetPath, UserDetails]] = set()
57
+
58
+ # Service globs
59
+ user = None
60
+ for trace_glob in self.SERVICE_GLOBS:
61
+ for trace_file in self.target.fs.path().glob(trace_glob):
62
+ self.trace_files.add((trace_file, user))
63
+
64
+ # User globs
65
+ for user_details in self.target.user_details.all_with_home():
66
+ for trace_glob in self.USER_GLOBS:
67
+ for trace_file in user_details.home_path.glob(trace_glob):
68
+ self.trace_files.add((trace_file, user_details.user))
69
+
70
+ def check_compatible(self) -> None:
71
+ if not self.trace_files:
72
+ raise UnsupportedPluginError("No Anydesk trace files found on target")
73
+
74
+ @export(record=RemoteAccessLogRecord)
75
+ def logs(self) -> Iterator[RemoteAccessLogRecord]:
76
+ """Parse AnyDesk trace files.
77
+
78
+ AnyDesk is a remote desktop application and can be used by adversaries to get (persistent) access to a machine.
79
+ Log files (.trace files) can be stored on various locations, based on target OS and client type.
80
+ Timestamps in trace files do not carry a time zone designator (TZD) but are in fact UTC.
81
+
82
+ References:
83
+ - https://www.inversecos.com/2021/02/forensic-analysis-of-anydesk-logs.html
84
+ - https://support.anydesk.com/knowledge/trace-files#trace-file-locations
85
+ """
86
+ for trace_file, user in self.trace_files:
87
+ for line in trace_file.open("rt", errors="backslashreplace"):
88
+ line = line.strip()
89
+
90
+ if not line or "* * * * * * * * * * * * * *" in line:
91
+ continue
92
+
93
+ try:
94
+ level, ts_date, ts_time, message = line.split(" ", 3)
95
+
96
+ timestamp = datetime.strptime(f"{ts_date} {ts_time}", "%Y-%m-%d %H:%M:%S.%f").replace(
97
+ tzinfo=timezone.utc
98
+ )
99
+ message = re.sub(r"\s\s+", " ", f"{level} {message}")
100
+
101
+ yield self.RemoteAccessLogRecord(
102
+ ts=timestamp,
103
+ message=message,
104
+ source=trace_file,
105
+ _target=self.target,
106
+ _user=user,
107
+ )
108
+
109
+ except ValueError as e:
110
+ self.target.log.warning("Could not parse log line in file %s: '%s'", trace_file, line)
111
+ self.target.log.debug("", exc_info=e)
@@ -2,14 +2,14 @@ from dissect.target.helpers.descriptor_extensions import UserRecordDescriptorExt
2
2
  from dissect.target.helpers.record import create_extended_descriptor
3
3
  from dissect.target.plugin import NamespacePlugin
4
4
 
5
- RemoteAccessRecord = create_extended_descriptor([UserRecordDescriptorExtension])(
6
- "application/log/remoteaccess",
7
- [
8
- ("datetime", "ts"),
9
- ("string", "tool"),
10
- ("path", "logfile"),
11
- ("string", "description"),
12
- ],
5
+ GENERIC_LOG_RECORD_FIELDS = [
6
+ ("datetime", "ts"),
7
+ ("string", "message"),
8
+ ("path", "source"),
9
+ ]
10
+
11
+ RemoteAccessLogRecord = create_extended_descriptor([UserRecordDescriptorExtension])(
12
+ "remoteaccess/log", GENERIC_LOG_RECORD_FIELDS
13
13
  )
14
14
 
15
15
 
@@ -1,60 +1,72 @@
1
1
  import re
2
- from datetime import datetime
2
+ from datetime import datetime, timezone
3
+ from typing import Iterator
3
4
 
4
5
  from dissect.target.exceptions import UnsupportedPluginError
6
+ from dissect.target.helpers.descriptor_extensions import UserRecordDescriptorExtension
7
+ from dissect.target.helpers.fsutil import TargetPath
8
+ from dissect.target.helpers.record import create_extended_descriptor
5
9
  from dissect.target.plugin import export
6
10
  from dissect.target.plugins.apps.remoteaccess.remoteaccess import (
11
+ GENERIC_LOG_RECORD_FIELDS,
7
12
  RemoteAccessPlugin,
8
- RemoteAccessRecord,
9
13
  )
14
+ from dissect.target.plugins.general.users import UserDetails
10
15
 
11
16
  START_PATTERN = re.compile(r"^(\d{2}|\d{4})/")
12
17
 
13
18
 
14
- class TeamviewerPlugin(RemoteAccessPlugin):
15
- """
16
- Teamviewer plugin.
19
+ class TeamViewerPlugin(RemoteAccessPlugin):
20
+ """TeamViewer client plugin.
21
+
22
+ Resources:
23
+ - https://teamviewer.com/en/global/support/knowledge-base/teamviewer-classic/contact-support/find-your-log-files
24
+ - https://www.systoolsgroup.com/forensics/teamviewer/
25
+ - https://benleeyr.wordpress.com/2020/05/19/teamviewer-forensics-tested-on-v15/
17
26
  """
18
27
 
19
28
  __namespace__ = "teamviewer"
20
29
 
21
- # Teamviewer log when service (Windows)
22
- GLOBS = [
30
+ SYSTEM_GLOBS = [
23
31
  "sysvol/Program Files/TeamViewer/*.log",
24
32
  "sysvol/Program Files (x86)/TeamViewer/*.log",
25
33
  ]
26
34
 
35
+ USER_GLOBS = [
36
+ "AppData/Roaming/TeamViewer/teamviewer*_logfile.log",
37
+ ]
38
+
39
+ RemoteAccessLogRecord = create_extended_descriptor([UserRecordDescriptorExtension])(
40
+ "remoteaccess/teamviewer/log", GENERIC_LOG_RECORD_FIELDS
41
+ )
42
+
27
43
  def __init__(self, target):
28
44
  super().__init__(target)
29
45
 
30
- self.logfiles = []
46
+ self.logfiles: list[list[TargetPath, UserDetails]] = []
31
47
 
32
- # Check service globs
33
- user = None
34
- for log_glob in self.GLOBS:
48
+ # Find system service log files.
49
+ for log_glob in self.SYSTEM_GLOBS:
35
50
  for logfile in self.target.fs.glob(log_glob):
36
- self.logfiles.append([logfile, user])
51
+ self.logfiles.append([logfile, None])
37
52
 
38
- # Teamviewer logs when as user (Windows)
53
+ # Find user log files.
39
54
  for user_details in self.target.user_details.all_with_home():
40
- for logfile in user_details.home_path.glob("appdata/roaming/teamviewer/teamviewer*_logfile.log"):
41
- self.logfiles.append([logfile, user_details.user])
55
+ for log_glob in self.USER_GLOBS:
56
+ for logfile in user_details.home_path.glob(log_glob):
57
+ self.logfiles.append([logfile, user_details])
42
58
 
43
59
  def check_compatible(self) -> None:
44
60
  if not len(self.logfiles):
45
61
  raise UnsupportedPluginError("No Teamviewer logs found")
46
62
 
47
- @export(record=RemoteAccessRecord)
48
- def logs(self):
49
- """Return the content of the TeamViewer logs.
50
-
51
- TeamViewer is a commercial remote desktop application. An adversary may use it to gain persistence on a
52
- system.
63
+ @export(record=RemoteAccessLogRecord)
64
+ def logs(self) -> Iterator[RemoteAccessLogRecord]:
65
+ """Yield TeamViewer client logs.
53
66
 
54
- References:
55
- - https://www.teamviewer.com/nl/
67
+ TeamViewer is a commercial remote desktop application. An adversary may use it to gain persistence on a system.
56
68
  """
57
- for logfile, user in self.logfiles:
69
+ for logfile, user_details in self.logfiles:
58
70
  logfile = self.target.fs.path(logfile)
59
71
 
60
72
  start_date = None
@@ -83,7 +95,7 @@ class TeamviewerPlugin(RemoteAccessPlugin):
83
95
  if not re.match(START_PATTERN, line):
84
96
  continue
85
97
 
86
- ts_day, ts_time, description = line.split(" ", 2)
98
+ ts_day, ts_time, message = line.split(" ", 2)
87
99
  ts_time = ts_time.split(".")[0]
88
100
 
89
101
  # Correct for use of : as millisecond separator
@@ -99,13 +111,14 @@ class TeamviewerPlugin(RemoteAccessPlugin):
99
111
  if ts_day.count("/") == 2 and len(ts_day.split("/")[0]) == 2:
100
112
  ts_day = "20" + ts_day
101
113
 
102
- timestamp = datetime.strptime(f"{ts_day} {ts_time}", "%Y/%m/%d %H:%M:%S")
114
+ timestamp = datetime.strptime(f"{ts_day} {ts_time}", "%Y/%m/%d %H:%M:%S").replace(
115
+ tzinfo=timezone.utc
116
+ )
103
117
 
104
- yield RemoteAccessRecord(
105
- tool="teamviewer",
118
+ yield self.RemoteAccessLogRecord(
106
119
  ts=timestamp,
107
- logfile=str(logfile),
108
- description=description,
120
+ message=message,
121
+ source=logfile,
109
122
  _target=self.target,
110
- _user=user,
123
+ _user=user_details.user if user_details else None,
111
124
  )
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: dissect.target
3
- Version: 3.19.dev13
3
+ Version: 3.19.dev14
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
@@ -0,0 +1,84 @@
1
+ import operator
2
+ import uuid
3
+ from datetime import datetime, timezone
4
+
5
+ from dissect.target.filesystem import VirtualFilesystem
6
+ from dissect.target.plugins.apps.remoteaccess.anydesk import AnydeskPlugin
7
+ from dissect.target.target import Target
8
+ from tests._utils import absolute_path
9
+
10
+
11
+ def test_anydesk_plugin_log(target_win_users: Target, fs_win: VirtualFilesystem) -> None:
12
+ fs_win.map_file(
13
+ "ProgramData/AnyDesk/TestAnydesk.trace",
14
+ absolute_path("_data/plugins/apps/remoteaccess/anydesk/TestAnydesk.trace"),
15
+ )
16
+
17
+ target_win_users.add_plugin(AnydeskPlugin)
18
+
19
+ records = list(target_win_users.anydesk.logs())
20
+ assert len(records) == 1
21
+
22
+ assert records[0].ts == datetime(2021, 11, 11, 12, 34, 56, 789000, tzinfo=timezone.utc)
23
+ assert records[0].message == "LEVEL Strip the headers, trace the source!"
24
+ assert records[0].source == "sysvol/ProgramData/AnyDesk/TestAnydesk.trace"
25
+ assert records[0].username is None
26
+ assert records[0].user_id is None
27
+ assert records[0].user_home is None
28
+
29
+
30
+ def test_anydesk_plugin_user_log(target_win_users: Target, fs_win: VirtualFilesystem) -> None:
31
+ fs_win.map_file(
32
+ "Users/John/AppData/Roaming/AnyDesk/TestAnydesk.trace",
33
+ absolute_path("_data/plugins/apps/remoteaccess/anydesk/TestAnydesk.trace"),
34
+ )
35
+
36
+ target_win_users.add_plugin(AnydeskPlugin)
37
+
38
+ records = list(target_win_users.anydesk.logs())
39
+ records.sort(key=operator.attrgetter("source"))
40
+ assert len(records) == 1
41
+
42
+ user_details = target_win_users.user_details.find(username="John")
43
+ assert records[0].ts == datetime(2021, 11, 11, 12, 34, 56, 789000, tzinfo=timezone.utc)
44
+ assert records[0].message == "LEVEL Strip the headers, trace the source!"
45
+ assert records[0].source == "C:/Users/John/AppData/Roaming/AnyDesk/TestAnydesk.trace"
46
+ assert records[0].username == user_details.user.name
47
+ assert records[0].user_id == user_details.user.sid
48
+ assert records[0].user_home == user_details.user.home
49
+
50
+
51
+ def test_anydesk_plugin_multiple_trace_files(target_win_users: Target, fs_win: VirtualFilesystem) -> None:
52
+ trace_file = absolute_path("_data/plugins/apps/remoteaccess/anydesk/Another.trace")
53
+ trace_files = 0
54
+
55
+ for str_path in AnydeskPlugin.SERVICE_GLOBS:
56
+ if "var/log/" in str_path:
57
+ continue
58
+ fs_win.map_file(str_path.replace("sysvol/", "").replace("*", uuid.uuid4().hex[:6]), trace_file)
59
+ trace_files += 1
60
+
61
+ for str_path in AnydeskPlugin.USER_GLOBS:
62
+ if str_path.startswith(".anydesk"):
63
+ continue
64
+ fs_win.map_file("Users\\John\\" + str_path.replace("*", uuid.uuid4().hex[:6]), trace_file)
65
+ trace_files += 1
66
+
67
+ target_win_users.add_plugin(AnydeskPlugin)
68
+ records = list(target_win_users.anydesk.logs())
69
+
70
+ assert len(target_win_users.anydesk.trace_files) == trace_files
71
+ assert len(records) == trace_files * 419
72
+
73
+
74
+ def test_anydesk_unix(target_unix_users: Target, fs_unix: VirtualFilesystem) -> None:
75
+ trace_file = absolute_path("_data/plugins/apps/remoteaccess/anydesk/Another.trace")
76
+ fs_unix.map_file("/var/log/anydesk/1337.trace", trace_file)
77
+ fs_unix.map_file("/root/.anydesk/1337.trace", trace_file)
78
+ fs_unix.map_file("/root/.anydesk_ad_1337/1337.trace", trace_file)
79
+
80
+ target_unix_users.add_plugin(AnydeskPlugin)
81
+ records = list(target_unix_users.anydesk.logs())
82
+
83
+ assert len(target_unix_users.anydesk.trace_files) == 3
84
+ assert len(records) == 3 * 419
@@ -1,6 +1,6 @@
1
1
  from datetime import datetime, timezone
2
2
 
3
- from dissect.target.plugins.apps.remoteaccess.teamviewer import TeamviewerPlugin
3
+ from dissect.target.plugins.apps.remoteaccess.teamviewer import TeamViewerPlugin
4
4
  from tests._utils import absolute_path
5
5
 
6
6
 
@@ -11,15 +11,15 @@ def test_teamviewer_plugin_global_log(target_win_users, fs_win):
11
11
  _, _, map_path = target_logfile_name.partition("sysvol/")
12
12
  fs_win.map_file(map_path, teamviewer_logfile)
13
13
 
14
- tvp = TeamviewerPlugin(target_win_users)
14
+ tvp = TeamViewerPlugin(target_win_users)
15
15
 
16
16
  records = list(tvp.logs())
17
17
  assert len(records) == 4
18
18
 
19
19
  record = records[0]
20
20
  assert record.ts == datetime(2021, 11, 11, 12, 34, 56, tzinfo=timezone.utc)
21
- assert record.description == "Strip the headers, trace the source!"
22
- assert record.logfile == target_logfile_name
21
+ assert record.message == "Strip the headers, trace the source!"
22
+ assert record.source == target_logfile_name
23
23
  assert record.username is None
24
24
  assert record.user_id is None
25
25
  assert record.user_home is None
@@ -33,15 +33,15 @@ def test_teamviewer_plugin_user_log(target_win_users, fs_win):
33
33
  _, _, map_path = target_logfile_name.partition("C:/")
34
34
  fs_win.map_file(map_path, teamviewer_logfile)
35
35
 
36
- tvp = TeamviewerPlugin(target_win_users)
36
+ tvp = TeamViewerPlugin(target_win_users)
37
37
 
38
38
  records = list(tvp.logs())
39
39
  assert len(records) == 4
40
40
 
41
41
  record = records[0]
42
42
  assert record.ts == datetime(2021, 11, 11, 12, 34, 56, tzinfo=timezone.utc)
43
- assert record.description == "Strip the headers, trace the source!"
44
- assert record.logfile == target_logfile_name
43
+ assert record.message == "Strip the headers, trace the source!"
44
+ assert record.source == target_logfile_name
45
45
  assert record.username == user_details.user.name
46
46
  assert record.user_id == user_details.user.sid
47
47
  assert record.user_home == user_details.user.home
@@ -55,19 +55,19 @@ def test_teamviewer_plugin_special_date_parsing(target_win_users, fs_win):
55
55
  _, _, map_path = target_logfile_name.partition("C:/")
56
56
  fs_win.map_file(map_path, teamviewer_logfile)
57
57
 
58
- tvp = TeamviewerPlugin(target_win_users)
58
+ tvp = TeamViewerPlugin(target_win_users)
59
59
 
60
60
  records = list(tvp.logs())
61
61
  assert len(records) == 4
62
62
 
63
63
  record_2 = records[1]
64
64
  assert record_2.ts == datetime(2021, 11, 11, 12, 35, 55, tzinfo=timezone.utc)
65
- assert record_2.description == "Should be year 2021"
65
+ assert record_2.message == "Should be year 2021"
66
66
 
67
67
  record_3 = records[2]
68
68
  assert record_3.ts == datetime(2021, 11, 11, 12, 36, 11, tzinfo=timezone.utc)
69
- assert record_3.description == "Should discard the milliseconds properly"
69
+ assert record_3.message == "Should discard the milliseconds properly"
70
70
 
71
71
  record_4 = records[3]
72
72
  assert record_4.ts == datetime(2021, 11, 11, 12, 37, 00, tzinfo=timezone.utc)
73
- assert record_4.description == "Should be year 2021"
73
+ assert record_4.message == "Should be year 2021"
@@ -1,91 +0,0 @@
1
- from datetime import datetime
2
-
3
- from dissect.target.exceptions import UnsupportedPluginError
4
- from dissect.target.plugin import export
5
- from dissect.target.plugins.apps.remoteaccess.remoteaccess import (
6
- RemoteAccessPlugin,
7
- RemoteAccessRecord,
8
- )
9
-
10
-
11
- class AnydeskPlugin(RemoteAccessPlugin):
12
- """
13
- Anydesk plugin.
14
- """
15
-
16
- __namespace__ = "anydesk"
17
-
18
- # Anydesk logs when installed as a service
19
- SERVICE_GLOBS = [
20
- "/sysvol/ProgramData/AnyDesk/*.trace", # Standard client >= Windows 7
21
- "/sysvol/ProgramData/AnyDesk/ad_*/*.trace", # Custom client >= Windows 7
22
- "/var/log/anydesk*.trace", # Standard/Custom client Linux/MacOS
23
- ]
24
-
25
- # User specific Anydesk logs
26
- USER_GLOBS = [
27
- "appdata/roaming/AnyDesk/*.trace", # Standard client Windows
28
- "appdata/roaming/AnyDesk/ad_*/*.trace", # Custom client Windows
29
- ".anydesk/*.trace", # Standard client Linux/MacOS
30
- ".anydesk_ad_*/*.trace", # Custom client Linux/MacOS
31
- ]
32
-
33
- def __init__(self, target):
34
- super().__init__(target)
35
-
36
- self.logfiles = []
37
-
38
- # Check service globs
39
- user = None
40
- for log_glob in self.SERVICE_GLOBS:
41
- for logfile in self.target.fs.glob(log_glob):
42
- self.logfiles.append([logfile, user])
43
-
44
- # Anydesk logs when as user
45
- for user_details in self.target.user_details.all_with_home():
46
- for log_glob in self.USER_GLOBS:
47
- for logfile in user_details.home_path.glob(log_glob):
48
- self.logfiles.append([logfile, user_details.user])
49
-
50
- def check_compatible(self) -> None:
51
- if not (len(self.logfiles)):
52
- raise UnsupportedPluginError("No Anydesk logs found")
53
-
54
- @export(record=RemoteAccessRecord)
55
- def logs(self):
56
- """Return the content of the AnyDesk logs.
57
-
58
- AnyDesk is a remote desktop application and can be used by adversaries to get (persistent) access to a machine.
59
- Log files (.trace files) are retrieved from various location based on OS and client type.
60
-
61
- References:
62
- - https://www.inversecos.com/2021/02/forensic-analysis-of-anydesk-logs.html
63
- - https://support.anydesk.com/knowledge/trace-files#trace-file-locations
64
- """
65
- for logfile, user in self.logfiles:
66
- logfile = self.target.fs.path(logfile)
67
-
68
- for line in logfile.open("rt"):
69
- line = line.strip()
70
-
71
- # Skip empty lines
72
- if not line:
73
- continue
74
-
75
- if "* * * * * * * * * * * * * *" in line:
76
- continue
77
-
78
- level, ts_day, ts_time, description = line.split(" ", 3)
79
- description = f"{level} {description}"
80
- ts_time = ts_time.split(".")[0]
81
-
82
- timestamp = datetime.strptime(f"{ts_day} {ts_time}", "%Y-%m-%d %H:%M:%S")
83
-
84
- yield RemoteAccessRecord(
85
- ts=timestamp,
86
- tool="anydesk",
87
- logfile=str(logfile),
88
- description=description,
89
- _target=self.target,
90
- _user=user,
91
- )
@@ -1,47 +0,0 @@
1
- from datetime import datetime, timezone
2
-
3
- from dissect.target.plugins.apps.remoteaccess.anydesk import AnydeskPlugin
4
- from tests._utils import absolute_path
5
-
6
-
7
- def test_anydesk_plugin_global_log(target_win_users, fs_win):
8
- anydesk_logfile = absolute_path("_data/plugins/apps/remoteaccess/anydesk/TestAnydesk.trace")
9
- target_logfile_name = "/sysvol/ProgramData/AnyDesk/TestAnydesk.trace"
10
-
11
- _, _, map_path = target_logfile_name.partition("sysvol/")
12
- fs_win.map_file(map_path, anydesk_logfile)
13
-
14
- adp = AnydeskPlugin(target_win_users)
15
-
16
- records = list(adp.logs())
17
- assert len(records) == 1
18
-
19
- record = records[0]
20
- assert record.ts == datetime(2021, 11, 11, 12, 34, 56, tzinfo=timezone.utc)
21
- assert record.description == "LEVEL Strip the headers, trace the source!"
22
- assert record.logfile == target_logfile_name
23
- assert record.username is None
24
- assert record.user_id is None
25
- assert record.user_home is None
26
-
27
-
28
- def test_anydesk_plugin_user_log(target_win_users, fs_win):
29
- anydesk_logfile = absolute_path("_data/plugins/apps/remoteaccess/anydesk/TestAnydesk.trace")
30
- user_details = target_win_users.user_details.find(username="John")
31
- target_logfile_name = f"{user_details.home_path}/appdata/roaming/AnyDesk/TestAnydesk.trace"
32
-
33
- _, _, map_path = target_logfile_name.partition("C:/")
34
- fs_win.map_file(map_path, anydesk_logfile)
35
-
36
- adp = AnydeskPlugin(target_win_users)
37
-
38
- records = list(adp.logs())
39
- assert len(records) == 1
40
-
41
- record = records[0]
42
- assert record.ts == datetime(2021, 11, 11, 12, 34, 56, tzinfo=timezone.utc)
43
- assert record.description == "LEVEL Strip the headers, trace the source!"
44
- assert record.logfile == target_logfile_name
45
- assert record.username == user_details.user.name
46
- assert record.user_id == user_details.user.sid
47
- assert record.user_home == user_details.user.home