Your RSA-2048 keys break in 2030. Find every one of them before attackers do.
Malicious package

ggk-happynpm

Malicious code in ggk-happy (npm) Remove it immediately and rotate any exposed credentials.

MAL-2026-4789
Immediate action
Remove the package, then rotate any secrets the build/runtime could reach.
npm uninstall ggk-happy

What this malware does

ggk-happy presents itself as the slopus/happy CLI (Mobile/Web client for Claude Code) — author metadata, homepage (happy.engineering), and repository (github.com/slopus/happy) all point at the legitimate upstream and the README still documents api.cluster-fluster.com as the default server. The shipped code, however, hardcodes different defaults: dist/types-CzmQ1hnz.cjs:174-175 sets DEFAULT_SERVER_URL = "https://happy-api.ask-ggk.com" and DEFAULT_WEBAPP_URL = "https://happy.ask-ggk.com", so any user running the CLI as documented routes every Claude Code session, login/auth flow, and machine metadata to ask-ggk.com instead of the publisher referenced in the README. In addition, at runtime the CLI fetches an opaque rtk binary from https://minio.ask-ggk.com/happy/rtk-<platform>.{zip,tar.gz} (mutable latest-style URL, no checksum or signature verification), writes it to ~/.local/share/ggkhappy/rtk/bin/rtk (or the Windows LOCALAPPDATA equivalent), executes it as rtk gain --all --format json, and POSTs the result together with the user's machineId and auth token to https://guguke.ask-ggk.com/api/v1/agent/rtk/gain/report (dist/index-PJG4KRwn.cjs:5856-5864). The downloaded binary's purpose has no relation to the advertised "Claude Code client" function, the host is not the impersonated publisher, and the same attacker domain mints the auth tokens being reported back. A scripts/postinstall.cjs hook additionally runs node bin/happy.mjs install on global installs, accelerating first contact with the attacker infrastructure. Combined, this is brand impersonation + silent relay of session traffic + runtime fetch-and-execute of an unverified binary from non-publisher infrastructure + exfiltration of host identity and binary output.

Malicious versions

3 flagged
1.0.91.2.01.2.12

Indicators of compromise (SHA-256)

01759f2a020bbf9172f916322b93b5b8bdd3d01ddc2b3130af73763709ec723c
da23474ba170aa6d3b5bea2c2e8ebbc59be022caec4b612528dd644891e31379
2100cce0806532b2cd0d4d94e26b50d2ce769b18c9d5baa28609f3b73b34c500
2a22c29c3d374a49fdb69fb941f2fb81e42b69006b8ed154eba8d365c755b245
667e02b68cd88196d2c42798c03d0470c213cf37212ee5158a1d73750d2b358b
c8481d1ce0252a2b05bc1e11282050aa8754d2dd24ddf51215361edbc6b0cef5

Frequently asked questions

No. ggk-happy on npm has been identified as a malicious package (versions 1.0.9, 1.2.0, 1.2.12 flagged). It should be removed immediately — do not install or keep it in your dependency tree.

Campaign

IN-MAL-2026-004879IN-MAL-2026-004878IN-MAL-2026-006091IN-MAL-2026-006090IN-MAL-2026-006088IN-MAL-2026-006089

References

Credits

  • Amazon Inspector · finder

Scan your dependencies

O3 Security blocks malicious packages like this at install time and in CI.

Supply-chain protection
ggk-happy (npm) malicious package — MAL-2026-4789 | O3 Security