diff --git a/packages/chrome.extensions.vm/chrome.extensions.vm.nuspec b/packages/chrome.extensions.vm/chrome.extensions.vm.nuspec new file mode 100644 index 000000000..425df138e --- /dev/null +++ b/packages/chrome.extensions.vm/chrome.extensions.vm.nuspec @@ -0,0 +1,13 @@ + + + + chrome.extensions.vm + 0.0.1.20240930 + Mandiant + A package for multiple useful chrome extensions from the Chrome webstore. + + + + + + diff --git a/packages/chrome.extensions.vm/tools/chocolateyinstall.ps1 b/packages/chrome.extensions.vm/tools/chocolateyinstall.ps1 new file mode 100644 index 000000000..cf8e679a0 --- /dev/null +++ b/packages/chrome.extensions.vm/tools/chocolateyinstall.ps1 @@ -0,0 +1,64 @@ +$ErrorActionPreference = 'Stop' +Import-Module vm.common -Force -DisableNameChecking + +try { + + $extensions = @( + # MetaMask + 'nkbihfbeogaeaoehlefnkodbefgpgknn' + # Phantom + 'bfnaelmomeimhlpmgjnjophhpkkoljpa' + # BNB Chain Wallet + 'fhbohimaelbohpjbbldcngcnapndodjp' + # Avira Password Manager + 'caljgklbbfbcjjanaijlacgncafpegll' + # KeePassXC-Browser + 'oboonakemofpalcgghocfoadofidjkkk' + # Yoroi + 'ffnbelfdoeiohenkjibnmadjiehjhajb' + # XDEFI Wallet + 'hmeobnfnfcmdkdcmlblgagmfpfboieaf' + # ... + ) + + $regKeyPath = "HKLM:\SOFTWARE\WOW6432Node\Policies\Google\Chrome\ExtensionInstallForcelist" + $updateUrl = "https://clients2.google.com/service/update2/crx" + + New-Item -Path $regKeyPath -Force -ea 0 | Out-Null + $valueName = 1 + Foreach ($extensionId in $extensions) + { + New-ItemProperty -Path "$regKeyPath" -Name "$valueName" -Type String -Value "$extensionId;$updateUrl" -Force -ea 0 | Out-Null + $valueName += 1 + } + + $chromePath = "${Env:ProgramFiles}\Google\Chrome\Application\chrome.exe" + $extensionsDir = "${Env:LocalAppData}\Google\Chrome\User Data\Default\Extensions" + + $loaded = $false + while (-not $loaded) + { + # Restart Chrome. + Stop-Process -Force -Name Chrome -ea 0 + $chromeId = (Start-Process -FilePath $chromePath -passthru).id + + # Wait for the extensions to be loaded. + Start-Sleep -Seconds 120 + Stop-Process -Force -Id $chromeId | Out-Null + + # Make sure all of the extensions are loaded. + $loaded = $true + Foreach ($extensionId in $extensions) + { + $extensionPath = Join-Path $extensionsDir $extensionId + if (-not (Test-Path -Path $extensionPath)) + { + $loaded = $false + break + } + } + } + +} catch { + VM-Write-Log-Exception $_ +} diff --git a/packages/chrome.extensions.vm/tools/chocolateyuninstall.ps1 b/packages/chrome.extensions.vm/tools/chocolateyuninstall.ps1 new file mode 100644 index 000000000..fafc394d7 --- /dev/null +++ b/packages/chrome.extensions.vm/tools/chocolateyuninstall.ps1 @@ -0,0 +1,5 @@ +$ErrorActionPreference = 'Continue' +Import-Module vm.common -Force -DisableNameChecking + +$regKeyPath = "HKLM:\SOFTWARE\WOW6432Node\Policies\Google\Chrome\ExtensionInstallForcelist" +Remove-Item -Path $regKeyPath -Recurse -Force -ea 0 diff --git a/scripts/test/lint.py b/scripts/test/lint.py index 16d8452b1..09c140a02 100644 --- a/scripts/test/lint.py +++ b/scripts/test/lint.py @@ -335,6 +335,7 @@ class UsesInvalidCategory(Lint): "python3.vm", "x64dbgpy.vm", "vscode.extension.", + "chrome.extensions.vm", ] root_path = os.path.abspath(os.path.join(__file__, "../../.."))