<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:content="http://purl.org/rss/1.0/modules/content/">
  <channel>
    <title>PyPI on Melted in Hex</title>
    <link>https://meltedinhex.com/tags/pypi/</link>
    <description>Recent content in PyPI on Melted in Hex</description>
    <image>
      <title>Melted in Hex</title>
      <url>https://meltedinhex.com/images/og-social.png</url>
      <link>https://meltedinhex.com/images/og-social.png</link>
    </image>
    <generator>Hugo</generator>
    <language>en-us</language>
    <lastBuildDate>Sun, 14 Jun 2026 20:00:00 +0530</lastBuildDate>
    <atom:link href="https://meltedinhex.com/tags/pypi/index.xml" rel="self" type="application/rss+xml" />
    <item>
      <title>Peeling the Sandworm: Reversing the nhmpy PyPI Supply-Chain Worm (Shai-Hulud / Hades Wave)</title>
      <link>https://meltedinhex.com/posts/shai-hulud-nhmpy-pypi/</link>
      <pubDate>Sun, 14 Jun 2026 20:00:00 +0530</pubDate>
      <guid>https://meltedinhex.com/posts/shai-hulud-nhmpy-pypi/</guid>
      <description>&lt;h2 id=&#34;the-short-version&#34;&gt;The short version&lt;/h2&gt;
&lt;p&gt;A package called &lt;code&gt;nhmpy&lt;/code&gt; showed up on PyPI sitting one keystroke away from NumPy (&lt;code&gt;n-h-mpy&lt;/code&gt; instead of &lt;code&gt;n-u-mpy&lt;/code&gt;). It had already been pulled from the index and the wheel was far larger than NumPy has any reason to be, so I pulled the artifact apart to see what it was really doing.&lt;/p&gt;
&lt;p&gt;It turned out to be a credential stealer that goes to real trouble not to look like one. The package carries a complete, working copy of NumPy as cover — install it, &lt;code&gt;import nhmpy&lt;/code&gt;, and it behaves exactly like the library it&amp;rsquo;s impersonating. Nothing breaks, so nothing seems wrong. The malice lives in two extra files: a &lt;code&gt;.pth&lt;/code&gt; file that runs the instant any Python interpreter starts, and a 5.2 MB JavaScript blob it executes through Bun, a runtime it quietly downloads from GitHub at run time.&lt;/p&gt;</description>
    </item>
  </channel>
</rss>
