dissect.target 3.19.dev13__tar.gz → 3.19.dev15__tar.gz
Sign up to get free protection for your applications and to get access to all the features.
- {dissect_target-3.19.dev13/dissect.target.egg-info → dissect_target-3.19.dev15}/PKG-INFO +1 -1
- dissect_target-3.19.dev15/dissect/target/plugins/apps/remoteaccess/anydesk.py +111 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/remoteaccess/remoteaccess.py +8 -8
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/remoteaccess/teamviewer.py +44 -31
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/_os.py +4 -4
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15/dissect.target.egg-info}/PKG-INFO +1 -1
- dissect_target-3.19.dev15/tests/plugins/apps/remoteaccess/test_anydesk.py +84 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/remoteaccess/test_teamviewer.py +11 -11
- dissect_target-3.19.dev13/dissect/target/plugins/apps/remoteaccess/anydesk.py +0 -91
- dissect_target-3.19.dev13/tests/plugins/apps/remoteaccess/test_anydesk.py +0 -47
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/COPYRIGHT +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/LICENSE +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/MANIFEST.in +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/README.md +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/container.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/containers/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/containers/asdf.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/containers/ewf.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/containers/fortifw.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/containers/hdd.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/containers/hds.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/containers/qcow2.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/containers/raw.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/containers/split.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/containers/vdi.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/containers/vhd.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/containers/vhdx.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/containers/vmdk.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/data/autocompletion/target_bash_completion.sh +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/exceptions.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/filesystem.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/filesystems/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/filesystems/ad1.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/filesystems/btrfs.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/filesystems/cb.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/filesystems/config.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/filesystems/cpio.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/filesystems/dir.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/filesystems/exfat.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/filesystems/extfs.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/filesystems/fat.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/filesystems/ffs.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/filesystems/itunes.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/filesystems/jffs.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/filesystems/ntfs.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/filesystems/overlay.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/filesystems/smb.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/filesystems/squashfs.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/filesystems/tar.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/filesystems/vmfs.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/filesystems/vmtar.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/filesystems/xfs.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/filesystems/zip.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/cache.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/compat/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/compat/path_310.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/compat/path_311.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/compat/path_312.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/compat/path_39.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/compat/path_common.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/config.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/configutil.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/cyber.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/data/windowsZones.xml +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/descriptor_extensions.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/docs.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/fsutil.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/hashutil.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/keychain.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/lazy.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/loaderutil.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/localeutil.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/mount.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/mui.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/network_managers.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/polypath.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/protobuf.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/record.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/record_modifier.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/regutil.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/shell_folder_ids.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/targetd.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/helpers/utils.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loader.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/ad1.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/asdf.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/cb.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/cyber.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/dir.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/hyperv.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/itunes.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/kape.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/local.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/log.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/mqtt.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/multiraw.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/ova.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/overlay.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/ovf.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/phobos.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/profile.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/pvm.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/pvs.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/raw.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/remote.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/res.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/smb.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/tanium.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/tar.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/target.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/targetd.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/utm.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/vb.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/vbox.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/velociraptor.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/vma.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/vmwarevm.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/vmx.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/loaders/xva.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugin.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/av/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/av/mcafee.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/av/sophos.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/av/symantec.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/av/trendmicro.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/browser/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/browser/brave.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/browser/browser.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/browser/chrome.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/browser/chromium.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/browser/edge.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/browser/firefox.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/browser/iexplore.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/container/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/container/docker.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/remoteaccess/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/shell/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/shell/powershell.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/ssh/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/ssh/openssh.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/ssh/opensshd.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/ssh/putty.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/ssh/ssh.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/vpn/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/vpn/openvpn.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/vpn/wireguard.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/webhosting/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/webhosting/cpanel.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/webserver/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/webserver/apache.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/webserver/caddy.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/webserver/citrix.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/webserver/iis.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/webserver/nginx.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/apps/webserver/webserver.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/child/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/child/docker.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/child/esxi.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/child/hyperv.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/child/virtuozzo.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/child/vmware_workstation.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/child/wsl.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/filesystem/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/filesystem/acquire_handles.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/filesystem/acquire_hash.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/filesystem/icat.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/filesystem/ntfs/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/filesystem/ntfs/mft.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/filesystem/ntfs/mft_timeline.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/filesystem/ntfs/usnjrnl.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/filesystem/ntfs/utils.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/filesystem/resolver.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/filesystem/unix/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/filesystem/unix/capability.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/filesystem/unix/suid.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/filesystem/walkfs.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/filesystem/yara.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/general/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/general/config.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/general/default.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/general/example.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/general/loaders.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/general/osinfo.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/general/plugins.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/general/scrape.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/general/users.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/_os.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/bsd/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/bsd/_os.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/bsd/citrix/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/bsd/citrix/_os.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/bsd/citrix/history.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/bsd/freebsd/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/bsd/freebsd/_os.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/bsd/ios/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/bsd/ios/_os.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/bsd/openbsd/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/bsd/openbsd/_os.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/bsd/osx/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/bsd/osx/_os.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/bsd/osx/user.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/cronjobs.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/datetime.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/esxi/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/esxi/_os.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/etc/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/etc/etc.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/etc.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/generic.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/history.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/_os.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/android/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/android/_os.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/cmdline.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/debian/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/debian/_os.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/debian/apt.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/debian/dpkg.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/debian/vyos/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/debian/vyos/_os.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/environ.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/fortios/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/fortios/_keys.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/fortios/_os.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/fortios/generic.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/fortios/locale.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/iptables.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/modules.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/netstat.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/proc.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/processes.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/redhat/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/redhat/_os.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/redhat/yum.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/services.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/sockets.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/suse/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/suse/_os.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/linux/suse/zypper.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/locale.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/locate/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/locate/gnulocate.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/locate/locate.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/locate/mlocate.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/locate/plocate.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/log/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/log/atop.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/log/audit.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/log/auth.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/log/journal.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/log/lastlog.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/log/messages.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/log/utmp.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/packagemanager.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/unix/shadow.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/activitiescache.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/adpolicy.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/amcache.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/catroot.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/cim.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/clfs.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/credhist.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/datetime.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/defender.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/defender_helpers/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/defender_helpers/defender_patterns.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/defender_helpers/defender_records.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/dpapi/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/dpapi/blob.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/dpapi/crypto.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/dpapi/dpapi.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/dpapi/master_key.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/env.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/exchange/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/exchange/exchange.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/generic.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/lnk.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/locale.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/log/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/log/amcache.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/log/etl.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/log/evt.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/log/evtx.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/log/pfro.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/log/schedlgu.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/notifications.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/prefetch.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/recyclebin.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/regf/7zip.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/regf/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/regf/appxdebugkeys.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/regf/auditpol.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/regf/bam.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/regf/cit.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/regf/clsid.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/regf/firewall.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/regf/mru.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/regf/muicache.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/regf/nethist.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/regf/recentfilecache.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/regf/regf.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/regf/runkeys.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/regf/shellbags.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/regf/shimcache.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/regf/trusteddocs.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/regf/usb.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/regf/userassist.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/registry.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/sam.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/services.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/sru.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/startupinfo.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/syscache.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/task_helpers/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/task_helpers/tasks_job.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/task_helpers/tasks_records.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/task_helpers/tasks_xml.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/tasks.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/thumbcache.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/ual.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/wer.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/report.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/target.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/tools/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/tools/build_pluginlist.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/tools/dd.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/tools/dump/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/tools/dump/run.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/tools/dump/state.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/tools/dump/utils.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/tools/fs.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/tools/info.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/tools/logging.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/tools/mount.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/tools/query.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/tools/reg.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/tools/shell.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/tools/utils.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/volume.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/volumes/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/volumes/bde.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/volumes/ddf.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/volumes/disk.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/volumes/luks.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/volumes/lvm.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/volumes/md.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/volumes/vmfs.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect.target.egg-info/SOURCES.txt +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect.target.egg-info/dependency_links.txt +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect.target.egg-info/entry_points.txt +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect.target.egg-info/requires.txt +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect.target.egg-info/top_level.txt +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/pyproject.toml +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/setup.cfg +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/_docs/Makefile +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/_docs/conf.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/_docs/index.rst +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/_utils.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/conftest.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/containers/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/containers/test_fortifw.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/containers/test_split.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/filesystems/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/filesystems/test_cb.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/filesystems/test_config.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/filesystems/test_cpio.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/filesystems/test_dir.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/filesystems/test_exfat.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/filesystems/test_fat.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/filesystems/test_ntfs.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/filesystems/test_overlay.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/filesystems/test_smb.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/filesystems/test_tar.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/filesystems/test_vmtar.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/filesystems/test_zip.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/helpers/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/helpers/test_cache.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/helpers/test_config.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/helpers/test_configutil.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/helpers/test_docs.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/helpers/test_fsutil.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/helpers/test_hashutil.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/helpers/test_keychain.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/helpers/test_loaderutil.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/helpers/test_localeutil.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/helpers/test_modifier.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/helpers/test_protobuf.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/helpers/test_record.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/helpers/test_regutil.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/helpers/test_utils.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/loaders/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/loaders/test_asdf.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/loaders/test_cb.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/loaders/test_dir.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/loaders/test_hyperv.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/loaders/test_kape.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/loaders/test_local.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/loaders/test_log.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/loaders/test_mqtt.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/loaders/test_multiraw.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/loaders/test_ova.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/loaders/test_overlay.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/loaders/test_ovf.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/loaders/test_phobos.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/loaders/test_pvm.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/loaders/test_pvs.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/loaders/test_remote.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/loaders/test_smb.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/loaders/test_tanium.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/loaders/test_tar.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/loaders/test_utm.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/loaders/test_vbox.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/loaders/test_velociraptor.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/loaders/test_vmwarevm.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/av/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/av/test_mcafee.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/av/test_sophos.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/av/test_symantec.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/av/test_trendmicro.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/browser/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/browser/test_brave.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/browser/test_chrome.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/browser/test_chromium.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/browser/test_edge.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/browser/test_firefox.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/browser/test_iexplore.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/container/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/container/test_docker.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/remoteaccess/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/shell/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/shell/test_powershell.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/ssh/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/ssh/test_openssh.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/ssh/test_opensshd.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/ssh/test_putty.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/vpn/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/vpn/test_openvpn.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/vpn/test_wireguard.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/webhosting/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/webhosting/test_cpanel.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/webserver/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/webserver/test_apache.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/webserver/test_caddy.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/webserver/test_citrix.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/webserver/test_iis.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/webserver/test_nginx.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/apps/webserver/test_webserver.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/child/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/child/test_docker.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/child/test_hyperv.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/child/test_virtuozzo.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/child/test_wsl.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/filesystem/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/filesystem/ntfs/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/filesystem/ntfs/test_mft.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/filesystem/ntfs/test_usnjrnl.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/filesystem/test_acquire_handles.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/filesystem/test_acquire_hash.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/filesystem/test_icat.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/filesystem/test_resolver.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/filesystem/test_walkfs.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/filesystem/test_yara.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/filesystem/unix/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/filesystem/unix/test_capability.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/filesystem/unix/test_suid.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/general/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/general/test_config.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/general/test_default.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/general/test_plugins.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/general/test_scrape.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/general/test_users.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/bsd/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/bsd/citrix/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/bsd/citrix/test__os.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/bsd/citrix/test_history.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/bsd/osx/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/bsd/osx/test__os.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/bsd/osx/test_user.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/esxi/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/esxi/test__os.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/linux/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/linux/android/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/linux/android/test__os.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/linux/debian/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/linux/debian/test_apt.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/linux/debian/test_dpkg.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/linux/fortios/test_keys.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/linux/redhat/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/linux/redhat/test_yum.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/linux/suse/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/linux/suse/test_zypper.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/linux/test_cmdline.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/linux/test_environ.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/linux/test_iptables.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/linux/test_modules.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/linux/test_netstat.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/linux/test_proc.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/linux/test_processes.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/linux/test_services.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/linux/test_sockets.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/locate/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/locate/test_gnulocate.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/locate/test_mlocate.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/locate/test_plocate.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/log/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/log/test_atop.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/log/test_audit.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/log/test_auth.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/log/test_lastlog.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/log/test_messages.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/log/test_utmp.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/test__os.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/test_generic.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/test_history.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/test_ips.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/test_journal.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/test_locale.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/test_packagemanager.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/test_shadow.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/test_users.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/unix/test_version.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/log/test_etl.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/log/test_evt.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/log/test_evtx.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/log/test_schedlgu.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/regf/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/regf/test_appxdebugkeys.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/regf/test_cit.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/regf/test_clsid.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/regf/test_muicache.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/regf/test_shellbags.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/regf/test_trusteddocs.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/regf/test_userassist.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/test__os.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/test_adpolicy.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/test_amcache.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/test_catroot.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/test_clfs.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/test_credhist.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/test_datetime.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/test_defender.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/test_dpapi.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/test_env.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/test_generic.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/test_lnk.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/test_locale.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/test_mru.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/test_notifications.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/test_prefetch.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/test_recyclebin.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/test_registry.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/test_sam.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/test_shimcache.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/test_sru.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/test_syscache.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/test_tasks.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/test_thumbcache.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/test_ual.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/plugins/os/windows/test_wer.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/test_container.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/test_filesystem.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/test_plugin.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/test_registration.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/test_report.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/test_target.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/test_volume.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/tools/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/tools/test_dump.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/tools/test_fs.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/tools/test_mount.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/tools/test_query.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/tools/test_reg.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/tools/test_shell.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/tools/test_utils.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/volumes/__init__.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/volumes/test_bde.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tests/volumes/test_md.py +0 -0
- {dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/tox.ini +0 -0
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.1
|
2
2
|
Name: dissect.target
|
3
|
-
Version: 3.19.
|
3
|
+
Version: 3.19.dev15
|
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
|
-
|
6
|
-
"
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
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
|
15
|
-
"""
|
16
|
-
|
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
|
-
|
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
|
-
#
|
33
|
-
|
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,
|
51
|
+
self.logfiles.append([logfile, None])
|
37
52
|
|
38
|
-
#
|
53
|
+
# Find user log files.
|
39
54
|
for user_details in self.target.user_details.all_with_home():
|
40
|
-
for
|
41
|
-
|
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=
|
48
|
-
def logs(self):
|
49
|
-
"""
|
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
|
-
|
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,
|
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,
|
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
|
105
|
-
tool="teamviewer",
|
118
|
+
yield self.RemoteAccessLogRecord(
|
106
119
|
ts=timestamp,
|
107
|
-
|
108
|
-
|
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
|
)
|
{dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/plugins/os/windows/_os.py
RENAMED
@@ -79,15 +79,15 @@ class WindowsPlugin(OSPlugin):
|
|
79
79
|
self.target.log.debug("", exc_info=e)
|
80
80
|
|
81
81
|
sysvol_drive = self.target.fs.mounts.get("sysvol")
|
82
|
-
|
83
|
-
|
82
|
+
if not sysvol_drive:
|
83
|
+
self.target.log.warning("No sysvol drive found")
|
84
|
+
elif operator.countOf(self.target.fs.mounts.values(), sysvol_drive) == 1:
|
85
|
+
# Fallback mount the sysvol to C: if we didn't manage to mount it to any other drive letter
|
84
86
|
if "c:" not in self.target.fs.mounts:
|
85
87
|
self.target.log.debug("Unable to determine drive letter of sysvol, falling back to C:")
|
86
88
|
self.target.fs.mount("c:", sysvol_drive)
|
87
89
|
else:
|
88
90
|
self.target.log.warning("Unknown drive letter for sysvol")
|
89
|
-
else:
|
90
|
-
self.target.log.warning("No sysvol drive found")
|
91
91
|
|
92
92
|
@export(property=True)
|
93
93
|
def hostname(self) -> Optional[str]:
|
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.1
|
2
2
|
Name: dissect.target
|
3
|
-
Version: 3.19.
|
3
|
+
Version: 3.19.dev15
|
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
|
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 =
|
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.
|
22
|
-
assert record.
|
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 =
|
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.
|
44
|
-
assert record.
|
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 =
|
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.
|
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.
|
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.
|
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
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/containers/__init__.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
{dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/containers/fortifw.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{dissect_target-3.19.dev13 → dissect_target-3.19.dev15}/dissect/target/filesystems/__init__.py
RENAMED
File without changes
|
File without changes
|
File without changes
|