www.reversinglabs.com
Open in
urlscan Pro
2606:2c40::c73c:671f
Public Scan
URL:
https://www.reversinglabs.com/blog/vmconnect-malicious-pypi-packages-imitate-popular-open-source-modules
Submission: On August 07 via api from DE — Scanned from DE
Submission: On August 07 via api from DE — Scanned from DE
Form analysis
2 forms found in the DOM/hs-search-results
<form action="/hs-search-results" class="modal__form" data-hs-cf-bound="true">
<input type="text" class="hs-search-field__input" name="term" autocomplete="off" aria-label="Search" placeholder="Search reversinglabs.com">
<input type="hidden" name="type" value="SITE_PAGE">
<input type="hidden" name="type" value="LANDING_PAGE">
<input type="hidden" name="type" value="BLOG_POST">
<input type="hidden" name="type" value="LISTING_PAGE">
<button aria-label="Search" class="modal__search-button"><span id="hs_cos_wrapper_module_156348961026185_" class="hs_cos_wrapper hs_cos_wrapper_widget hs_cos_wrapper_type_icon" style="" data-hs-cos-general-type="widget" data-hs-cos-type="icon"><svg
version="1.0" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512" aria-hidden="true">
<g id="search1_layer">
<path
d="M505 442.7L405.3 343c-4.5-4.5-10.6-7-17-7H372c27.6-35.3 44-79.7 44-128C416 93.1 322.9 0 208 0S0 93.1 0 208s93.1 208 208 208c48.3 0 92.7-16.4 128-44v16.3c0 6.4 2.5 12.5 7 17l99.7 99.7c9.4 9.4 24.6 9.4 33.9 0l28.3-28.3c9.4-9.4 9.4-24.6.1-34zM208 336c-70.7 0-128-57.2-128-128 0-70.7 57.2-128 128-128 70.7 0 128 57.2 128 128 0 70.7-57.2 128-128 128z">
</path>
</g>
</svg></span></button>
</form>
POST https://forms.hsforms.com/submissions/v3/public/submit/formsnext/multipart/3375217/24abef2a-a2f4-4889-8899-dd4026584fa9
<form id="hsForm_24abef2a-a2f4-4889-8899-dd4026584fa9_308" method="POST" accept-charset="UTF-8" enctype="multipart/form-data" novalidate=""
action="https://forms.hsforms.com/submissions/v3/public/submit/formsnext/multipart/3375217/24abef2a-a2f4-4889-8899-dd4026584fa9"
class="hs-form-private hsForm_24abef2a-a2f4-4889-8899-dd4026584fa9 hs-form-24abef2a-a2f4-4889-8899-dd4026584fa9 hs-form-24abef2a-a2f4-4889-8899-dd4026584fa9_57a3a104-bec5-4bb6-a9d9-0739d9976935 hs-form stacked hs-custom-form"
target="target_iframe_24abef2a-a2f4-4889-8899-dd4026584fa9_308" data-instance-id="57a3a104-bec5-4bb6-a9d9-0739d9976935" data-form-id="24abef2a-a2f4-4889-8899-dd4026584fa9" data-portal-id="3375217" data-hs-cf-bound="true">
<div class="hs_email hs-email hs-fieldtype-text field hs-form-field"><label id="label-email-24abef2a-a2f4-4889-8899-dd4026584fa9_308" class="" placeholder="Enter your " for="email-24abef2a-a2f4-4889-8899-dd4026584fa9_308"><span></span></label>
<legend class="hs-field-desc" style="display: none;"></legend>
<div class="input"><input id="email-24abef2a-a2f4-4889-8899-dd4026584fa9_308" name="email" required="" placeholder="Email*" type="email" class="hs-input" inputmode="email" autocomplete="email" value=""></div>
</div>
<div class="hs_leadsource hs-leadsource hs-fieldtype-select field hs-form-field" style="display: none;"><label id="label-leadsource-24abef2a-a2f4-4889-8899-dd4026584fa9_308" class="" placeholder="Enter your Lead source"
for="leadsource-24abef2a-a2f4-4889-8899-dd4026584fa9_308"><span>Lead source</span></label>
<legend class="hs-field-desc" style="display: none;"></legend>
<div class="input"><input name="leadsource" class="hs-input" type="hidden" value="Website"></div>
</div>
<div class="hs_utm_campaign hs-utm_campaign hs-fieldtype-text field hs-form-field" style="display: none;"><label id="label-utm_campaign-24abef2a-a2f4-4889-8899-dd4026584fa9_308" class="" placeholder="Enter your utm_campaign"
for="utm_campaign-24abef2a-a2f4-4889-8899-dd4026584fa9_308"><span>utm_campaign</span></label>
<legend class="hs-field-desc" style="display: none;"></legend>
<div class="input"><input name="utm_campaign" class="hs-input" type="hidden" value=""></div>
</div>
<div class="hs_utm_content hs-utm_content hs-fieldtype-text field hs-form-field" style="display: none;"><label id="label-utm_content-24abef2a-a2f4-4889-8899-dd4026584fa9_308" class="" placeholder="Enter your utm_content"
for="utm_content-24abef2a-a2f4-4889-8899-dd4026584fa9_308"><span>utm_content</span></label>
<legend class="hs-field-desc" style="display: none;"></legend>
<div class="input"><input name="utm_content" class="hs-input" type="hidden" value=""></div>
</div>
<div class="hs_utm_medium hs-utm_medium hs-fieldtype-text field hs-form-field" style="display: none;"><label id="label-utm_medium-24abef2a-a2f4-4889-8899-dd4026584fa9_308" class="" placeholder="Enter your utm_medium"
for="utm_medium-24abef2a-a2f4-4889-8899-dd4026584fa9_308"><span>utm_medium</span></label>
<legend class="hs-field-desc" style="display: none;"></legend>
<div class="input"><input name="utm_medium" class="hs-input" type="hidden" value=""></div>
</div>
<div class="hs_utm_source hs-utm_source hs-fieldtype-text field hs-form-field" style="display: none;"><label id="label-utm_source-24abef2a-a2f4-4889-8899-dd4026584fa9_308" class="" placeholder="Enter your utm_source"
for="utm_source-24abef2a-a2f4-4889-8899-dd4026584fa9_308"><span>utm_source</span></label>
<legend class="hs-field-desc" style="display: none;"></legend>
<div class="input"><input name="utm_source" class="hs-input" type="hidden" value=""></div>
</div>
<div class="hs_utm_term hs-utm_term hs-fieldtype-text field hs-form-field" style="display: none;"><label id="label-utm_term-24abef2a-a2f4-4889-8899-dd4026584fa9_308" class="" placeholder="Enter your utm_term"
for="utm_term-24abef2a-a2f4-4889-8899-dd4026584fa9_308"><span>utm_term</span></label>
<legend class="hs-field-desc" style="display: none;"></legend>
<div class="input"><input name="utm_term" class="hs-input" type="hidden" value=""></div>
</div>
<div class="hs_submit hs-submit">
<div class="hs-field-desc" style="display: none;"></div>
<div class="actions"><input type="submit" class="hs-button primary large" value="Submit"></div>
</div><input name="hs_context" type="hidden"
value="{"embedAtTimestamp":"1691411879877","formDefinitionUpdatedAt":"1691179463077","lang":"en","clonedFromForm":"ce383929-448d-4186-b8e8-0851a2285f27","userAgent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/115.0.5790.170 Safari/537.36","pageTitle":"VMConnect: Malicious PyPI packages imitate popular open source modules","pageUrl":"https://www.reversinglabs.com/blog/vmconnect-malicious-pypi-packages-imitate-popular-open-source-modules","pageId":"128190968732","isHubSpotCmsGeneratedPage":true,"canonicalUrl":"https://www.reversinglabs.com/blog/vmconnect-malicious-pypi-packages-imitate-popular-open-source-modules","contentType":"blog-post","hutk":"eb0475e201baf943332202a646cbf8f8","__hsfp":2246696628,"__hssc":"60854195.1.1691411881867","__hstc":"60854195.eb0475e201baf943332202a646cbf8f8.1691411881867.1691411881867.1691411881867.1","formTarget":"#hs_form_target_form_893289651","formInstanceId":"308","rawInlineMessage":"<p>Thanks for your interest in our blog.&nbsp; You will receive an email when new blogs are published!</p>","hsFormKey":"6927e25663fd7fc1b4982b84d7fcfb82","pageName":"VMConnect: Malicious PyPI packages imitate popular open source modules","locale":"en","timestamp":1691411881921,"originalEmbedContext":{"portalId":"3375217","formId":"24abef2a-a2f4-4889-8899-dd4026584fa9","region":"na1","target":"#hs_form_target_form_893289651","isBuilder":false,"isTestPage":false,"isPreview":false,"formInstanceId":"308","formsBaseUrl":"/_hcms/forms","css":"","inlineMessage":"<p>Thanks for your interest in our blog.&nbsp; You will receive an email when new blogs are published!</p>","isMobileResponsive":true,"rawInlineMessage":"<p>Thanks for your interest in our blog.&nbsp; You will receive an email when new blogs are published!</p>","hsFormKey":"6927e25663fd7fc1b4982b84d7fcfb82","pageName":"VMConnect: Malicious PyPI packages imitate popular open source modules","pageId":"128190968732","contentType":"blog-post","formData":{"cssClass":"hs-form stacked hs-custom-form"},"isCMSModuleEmbed":true},"correlationId":"57a3a104-bec5-4bb6-a9d9-0739d9976935","renderedFieldsIds":["email","leadsource","utm_campaign","utm_content","utm_medium","utm_source","utm_term"],"captchaStatus":"NOT_APPLICABLE","emailResubscribeStatus":"NOT_APPLICABLE","isInsideCrossOriginFrame":false,"source":"forms-embed-1.3512","sourceName":"forms-embed","sourceVersion":"1.3512","sourceVersionMajor":"1","sourceVersionMinor":"3512","_debug_allPageIds":{"embedContextPageId":"128190968732","analyticsPageId":"128190968732","pageContextPageId":"128190968732"},"_debug_embedLogLines":[{"clientTimestamp":1691411880059,"level":"INFO","message":"Retrieved customer callbacks used on embed context: [\"getExtraMetaDataBeforeSubmit\"]"},{"clientTimestamp":1691411880060,"level":"INFO","message":"Retrieved pageContext values which may be overriden by the embed context: {\"pageTitle\":\"VMConnect: Malicious PyPI packages imitate popular open source modules\",\"pageUrl\":\"https://www.reversinglabs.com/blog/vmconnect-malicious-pypi-packages-imitate-popular-open-source-modules\",\"userAgent\":\"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/115.0.5790.170 Safari/537.36\",\"pageId\":\"128190968732\",\"isHubSpotCmsGeneratedPage\":true}"},{"clientTimestamp":1691411880062,"level":"INFO","message":"Retrieved countryCode property from normalized embed definition response: \"DE\""},{"clientTimestamp":1691411881904,"level":"INFO","message":"Retrieved analytics values from API response which may be overriden by the embed context: {\"hutk\":\"eb0475e201baf943332202a646cbf8f8\",\"canonicalUrl\":\"https://www.reversinglabs.com/blog/vmconnect-malicious-pypi-packages-imitate-popular-open-source-modules\",\"contentType\":\"blog-post\",\"pageId\":\"128190968732\"}"}]}"><iframe
name="target_iframe_24abef2a-a2f4-4889-8899-dd4026584fa9_308" style="display: none;"></iframe>
</form>
Text Content
slide 2 of 3 Read the LATEST Software Supply Chain Security Risk Report Read Now Find RL at Hacker Summer Camp - Black Hat, Def Con 31, & BSides LV! Learn More DevSecOps: A New Hope For Software Supply Chain Security | Webinar Aug 16 Register Now Read the LATEST Software Supply Chain Security Risk Report Read Now Find RL at Hacker Summer Camp - Black Hat, Def Con 31, & BSides LV! Learn More Solutions Software Supply Chain Security Software Supply Chain Security Software Bill of Materials Verify Third Party Software Verify Software Build & Release Automate SOC Support Triage Incident Response SIEM/SOAR Protect Cloud File Shares Optimize Threat Hunting Ransomware Feed Malware Lab Threat Hunting Sandbox Email EDR Threat Intelligence Platforms Threat Intelligence for Microsoft Sentinel Platform & Products Titanium Platform ReversingLabs Software Supply Chain Security ReversingLabs Threat Intelligence ReversingLabs Cloud Deep Scan ReversingLabs Elastic Threat Infrastructure ReversingLabs Threat Analysis & Hunting Free: Open-Source YARA Rules Why Us Why Choose ReversingLabs Partners GSI & Reseller Partners Integration Partners Security Partners Alliances ReversingLabs and Synopsys Resources Content Library Webinars Software Deconstruction Demo Series ReversingGlass: Concepts Explained ConversingLabs Podcast From the Labs: YARA Rules Demo Videos Learning with ReversingLabs Threat Intelligence Quiz Company Company About Us Leadership Careers Series B Investment Company News Events Events Hacker Summer Camp 2023 Press Press Releases In the News Demo Search Contact Us Support Login Blog Developer Portal REVERSINGLABS BLOG Threat Research | August 3, 2023 VMCONNECT: MALICIOUS PYPI PACKAGES IMITATE POPULAR OPEN SOURCE MODULES REVERSINGLABS THREAT RESEARCHERS HAVE IDENTIFIED A NEW MALICIOUS PYPI CAMPAIGN THAT INCLUDES A SUSPICIOUS VMCONNECT PACKAGE PUBLISHED TO THE PYPI REPO. Blog Author Karlo Zanki, Reverse Engineer at ReversingLabs. Read More... * * * * ReversingLabs has identified several malicious Python packages on the Python Package Index (PyPI) open source repository. In all, ReversingLabs researchers uncovered 24 malicious packages imitating three, popular open source Python tools: vConnector, a wrapper module for pyVmomi VMware vSphere bindings; as well as eth-tester, a collection of tools for testing ethereum based applications; and databases, a tool that gives asyncro support for a range of databases. Based on the research team's observations, the campaign began on or around July 28, 2023, when the first of the malicious packages were published. It continues to the current day, with new, malicious PyPI packages posted on a daily basis, as prior packages are detected and removed. In contrast to other, recent supply chain campaigns, such as Operation Brainleeches, the malicious packages that make up this campaign display evidence of a concerted effort to deceive developers. They achieve this by implementing the entire functionality of the modules they are imitating and standing up corresponding and linked GitHub projects that omit the malicious functionality found in the PyPI release package. This is not the first time that we have observed such behavior. In June, 2022, for example, we discovered an npm malicious package, maintenancewebsite, which used a similar approach to hide cryptomining features. The VMConnect campaign is the latest example of open source modules being used to propagate malicious code, and more evidence that security assessments of open source code repositories may miss these nuanced attacks. The ReversingLabs research team is continuously monitoring open-source package repositories for instances of malicious code tampering, the planting of malicious packages or dependencies and other forms of software supply chain attacks. This work involves both automated and human-led scanning and analysis of packages published in the most popular public package repositories like npm, PyPI, Ruby and NuGet. Historically, the vast majority of the malicious supply chain campaigns we have identified were found on the npm open source repository, which is home to the lion’s share of open source projects and developers. However, in recent months other platforms, in particular, the Python Package Index (PyPI) have seen increased malicious activity. In February, for example, ReversingLabs researchers discovered 41 malicious PyPI packages posing as HTTP libraries, with some mimicking popular and widely used libraries. In March, we encountered a malicious PyPI package named termcolour, a three-stage downloader published in multiple versions that co-opted the name of a defunct PyPI package. Then, in May, PyPI briefly stopped accepting new submissions after it was overwhelmed with malicious submissions. ReversingLabs threat researchers have identified a new malicious PyPI campaign that includes a suspicious VMConnect package published to the PyPI repository. SUSPICIOUS BEHAVIOR DETECTED This package was declared suspicious during routine scanning by ReversingLabs Titanium Platform, a powerful static analysis engine capable of extracting various types of metadata from a wide range of file formats. Besides the various types of metadata, the ReversingLabs Titanium Platform is also capable of extracting behavior indicators, making it easier to understand functional capabilities of a file. And that capability is what drew our attention to the _init_.py file within VMConnect. Code inside VMConnect’s __init__.py file is capable of creating a process, decoding data using the Base64 algorithm and converting binary data to its string representation — a behavior commonly used in obfuscation. This combination of behaviors is what triggered the initial detection and prompted further investigation. Figure 1: Behavior indicators extracted from VMConnect package. A detailed look at the __init__.py file confirmed the presence of malicious functionality inside the package. That started with that Base64 encoded string, which gets decoded and executed in another process. Figure 2: Execution of Base64 encoded string inside the __init__.py file. When we decode the string, we discovered that it contains a download URL which is modified based on the information collected from the host machine. The substring paperpin3902 in the command and control URL is replaced with a string containing the first letter of the host’s platform name, username and a random, 6 character-long string. Figure 3: C2 URL template, extracted from the Base64 encoded string, gets modified based on host machine information. The decoded and executed Base64 string contains an endless execution loop which contacts the command and control (C2) server and attempts to download another Base64 encoded string with additional commands. If it succeeds, that code is executed and the loop repeats, with the C2 server polled by the infected host for new commands after a preconfigured sleep period. Figure 4: Command fetching and execution loop extracted from the Base64 encoded string present in the __init__.pyfile. Although the C2 server was live at the time of this research, the research team did not observe it serving any commands. Since the command fetching is performed in an endless loop, it is possible that the operator of the C2 server uploads commands only after the infected machine is determined to be interesting to the threat actor. Alternatively, the C2 server could be performing some type of request filtering. For example, attackers may filter requests based on the IP address of the infected machine to avoid infecting targets from specific countries. GITHUB MISDIRECTION The VMConnect package was published on July 28th, by a developer named Hushki Manager — a throw-away PyPI account created the same day when its only package was published. Figure 5: PyPI profile of hushki502 user. Despite that, the actor did put a lot of effort into making the package look trustworthy. For example, it has a legitimate-looking description, and that description corresponds to the functionality present inside the package. Threat actors often don’t make the effort to tidy up the project's description on the PyPI website. Instead, they often rely on simple typosquatting of package names in order to trick enough developers into installing their creation. For example, the threat actors behind the recently discovered Operation Brainleeches campaign made minimal efforts to disguise their malicious packages, using default file names like index.html and DEMO.txt likely copied from phishing kits and minimally altered before being published. Figure 6: VMConnect package description. In this campaign, however, the attackers took a more studied approach. In addition to reusing the description from the actual packages, the attackers properly set links to a Github source code repository which was created by the same author on the same day. The Github project site looks trustworthy, with a description matching the one on the PyPI site and several commits and nothing obviously suspicious in the published files. Figure 7: Github profile of hushki502 user. Finally, the malicious actors took care to hide the malicious nature of this tool by omitting malicious functionality from the __init__.py file that was published to the Github repository. Figure 8: Benign version of__init__.py file present in Github repository. The use of corresponding GitHub repositories to create the impression of a legitimate open source package is something we have seen before - and there’s a good explanation for why threat actors are taking the trouble to do this. Historically, many supply chain security solutions have relied on source code reviews of third party libraries. Attackers, therefore, have an incentive to throw code scanning tools and manual code reviewers off their scent. For reviewers, PyPI projects tend to look more trustworthy if they have a corresponding link to a Github repository that doesn’t seem arbitrary. In the case of the malicious PyPI packages, the attacker created a phony Github repository with an identical name as the PyPI package and copied the entire functionality from the legitimate Github project into the corresponding PyPI project. However, the malicious functionality is not present within the source code. It is only by scanning the artifacts used in the build process that this threat would have been detected. ReversingLabs observed a similar tactic used in the case of the npm coinminer discovered a year ago. In that campaign, the content of the release package - a temporary “maintenance mode” website” — was also different from the content hosted in the corresponding source code repository. As with the current PyPI packages, malicious content was added to the legitimate public source code resulting in a PyPI release package that looks much the same as the open source code it is built on, but with some subtle (and malicious) changes that are easily overlooked. The lesson for development and application security teams is that release packages can (and do) contain malicious functionality which isn’t present in open source repositories and therefore can’t be detected with source code scanning or manual source code reviews alone. These teams need a method for detecting suspicious content in the final release packages themselves to avoid falling victim to supply chain attacks such as this VMConnect PyPI campaign. IMITATION: THE SINCEREST FORM OF THIEVERY It is also educational to take a closer look at the methods the attackers in this case used to disguise their malicious intent, including dressing their malicious wares up to imitate legitimate and widely used open source packages. As we noted above, the packages we detected mimic a variety of well known PyPI packages with wide distributions, but serving very different ends. The common thread connecting the PyPI packages that were imitated appears to be nothing more than their popularity, measured in monthly downloads. In each case, the attackers disguised their PyPI packages to look like these widely used and legitimate tools. That included copying the package description and pasting it into their imitation packages, simply replacing the legitimate package name with the name of their impostor package. From the standpoint of a threat researcher or incident responder, their lack of effort makes the job of detecting the ruse easier. In our research, a Google search for the first sentence of the description immediately revealed the corresponding, legitimate package that was being mimickedAs visible in Figures 9 and 10, the descriptions of the PyPI packages and Github projects are identical, aside from the project name. Figure 9: Github description of the malicious VMConnect project. Figure 10: Github description of the legitimate vConnector project. In this case, vConnector is a fairly popular package, first published nine years ago, with the last modification being committed to the Github repository almost four years ago. Download stats for this package show that it has almost 40 thousand downloads per month. A large number of monthly downloads combined with the lack of recent maintenance make this package a very good target for impersonation. On July 19, seven different versions of a package titled osinfopkg were published to the PyPI repository and used to develop and test the malicious functionality that eventually got included into the VMConnect package.Since this was a testing package, the malicious actor didn’t give too much care into making it look trustworthy, even though it did create a dedicated Github repository containing two more projects. Then, on July 31, another package named ethter, was released. In this case, the threat actor impersonated the popular package eth-tester — a collection of tools for testing ethereum based applications which has more than 60 thousand monthly downloads. As the ReversingLabs research team observed with the VMConnect package, the ethter description was copied verbatim from the eth-tester package, with only the package name replaced. Here again, a phony Github repository was created and malicious functionality was hidden in the utils/based.py file inside the corresponding PyPI package. The malicious file isn’t present in the Github source code repository, only in the PyPI package. The threat actor also released the latest version of their malicious package with the 1.10.1b1 version number. That is in line with the version numbering convention of the impersonated package, and is higher than the latest released version of the impersonated package. The same approach is applied to the malicious quantiumbase package impersonating legitimate databases package. ATTACKERS PLAY WHAC-A-MODULE Fortunately for Python developers, none of the packages we detected were available for download for very long. Most, including the VMConnect package, were removed from PyPI within one to three days of being posted. Because of limitations in the PyPI platform, we do not know the reason that these packages were removed: whether they were detected by internal systems operated by PyPI itself, whether reports from ReversingLabs or other firms led to the takedowns, or whether the malicious actors themselves removed the packages. Efforts to get a definitive answer from PyPI on the circumstances that led to the various take downs were not successful. However, we have observed that new malicious packages get published to PyPI on a daily basis, as soon as the previous package is reported and removed from the PyPI repository. In other words, despite the detection and removal of the packages described above, this malicious PyPI campaign is alive and ongoing. The quick response from threat actors to replace malicious PyPI packages suggests that this is a well-planned and organized campaign and that the malicious actors probably have a prepared list of packages suitable for imitation. QUESTIONS LINGER ON WHO, WHAT, AND WHY There are lingering questions about key elements of this malicious, supply chain campaign. Among them: who (or what) posted the malicious packages, what the ultimate objective of the attacks is and why the campaign was launched. On the question of who, we do not have sufficient telemetry to pinpoint a threat actor or actors as being responsible for the latest campaign. By publishing the IOCs including command and control infrastructure we have collected, however, we hope that others may be able to connect those with evidence of known attacks and threat actors to help fill in the full picture behind this campaign. Previous supply chain attacks utilizing PyPI, npm and other public repositories range from sophisticated (IconBurst) to unsophisticated (Operation Brainleeches). While the VMConnect campaign doesn’t have many of the telltale signs of a sophisticated nation-state campaign, it is not a copy and paste “script kiddie” operation either. More data is required to reach conclusions about who or what is responsible for this PyPI malicious campaign. Similarly, the research team was unable to obtain the second stage deliverable used in these attacks. As noted, the compromised endpoints ReversingLabs observed merely polled C2 servers waiting for further commands (and presumably downloads). But we were unable to observe any active exchanges, which could indicate that the malicious actors were not actively using the infrastructure, or that the compromised endpoints we controlled were not of interest to them. Lacking any visibility into the later stages of this campaign, it is impossible to know what its ultimate purpose was: theft of sensitive data or intellectual property? Surveillance? Ransomware? All of the above? More data that reveals the full breadth of this campaign is needed before we can speculate on its intent. INDICATORS OF COMPROMISE (IOCS) Indicators of Compromise (IoCs) refer to forensic artifacts or evidence related to a security breach or unauthorized activity on a computer network or system. IOCs play a crucial role in cybersecurity investigations and cyber incident response efforts, helping analysts and cybersecurity professionals identify and detect potential security incidents. The following IOCs were collected as part of ReversingLabs investigation of the VMConnect software supply chain campaign. COMMAND AND CONTROL (C2) DOMAINS AND IP ADDRESS: 45.61.139.219 ethertestnet.pro deliworkshopexpress.xyz PYPI PACKAGES: package_name version SHA1 VMConnect 1.1.7 b0095f149951241c6e11e0d1be1f74e8cdfbdbb2 VMConnect 1.1.7 2ff1b3aa2dbff6d87447b250a8d19241e7853ab0 osinfopkg 0.0.2 67226da423ab4a2c97b2d008dec45280aaa5fdf5 osinfopkg 0.0.2 146942c5dbaba55be174b1bfb127410e332caa03 osinfopkg 0.0.3 0eb79e80c51c0e14be3620dfb237f7b53160a292 osinfopkg 0.0.3 bc2d48d6d9eeaf0b29625683942e90dfd2b75723 osinfopkg 0.0.4 9a276ca3678898f5596166416f7e709a2064e95c osinfopkg 0.0.4 658605988c7afd9adf437fb64ff682cb4190f144 osinfopkg 1.0.1 5f03b73d56528ecbc3f24b8e7daec6b3d3370834 osinfopkg 1.0.1 19684554e4905bb3cf354a5d5a0f00d696f38926 osinfopkg 1.0.2 e531121b137182453f0d120be860ad882d2dc0a7 osinfopkg 1.0.2 b1f2d50be0aca0672475488d77c6f71a1b0633f8 osinfopkg 1.0.3 de4e9efeace6ff76dc00a166dca152dc3021d799 osinfopkg 1.0.3 664f0913a5952eeb77373f83e090fab7e94aa45e osinfopkg 1.0.4 bd7ba47f730c2bc33afa67a39d9cbe3768f62426 osinfopkg 1.0.4 0dc723e77a5b97183a90eaecb62c9b7341e483ed ethter 0.9.1b1 6bf76b01bd17f370cd3f9947135bf250597d1ac1 ethter 0.9.1b1 497df2fd2dba324be04cc57f50a3170b532aa70c ethter 1.10.1b1 d404a55f1f7fbcd8b3156a84ebcf97c57ba24b95 ethter 1.10.1b1 9588affaf9d85e2141b9d76b914d9f89a8292574 quantiumbase 0.7.0 dbc14c3ac0528a8aeb6edba8a0b2792dab131102 quantiumbase 0.7.0 0b7b4444f820e9990dfeb5e2080321b5f25a9785 quantiumbase 0.8.1 e6494b9a91862191556d77022e5577ddbe749ef4 quantiumbase 0.8.1 a1b039f88c385f5c5eec2ef1701251c7341b1fcd CONCLUSION These latest examples of malicious packages on the PyPI platform are typical in many ways. They imitate popular and legitimate open source packages with tens of thousands monthly downloads and hide malicious functionality inside Base64 encoded strings which downloads additional commands from a C2 server. The ReversingLabs research team has seen many variations on this attack pattern in recent months. What does this mean for security teams and development organizations? The VMConnect campaign is a reminder that threats lurk on open source repositories, and that standard practices like automated source code reviews are not enough to smoke them out. Source code for the malicious modules published to GitHub was non malicious, but significantly different from the content of the release packages that eventually get compiled into the release artifacts as third party dependencies. Clues that something was amiss — like Base64 encoded strings — were easy to spot, if you know where to look for them. Still, such indicators often escape notice by conventional application security testing and manual code reviews. The ReversingLabs Software Supply Chain Security platform can assist you in security assessments, helping sniff out signs of malicious functionality, assess third party package dependencies, and provide a wide range of behavior indicators. These indicators can be extracted from various file formats and used to detect this type of threat before it results in malicious code being deployed in your environment. Learn about ReversingLabs Software Supply Chain Security, see the three-minute demo — and start a free trial. Who is ReversingLabs? Matt Rose explains. KEEP LEARNING * Supply Chain Risk Report: Learn why you need to upgrade your app sec tools * See Webinar: Deconstructing the 3CX Software Supply Chain Attack * Learn more: SCA tools and how app sec is evolving to tackle supply chain security * Learn how to to harden machine learning models against attacks * Track key trends, what's ahead: The State of Supply Chain Security 2022-23 * Tags: * Threat Research * Software Supply Chain Security * Dev & DevSecOps MORE BLOG ARTICLES Software Supply Chain Security | August 04, 2023 8 Black Hat sessions you don’t want to miss Black Hat USA is a showcase for top security experts and companies. Here's our short list of must-see sessions for 2023. Read More Company & Events | August 03, 2023 ReversingLabs @ Hacker Summer Camp: See you there Every summer, teams congregate in Las Vegas to talk about all things cybersecurity. ReversingLabs has a lot going on. Here’s what we're up to at BSides, Black Hat, and DEF CON. Read More The Week in Security | August 03, 2023 The Week in Security: Malware gives remote access to air-gapped devices, cyber attackers target Italy This week: Hackers use new malware to gain remote access to air-gapped devices. Also: Cybercriminals are using WikiLoader to attack Italian organizations. Read More TOPICS * All Blog Posts * Software Supply Chain Security * Dev & DevSecOps * Threat Research * Security Operations * Products & Technology * Company & Events FOLLOW US * Twitter * Linkedin * Youtube play SUBSCRIBE Get our blog delivered to your in-box weekly to stay up to date on key trends, analysis and best practices across threat intelligence and software supply chain security. Lead source utm_campaign utm_content utm_medium utm_source utm_term SPECIAL REPORTS * Software Supply Chain Security Risk Report: Tooling Gap Leaves Organizations Exposed July 26, 2023 * Secrets Exposed: An Essential Guide to Improving Secrets Security in Software April 18, 2023 * The State of Software Supply Chain Security | Special Report June 27, 2023 * Special Report: The Evolution of Application Security February 14, 2023 Creating the Standard for Supply Chain Risk Conversations About Threat Hunting and Software Supply Chain Security ReversingGlass: Software Supply Chain Security: Vulns & Malware Glassboard conversations with ReversingLabs Field CISO Matt Rose Software Package Deconstruction: Supply Chain Analysis - Part 2: Code Signing Certificates Analyzing Risks To Your Software Supply Chain The Software Supply Chain Security Platform for Dev and SOC Teams Special Report: The State of Software Supply Chain Security * * About Us * Careers * * Contact Us * Events * * In the News * Glossary * * Twitter * LinkedIn * * Facebook * Instagram * * YouTube * RSS All rights reserved ReversingLabs © 2023 | Privacy Policy | Cookies ✖ This website uses cookies to ensure the best website experience. By continuing to use this website you are giving your consent to cookies being used. Detailed information about our use of cookies is here. cookie script