dissect.target 3.20.dev45__tar.gz → 3.20.dev47__tar.gz
Sign up to get free protection for your applications and to get access to all the features.
- {dissect_target-3.20.dev45/dissect.target.egg-info → dissect_target-3.20.dev47}/PKG-INFO +1 -1
- dissect_target-3.20.dev47/dissect/target/plugins/os/unix/log/auth.py +373 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47/dissect.target.egg-info}/PKG-INFO +1 -1
- dissect_target-3.20.dev47/tests/plugins/os/unix/log/test_auth.py +313 -0
- dissect_target-3.20.dev45/dissect/target/plugins/os/unix/log/auth.py +0 -62
- dissect_target-3.20.dev45/tests/plugins/os/unix/log/test_auth.py +0 -102
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/COPYRIGHT +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/LICENSE +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/MANIFEST.in +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/README.md +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/container.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/containers/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/containers/asdf.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/containers/ewf.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/containers/fortifw.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/containers/hdd.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/containers/hds.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/containers/qcow2.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/containers/raw.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/containers/split.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/containers/vdi.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/containers/vhd.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/containers/vhdx.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/containers/vmdk.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/data/autocompletion/target_bash_completion.sh +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/exceptions.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/filesystem.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/filesystems/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/filesystems/ad1.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/filesystems/btrfs.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/filesystems/cb.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/filesystems/config.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/filesystems/cpio.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/filesystems/dir.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/filesystems/exfat.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/filesystems/extfs.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/filesystems/fat.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/filesystems/ffs.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/filesystems/itunes.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/filesystems/jffs.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/filesystems/ntfs.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/filesystems/overlay.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/filesystems/smb.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/filesystems/squashfs.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/filesystems/tar.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/filesystems/vmfs.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/filesystems/vmtar.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/filesystems/xfs.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/filesystems/zip.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/cache.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/compat/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/compat/path_310.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/compat/path_311.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/compat/path_312.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/compat/path_39.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/compat/path_common.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/config.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/configutil.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/cyber.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/data/windowsZones.xml +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/descriptor_extensions.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/docs.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/fsutil.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/hashutil.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/keychain.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/lazy.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/loaderutil.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/localeutil.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/mount.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/mui.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/polypath.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/protobuf.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/record.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/record_modifier.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/regutil.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/shell_application_ids.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/shell_folder_ids.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/helpers/utils.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loader.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/ab.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/ad1.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/asdf.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/cb.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/cyber.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/dir.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/hyperv.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/itunes.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/kape.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/libvirt.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/local.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/log.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/mqtt.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/multiraw.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/ova.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/overlay.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/ovf.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/phobos.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/profile.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/proxmox.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/pvm.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/pvs.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/raw.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/remote.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/res.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/smb.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/tanium.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/tar.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/target.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/utm.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/vb.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/vbox.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/velociraptor.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/vma.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/vmwarevm.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/vmx.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/loaders/xva.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugin.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/av/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/av/mcafee.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/av/sophos.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/av/symantec.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/av/trendmicro.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/browser/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/browser/brave.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/browser/browser.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/browser/chrome.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/browser/chromium.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/browser/edge.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/browser/firefox.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/browser/iexplore.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/container/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/container/docker.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/editor/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/editor/editor.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/editor/windowsnotepad.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/other/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/other/env.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/remoteaccess/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/remoteaccess/anydesk.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/remoteaccess/remoteaccess.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/remoteaccess/teamviewer.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/shell/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/shell/powershell.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/shell/wget.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/ssh/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/ssh/openssh.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/ssh/opensshd.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/ssh/putty.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/ssh/ssh.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/virtualization/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/virtualization/vmware_workstation.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/vpn/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/vpn/openvpn.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/vpn/wireguard.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/webhosting/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/webhosting/cpanel.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/webserver/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/webserver/apache.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/webserver/caddy.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/webserver/citrix.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/webserver/iis.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/webserver/nginx.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/apps/webserver/webserver.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/child/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/child/docker.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/child/esxi.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/child/hyperv.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/child/parallels.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/child/proxmox.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/child/qemu.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/child/virtuozzo.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/child/vmware_workstation.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/child/wsl.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/filesystem/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/filesystem/acquire_handles.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/filesystem/acquire_hash.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/filesystem/icat.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/filesystem/ntfs/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/filesystem/ntfs/mft.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/filesystem/ntfs/mft_timeline.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/filesystem/ntfs/usnjrnl.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/filesystem/ntfs/utils.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/filesystem/resolver.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/filesystem/unix/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/filesystem/unix/capability.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/filesystem/unix/suid.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/filesystem/walkfs.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/filesystem/yara.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/general/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/general/config.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/general/default.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/general/example.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/general/loaders.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/general/network.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/general/osinfo.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/general/plugins.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/general/scrape.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/general/users.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/_os.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/applications.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/bsd/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/bsd/_os.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/bsd/citrix/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/bsd/citrix/_os.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/bsd/citrix/history.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/bsd/freebsd/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/bsd/freebsd/_os.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/bsd/ios/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/bsd/ios/_os.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/bsd/openbsd/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/bsd/openbsd/_os.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/bsd/osx/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/bsd/osx/_os.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/bsd/osx/network.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/bsd/osx/user.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/cronjobs.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/datetime.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/esxi/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/esxi/_os.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/etc/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/etc/etc.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/generic.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/history.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/_os.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/android/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/android/_os.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/cmdline.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/debian/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/debian/_os.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/debian/apt.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/debian/dpkg.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/debian/proxmox/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/debian/proxmox/_os.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/debian/proxmox/vm.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/debian/snap.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/debian/vyos/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/debian/vyos/_os.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/environ.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/fortios/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/fortios/_keys.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/fortios/_os.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/fortios/generic.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/fortios/locale.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/iptables.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/modules.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/netstat.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/network_managers.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/proc.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/processes.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/redhat/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/redhat/_os.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/redhat/yum.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/services.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/sockets.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/suse/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/suse/_os.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/linux/suse/zypper.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/locale.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/locate/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/locate/gnulocate.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/locate/locate.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/locate/mlocate.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/locate/plocate.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/log/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/log/atop.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/log/audit.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/log/journal.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/log/lastlog.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/log/messages.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/log/utmp.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/packagemanager.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/shadow.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/unix/trash.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/_os.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/activitiescache.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/adpolicy.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/amcache.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/catroot.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/cim.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/clfs.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/credential/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/credential/credhist.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/credential/lsa.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/credential/sam.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/datetime.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/defender.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/defender_helpers/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/defender_helpers/defender_patterns.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/defender_helpers/defender_records.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/dpapi/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/dpapi/blob.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/dpapi/crypto.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/dpapi/dpapi.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/dpapi/keyprovider/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/dpapi/keyprovider/credhist.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/dpapi/keyprovider/empty.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/dpapi/keyprovider/keychain.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/dpapi/keyprovider/keyprovider.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/dpapi/keyprovider/lsa.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/dpapi/master_key.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/env.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/exchange/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/exchange/exchange.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/generic.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/jumplist.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/lnk.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/locale.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/log/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/log/amcache.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/log/etl.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/log/evt.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/log/evtx.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/log/pfro.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/log/schedlgu.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/network.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/notifications.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/prefetch.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/recyclebin.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/regf/7zip.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/regf/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/regf/applications.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/regf/appxdebugkeys.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/regf/auditpol.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/regf/bam.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/regf/cit.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/regf/clsid.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/regf/firewall.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/regf/mru.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/regf/muicache.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/regf/nethist.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/regf/recentfilecache.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/regf/regf.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/regf/runkeys.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/regf/shellbags.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/regf/shimcache.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/regf/trusteddocs.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/regf/usb.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/regf/userassist.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/registry.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/services.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/sru.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/startupinfo.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/syscache.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/task_helpers/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/task_helpers/tasks_job.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/task_helpers/tasks_records.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/task_helpers/tasks_xml.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/tasks.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/thumbcache.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/ual.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/wer.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/plugins/os/windows/wua_history.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/report.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/target.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/tools/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/tools/build_pluginlist.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/tools/dd.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/tools/dump/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/tools/dump/run.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/tools/dump/state.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/tools/dump/utils.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/tools/fs.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/tools/fsutils.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/tools/info.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/tools/logging.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/tools/mount.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/tools/query.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/tools/reg.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/tools/shell.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/tools/utils.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/tools/yara.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/volume.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/volumes/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/volumes/bde.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/volumes/ddf.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/volumes/disk.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/volumes/luks.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/volumes/lvm.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/volumes/md.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect/target/volumes/vmfs.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect.target.egg-info/SOURCES.txt +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect.target.egg-info/dependency_links.txt +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect.target.egg-info/entry_points.txt +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect.target.egg-info/requires.txt +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/dissect.target.egg-info/top_level.txt +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/pyproject.toml +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/setup.cfg +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/_docs/Makefile +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/_docs/conf.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/_docs/index.rst +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/_utils.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/conftest.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/containers/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/containers/test_fortifw.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/containers/test_split.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/filesystems/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/filesystems/test_btrfs.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/filesystems/test_cb.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/filesystems/test_config.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/filesystems/test_cpio.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/filesystems/test_dir.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/filesystems/test_exfat.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/filesystems/test_extfs.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/filesystems/test_fat.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/filesystems/test_ffs.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/filesystems/test_jffs2.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/filesystems/test_ntfs.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/filesystems/test_overlay.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/filesystems/test_smb.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/filesystems/test_tar.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/filesystems/test_vmtar.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/filesystems/test_xfs.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/filesystems/test_zip.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/helpers/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/helpers/test_cache.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/helpers/test_config.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/helpers/test_configutil.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/helpers/test_docs.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/helpers/test_fsutil.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/helpers/test_hashutil.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/helpers/test_keychain.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/helpers/test_loaderutil.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/helpers/test_localeutil.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/helpers/test_modifier.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/helpers/test_protobuf.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/helpers/test_record.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/helpers/test_regutil.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/helpers/test_utils.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/loaders/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/loaders/test_ab.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/loaders/test_asdf.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/loaders/test_cb.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/loaders/test_dir.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/loaders/test_hyperv.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/loaders/test_kape.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/loaders/test_libvirt.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/loaders/test_local.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/loaders/test_log.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/loaders/test_mqtt.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/loaders/test_multiraw.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/loaders/test_ova.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/loaders/test_overlay.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/loaders/test_ovf.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/loaders/test_phobos.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/loaders/test_pvm.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/loaders/test_pvs.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/loaders/test_remote.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/loaders/test_smb.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/loaders/test_tanium.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/loaders/test_tar.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/loaders/test_utm.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/loaders/test_vbox.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/loaders/test_velociraptor.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/loaders/test_vmwarevm.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/av/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/av/test_mcafee.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/av/test_sophos.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/av/test_symantec.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/av/test_trendmicro.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/browser/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/browser/test_brave.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/browser/test_chrome.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/browser/test_chromium.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/browser/test_edge.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/browser/test_firefox.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/browser/test_iexplore.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/container/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/container/test_docker.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/editor/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/editor/test_windowsnotepad.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/other/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/other/test_envfile.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/remoteaccess/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/remoteaccess/test_anydesk.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/remoteaccess/test_teamviewer.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/shell/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/shell/test_powershell.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/shell/test_wget.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/ssh/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/ssh/test_openssh.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/ssh/test_opensshd.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/ssh/test_putty.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/virtualization/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/virtualization/test_vmware_workstation.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/vpn/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/vpn/test_openvpn.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/vpn/test_wireguard.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/webhosting/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/webhosting/test_cpanel.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/webserver/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/webserver/test_apache.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/webserver/test_caddy.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/webserver/test_citrix.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/webserver/test_iis.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/webserver/test_nginx.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/apps/webserver/test_webserver.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/child/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/child/test_docker.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/child/test_hyperv.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/child/test_parallels.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/child/test_qemu.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/child/test_virtuozzo.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/child/test_vmware_workstation.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/child/test_wsl.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/filesystem/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/filesystem/ntfs/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/filesystem/ntfs/test_mft.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/filesystem/ntfs/test_usnjrnl.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/filesystem/test_acquire_handles.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/filesystem/test_acquire_hash.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/filesystem/test_icat.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/filesystem/test_resolver.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/filesystem/test_walkfs.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/filesystem/test_yara.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/filesystem/unix/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/filesystem/unix/test_capability.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/filesystem/unix/test_suid.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/general/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/general/test_config.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/general/test_default.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/general/test_network.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/general/test_plugins.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/general/test_scrape.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/general/test_users.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/bsd/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/bsd/citrix/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/bsd/citrix/test__os.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/bsd/citrix/test_history.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/bsd/osx/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/bsd/osx/test__os.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/bsd/osx/test_network.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/bsd/osx/test_user.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/esxi/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/esxi/test__os.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/linux/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/linux/android/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/linux/android/test__os.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/linux/debian/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/linux/debian/proxmox/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/linux/debian/proxmox/test__os.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/linux/debian/test_apt.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/linux/debian/test_dpkg.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/linux/debian/test_snap.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/linux/fortios/test_keys.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/linux/redhat/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/linux/redhat/test_yum.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/linux/suse/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/linux/suse/test_zypper.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/linux/test__os.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/linux/test_cmdline.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/linux/test_environ.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/linux/test_iptables.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/linux/test_modules.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/linux/test_netstat.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/linux/test_proc.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/linux/test_processes.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/linux/test_services.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/linux/test_sockets.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/locate/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/locate/test_gnulocate.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/locate/test_mlocate.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/locate/test_plocate.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/log/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/log/test_atop.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/log/test_audit.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/log/test_journal.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/log/test_lastlog.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/log/test_messages.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/log/test_utmp.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/test__os.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/test_applications.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/test_generic.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/test_history.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/test_ips.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/test_locale.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/test_packagemanager.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/test_shadow.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/test_trash.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/test_users.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/unix/test_version.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/credential/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/credential/test_credhist.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/credential/test_lsa.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/credential/test_sam.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/log/test_etl.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/log/test_evt.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/log/test_evtx.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/log/test_schedlgu.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/regf/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/regf/test_applications.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/regf/test_appxdebugkeys.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/regf/test_cit.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/regf/test_clsid.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/regf/test_muicache.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/regf/test_shellbags.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/regf/test_trusteddocs.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/regf/test_usb.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/regf/test_userassist.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/test__os.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/test_adpolicy.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/test_amcache.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/test_catroot.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/test_clfs.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/test_datetime.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/test_defender.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/test_dpapi.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/test_env.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/test_generic.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/test_jumplist.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/test_lnk.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/test_locale.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/test_mru.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/test_network.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/test_notifications.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/test_prefetch.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/test_recyclebin.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/test_registry.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/test_shimcache.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/test_sru.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/test_syscache.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/test_tasks.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/test_thumbcache.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/test_ual.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/test_wer.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/plugins/os/windows/test_wua_history.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/test_container.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/test_filesystem.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/test_plugin.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/test_registration.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/test_report.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/test_target.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/test_tests.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/test_volume.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/tools/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/tools/test_dump.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/tools/test_fs.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/tools/test_fsutils.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/tools/test_info.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/tools/test_mount.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/tools/test_query.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/tools/test_reg.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/tools/test_shell.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/tools/test_utils.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/tools/test_yara.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/volumes/__init__.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/volumes/test_bde.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tests/volumes/test_md.py +0 -0
- {dissect_target-3.20.dev45 → dissect_target-3.20.dev47}/tox.ini +0 -0
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.1
|
2
2
|
Name: dissect.target
|
3
|
-
Version: 3.20.
|
3
|
+
Version: 3.20.dev47
|
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,373 @@
|
|
1
|
+
from __future__ import annotations
|
2
|
+
|
3
|
+
import itertools
|
4
|
+
import logging
|
5
|
+
import re
|
6
|
+
from abc import ABC, abstractmethod
|
7
|
+
from datetime import datetime
|
8
|
+
from functools import lru_cache
|
9
|
+
from itertools import chain
|
10
|
+
from pathlib import Path
|
11
|
+
from typing import Any, Iterator
|
12
|
+
|
13
|
+
from dissect.target import Target
|
14
|
+
from dissect.target.exceptions import UnsupportedPluginError
|
15
|
+
from dissect.target.helpers.fsutil import open_decompress
|
16
|
+
from dissect.target.helpers.record import DynamicDescriptor, TargetRecordDescriptor
|
17
|
+
from dissect.target.helpers.utils import year_rollover_helper
|
18
|
+
from dissect.target.plugin import Plugin, alias, export
|
19
|
+
|
20
|
+
log = logging.getLogger(__name__)
|
21
|
+
|
22
|
+
RE_TS = re.compile(r"^[A-Za-z]{3}\s*\d{1,2}\s\d{1,2}:\d{2}:\d{2}")
|
23
|
+
RE_TS_ISO = re.compile(r"^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}\.\d{6}\+\d{2}:\d{2}")
|
24
|
+
RE_LINE = re.compile(
|
25
|
+
r"""
|
26
|
+
\d{2}:\d{2}\s # First match on the similar ending of the different timestamps
|
27
|
+
(?P<hostname>\S+)\s # The hostname
|
28
|
+
(?P<service>\S+?)(\[(?P<pid>\d+)\])?: # The service with optionally the PID between brackets
|
29
|
+
\s*(?P<message>.+?)\s*$ # The log message stripped from spaces left and right
|
30
|
+
""",
|
31
|
+
re.VERBOSE,
|
32
|
+
)
|
33
|
+
|
34
|
+
# Generic regular expressions
|
35
|
+
RE_IPV4_ADDRESS = re.compile(
|
36
|
+
r"""
|
37
|
+
((25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.){3} # First three octets
|
38
|
+
(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?) # Last octet
|
39
|
+
""",
|
40
|
+
re.VERBOSE,
|
41
|
+
)
|
42
|
+
RE_USER = re.compile(r"for ([^\s]+)")
|
43
|
+
|
44
|
+
|
45
|
+
class BaseService(ABC):
|
46
|
+
@classmethod
|
47
|
+
@abstractmethod
|
48
|
+
def parse(cls, message: str) -> dict[str, any]:
|
49
|
+
pass
|
50
|
+
|
51
|
+
|
52
|
+
class SudoService(BaseService):
|
53
|
+
"""Parsing of sudo service messages in the auth log."""
|
54
|
+
|
55
|
+
RE_SUDO_COMMAND = re.compile(
|
56
|
+
r"""
|
57
|
+
TTY=(?P<tty>\w+\/\w+)\s;\s # The TTY -> TTY=pts/0 ;
|
58
|
+
PWD=(?P<pwd>[\/\w]+)\s;\s # The current working directory -> PWD="/home/user" ;
|
59
|
+
USER=(?P<effective_user>\w+)\s;\s # The effective user -> USER=root ;
|
60
|
+
COMMAND=(?P<command>.+)$ # The command -> COMMAND=/usr/bin/whoami
|
61
|
+
""",
|
62
|
+
re.VERBOSE,
|
63
|
+
)
|
64
|
+
|
65
|
+
@classmethod
|
66
|
+
def parse(cls, message: str) -> dict[str, str]:
|
67
|
+
"""Parse auth log message from sudo."""
|
68
|
+
if not (match := cls.RE_SUDO_COMMAND.search(message)):
|
69
|
+
return {}
|
70
|
+
|
71
|
+
additional_fields = {}
|
72
|
+
for key, value in match.groupdict().items():
|
73
|
+
additional_fields[key] = value
|
74
|
+
|
75
|
+
return additional_fields
|
76
|
+
|
77
|
+
|
78
|
+
class SshdService(BaseService):
|
79
|
+
"""Class for parsing sshd messages in the auth log."""
|
80
|
+
|
81
|
+
RE_SSHD_PORTREGEX = re.compile(r"port\s(\d+)")
|
82
|
+
RE_USER = re.compile(r"for\s([^\s]+)")
|
83
|
+
|
84
|
+
@classmethod
|
85
|
+
def parse(cls, message: str) -> dict[str, str | int]:
|
86
|
+
"""Parse message from sshd"""
|
87
|
+
additional_fields = {}
|
88
|
+
if ip_address := RE_IPV4_ADDRESS.search(message):
|
89
|
+
field_name = "host_ip" if "listening" in message else "remote_ip"
|
90
|
+
additional_fields[field_name] = ip_address.group(0)
|
91
|
+
if port := cls.RE_SSHD_PORTREGEX.search(message):
|
92
|
+
additional_fields["port"] = int(port.group(1))
|
93
|
+
if user := cls.RE_USER.search(message):
|
94
|
+
additional_fields["user"] = user.group(1)
|
95
|
+
# Accepted publickey for test_user from 8.8.8.8 IP port 12345 ssh2: RSA SHA256:123456789asdfghjklertzuio
|
96
|
+
if "Accepted publickey" in message:
|
97
|
+
ssh_protocol, encryption_algo, key_info = message.split()[-3:]
|
98
|
+
hash_algo, key_hash = key_info.split(":")
|
99
|
+
additional_fields["ssh_protocol"] = ssh_protocol.strip(":")
|
100
|
+
additional_fields["encryption_algorithm"] = encryption_algo
|
101
|
+
additional_fields["hash_algorithm"] = hash_algo
|
102
|
+
additional_fields["key_hash"] = key_hash
|
103
|
+
if (failed := "Failed" in message) or "Accepted" in message:
|
104
|
+
action_type = "failed" if failed else "accepted"
|
105
|
+
additional_fields["action"] = f"{action_type} authentication"
|
106
|
+
additional_fields["authentication_type"] = "password" if "password" in message else "publickey"
|
107
|
+
|
108
|
+
return additional_fields
|
109
|
+
|
110
|
+
|
111
|
+
class SystemdLogindService(BaseService):
|
112
|
+
"""Class for parsing systemd-logind messages in the auth log."""
|
113
|
+
|
114
|
+
RE_SYSTEMD_LOGIND_WATCHING = re.compile(
|
115
|
+
r"""
|
116
|
+
(?P<action>Watching\ssystem\sbuttons)\s # Action is "Watching system buttons"
|
117
|
+
on\s(?P<device>[^\s]+)\s # The device the button is related to -> /dev/input/event0
|
118
|
+
\((?P<device_name>.*?)\) # The device (button) name -> (Power button)
|
119
|
+
""",
|
120
|
+
re.VERBOSE,
|
121
|
+
)
|
122
|
+
|
123
|
+
@classmethod
|
124
|
+
def parse(cls, message: str):
|
125
|
+
"""Parse auth log message from systemd-logind."""
|
126
|
+
additional_fields = {}
|
127
|
+
# Example: Nov 14 07:14:09 ubuntu-1 systemd-logind[4]: Removed session 4.
|
128
|
+
if "Removed" in message:
|
129
|
+
additional_fields["action"] = "removed session"
|
130
|
+
additional_fields["session"] = message.split()[-1].strip(".")
|
131
|
+
elif "Watching" in message and (match := cls.RE_SYSTEMD_LOGIND_WATCHING.search(message)):
|
132
|
+
for key, value in match.groupdict().items():
|
133
|
+
additional_fields[key] = value
|
134
|
+
# Example: New session 4 of user sampleuser.
|
135
|
+
elif "New session" in message:
|
136
|
+
parts = message.removeprefix("New session ").split()
|
137
|
+
additional_fields["action"] = "new session"
|
138
|
+
additional_fields["session"] = parts[0]
|
139
|
+
additional_fields["user"] = parts[-1].strip(".")
|
140
|
+
# Example: Session 4 logged out. Waiting for processes to exit.
|
141
|
+
elif "logged out" in message:
|
142
|
+
session = message.removeprefix("Session ").split(maxsplit=1)[0]
|
143
|
+
additional_fields["action"] = "logged out session"
|
144
|
+
additional_fields["session"] = session
|
145
|
+
# Example: New seat seat0.
|
146
|
+
elif "New seat" in message:
|
147
|
+
seat = message.split()[-1].strip(".")
|
148
|
+
additional_fields["action"] = "new seat"
|
149
|
+
additional_fields["seat"] = seat
|
150
|
+
|
151
|
+
return additional_fields
|
152
|
+
|
153
|
+
|
154
|
+
class SuService(BaseService):
|
155
|
+
"""Class for parsing su messages in the auth log."""
|
156
|
+
|
157
|
+
RE_SU_BY = re.compile(r"by\s([^\s]+)")
|
158
|
+
RE_SU_ON = re.compile(r"on\s([^\s]+)")
|
159
|
+
RE_SU_COMMAND = re.compile(r"'(.*?)'")
|
160
|
+
|
161
|
+
@classmethod
|
162
|
+
def parse(cls, message: str) -> dict[str, str]:
|
163
|
+
additional_fields = {}
|
164
|
+
if user := RE_USER.search(message):
|
165
|
+
additional_fields["user"] = user.group(1)
|
166
|
+
if by := cls.RE_SU_BY.search(message):
|
167
|
+
additional_fields["by"] = by.group(1)
|
168
|
+
if on := cls.RE_SU_ON.search(message):
|
169
|
+
additional_fields["device"] = on.group(1)
|
170
|
+
if command := cls.RE_SU_COMMAND.search(message):
|
171
|
+
additional_fields["command"] = command.group(1)
|
172
|
+
if (failed := "failed" in message) or "Successful" in message:
|
173
|
+
additional_fields["su_result"] = "failed" if failed else "success"
|
174
|
+
|
175
|
+
return additional_fields
|
176
|
+
|
177
|
+
|
178
|
+
class PkexecService(BaseService):
|
179
|
+
"""Class for parsing pkexec messages in the auth log."""
|
180
|
+
|
181
|
+
RE_PKEXEC_COMMAND = re.compile(
|
182
|
+
r"""
|
183
|
+
(?P<user>\S+?):\sExecuting\scommand\s # Starts with actual user -> user:
|
184
|
+
\[USER=(?P<effective_user>[^\]]+)\]\s # The impersonated user -> [USER=root]
|
185
|
+
\[TTY=(?P<tty>[^\]]+)\]\s # The tty -> [TTY=unknown]
|
186
|
+
\[CWD=(?P<cwd>[^\]]+)\]\s # Current working directory -> [CWD=/home/user]
|
187
|
+
\[COMMAND=(?P<command>[^\]]+)\] # Command -> [COMMAND=/usr/lib/example]
|
188
|
+
""",
|
189
|
+
re.VERBOSE,
|
190
|
+
)
|
191
|
+
|
192
|
+
@classmethod
|
193
|
+
def parse(cls, message: str) -> dict[str, str]:
|
194
|
+
"""Parse auth log message from pkexec"""
|
195
|
+
additional_fields = {}
|
196
|
+
if exec_cmd := cls.RE_PKEXEC_COMMAND.search(message):
|
197
|
+
additional_fields["action"] = "executing command"
|
198
|
+
for key, value in exec_cmd.groupdict().items():
|
199
|
+
if value and value.isdigit():
|
200
|
+
value = int(value)
|
201
|
+
additional_fields[key] = value
|
202
|
+
|
203
|
+
return additional_fields
|
204
|
+
|
205
|
+
|
206
|
+
class PamUnixService(BaseService):
|
207
|
+
RE_PAM_UNIX = re.compile(
|
208
|
+
r"""
|
209
|
+
pam_unix\([^\s]+:session\):\s(?P<action>session\s\w+)\s # Session action, usually opened or closed
|
210
|
+
for\suser\s(?P<user>[^\s\(]+)(?:\(uid=(?P<user_uid>\d+)\))? # User may contain uid like: root(uid=0)
|
211
|
+
(?:\sby\s\(uid=(?P<by_uid>\d+)\))?$ # Opened action also contains by
|
212
|
+
""",
|
213
|
+
re.VERBOSE,
|
214
|
+
)
|
215
|
+
|
216
|
+
@classmethod
|
217
|
+
def parse(cls, message):
|
218
|
+
"""Parse auth log message from pluggable authentication modules (PAM)."""
|
219
|
+
if not (match := cls.RE_PAM_UNIX.search(message)):
|
220
|
+
return {}
|
221
|
+
|
222
|
+
additional_fields = {}
|
223
|
+
for key, value in match.groupdict().items():
|
224
|
+
if value and value.isdigit():
|
225
|
+
value = int(value)
|
226
|
+
additional_fields[key] = value
|
227
|
+
|
228
|
+
return additional_fields
|
229
|
+
|
230
|
+
|
231
|
+
class AuthLogRecordBuilder:
|
232
|
+
"""Class for dynamically creating auth log records."""
|
233
|
+
|
234
|
+
RECORD_NAME = "linux/log/auth"
|
235
|
+
SERVICES: dict[str, BaseService] = {
|
236
|
+
"su": SuService,
|
237
|
+
"sudo": SudoService,
|
238
|
+
"sshd": SshdService,
|
239
|
+
"systemd-logind": SystemdLogindService,
|
240
|
+
"pkexec": PkexecService,
|
241
|
+
}
|
242
|
+
|
243
|
+
def __init__(self, target: Target):
|
244
|
+
self._create_event_descriptor = lru_cache(4096)(self._create_event_descriptor)
|
245
|
+
self.target = target
|
246
|
+
|
247
|
+
def _parse_additional_fields(self, service: str | None, message: str) -> dict[str, Any]:
|
248
|
+
"""Parse additional fields in the message based on the service."""
|
249
|
+
if "pam_unix(" in message:
|
250
|
+
return PamUnixService.parse(message)
|
251
|
+
|
252
|
+
if service not in self.SERVICES:
|
253
|
+
self.target.log.debug("Service %s is not recognised, no additional fields could be parsed", service)
|
254
|
+
return {}
|
255
|
+
|
256
|
+
try:
|
257
|
+
return self.SERVICES[service].parse(message)
|
258
|
+
except Exception as e:
|
259
|
+
self.target.log.warning("Parsing additional fields in message '%s' for service %s failed", message, service)
|
260
|
+
self.target.log.debug("", exc_info=e)
|
261
|
+
raise e
|
262
|
+
|
263
|
+
def build_record(self, ts: datetime, source: Path, line: str) -> TargetRecordDescriptor:
|
264
|
+
"""Builds an ``AuthLog`` event record."""
|
265
|
+
|
266
|
+
record_fields = [
|
267
|
+
("datetime", "ts"),
|
268
|
+
("path", "source"),
|
269
|
+
("string", "service"),
|
270
|
+
("varint", "pid"),
|
271
|
+
("string", "message"),
|
272
|
+
]
|
273
|
+
|
274
|
+
record_values = {
|
275
|
+
"ts": ts,
|
276
|
+
"message": line,
|
277
|
+
"service": None,
|
278
|
+
"pid": None,
|
279
|
+
"source": source,
|
280
|
+
"_target": self.target,
|
281
|
+
}
|
282
|
+
|
283
|
+
match = RE_LINE.search(line)
|
284
|
+
if match:
|
285
|
+
record_values.update(match.groupdict())
|
286
|
+
|
287
|
+
for key, value in self._parse_additional_fields(record_values["service"], line).items():
|
288
|
+
record_type = "string"
|
289
|
+
if isinstance(value, int):
|
290
|
+
record_type = "varint"
|
291
|
+
|
292
|
+
record_fields.append((record_type, key))
|
293
|
+
record_values[key] = value
|
294
|
+
|
295
|
+
# tuple conversion here is needed for lru_cache
|
296
|
+
desc = self._create_event_descriptor(tuple(record_fields))
|
297
|
+
return desc(**record_values)
|
298
|
+
|
299
|
+
def _create_event_descriptor(self, record_fields) -> TargetRecordDescriptor:
|
300
|
+
return TargetRecordDescriptor(self.RECORD_NAME, record_fields)
|
301
|
+
|
302
|
+
|
303
|
+
class AuthPlugin(Plugin):
|
304
|
+
"""Unix authentication log plugin."""
|
305
|
+
|
306
|
+
def __init__(self, target: Target):
|
307
|
+
super().__init__(target)
|
308
|
+
self._auth_log_builder = AuthLogRecordBuilder(target)
|
309
|
+
|
310
|
+
def check_compatible(self) -> None:
|
311
|
+
var_log = self.target.fs.path("/var/log")
|
312
|
+
if not any(var_log.glob("auth.log*")) and not any(var_log.glob("secure*")):
|
313
|
+
raise UnsupportedPluginError("No auth log files found")
|
314
|
+
|
315
|
+
@alias("securelog")
|
316
|
+
@export(record=DynamicDescriptor(["datetime", "path", "string"]))
|
317
|
+
def authlog(self) -> Iterator[Any]:
|
318
|
+
"""Yield contents of ``/var/log/auth.log*`` and ``/var/log/secure*`` files.
|
319
|
+
|
320
|
+
Order of returned events is not guaranteed to be chronological because of year
|
321
|
+
rollover detection efforts for log files without a year in the timestamp.
|
322
|
+
|
323
|
+
The following timestamp formats are recognised automatically. This plugin
|
324
|
+
assumes that no custom ``date_format`` template is set in ``syslog-ng`` or ``systemd``
|
325
|
+
configuration (defaults to ``M d H:M:S``).
|
326
|
+
|
327
|
+
ISO formatted authlog entries are parsed as can be found in Ubuntu 24.04 and later.
|
328
|
+
|
329
|
+
.. code-block:: text
|
330
|
+
|
331
|
+
CentOS format: Jan 12 13:37:00 hostname daemon: message
|
332
|
+
Debian format: Jan 12 13:37:00 hostname daemon[pid]: pam_unix(daemon:session): message
|
333
|
+
Ubuntu 24.04: 2024-01-12T13:37:00.000000+02:00 hostname daemon[pid]: pam_unix(daemon:session): message
|
334
|
+
|
335
|
+
Resources:
|
336
|
+
- https://help.ubuntu.com/community/LinuxLogFiles
|
337
|
+
"""
|
338
|
+
|
339
|
+
tzinfo = self.target.datetime.tzinfo
|
340
|
+
|
341
|
+
var_log = self.target.fs.path("/var/log")
|
342
|
+
for auth_file in chain(var_log.glob("auth.log*"), var_log.glob("secure*")):
|
343
|
+
if is_iso_fmt(auth_file):
|
344
|
+
iterable = iso_readlines(auth_file)
|
345
|
+
else:
|
346
|
+
iterable = year_rollover_helper(auth_file, RE_TS, "%b %d %H:%M:%S", tzinfo)
|
347
|
+
|
348
|
+
for ts, line in iterable:
|
349
|
+
yield self._auth_log_builder.build_record(ts, auth_file, line)
|
350
|
+
|
351
|
+
|
352
|
+
def iso_readlines(file: Path) -> Iterator[tuple[datetime, str]]:
|
353
|
+
"""Iterator reading the provided auth log file in ISO format. Mimics ``year_rollover_helper`` behaviour."""
|
354
|
+
with open_decompress(file, "rt") as fh:
|
355
|
+
for line in fh:
|
356
|
+
if not (match := RE_TS_ISO.match(line)):
|
357
|
+
log.warning("No timestamp found in one of the lines in %s!", file)
|
358
|
+
log.debug("Skipping line: %s", line)
|
359
|
+
continue
|
360
|
+
|
361
|
+
try:
|
362
|
+
ts = datetime.strptime(match[0], "%Y-%m-%dT%H:%M:%S.%f%z")
|
363
|
+
except ValueError as e:
|
364
|
+
log.warning("Unable to parse ISO timestamp in line: %s", line)
|
365
|
+
log.debug("", exc_info=e)
|
366
|
+
continue
|
367
|
+
|
368
|
+
yield ts, line
|
369
|
+
|
370
|
+
|
371
|
+
def is_iso_fmt(file: Path) -> bool:
|
372
|
+
"""Determine if the provided auth log file uses new ISO format logging or not."""
|
373
|
+
return any(itertools.islice(iso_readlines(file), 0, 2))
|
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.1
|
2
2
|
Name: dissect.target
|
3
|
-
Version: 3.20.
|
3
|
+
Version: 3.20.dev47
|
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
|