Back to Home

How I Found a Fake Job Assessment Repo Hiding Malware Inside SVG Files
Like a lot of developers in this market, I’ve been taking freelance assessments and Discord job leads more seriously than I normally would. One of those assessments turned into a malware investigation. One day, I saw a post in a Discord server looking for a fullstack dev. I pitched. The reply...
B
Blizine Admin
·7 min read·0 views
Like a lot of developers in this market, I’ve been taking freelance assessments and Discord job leads more seriously than I normally would.
One of those assessments turned into a malware investigation.
One day, I saw a post in a Discord server looking for a fullstack dev. I pitched. The reply looked routine at first: they DM’d me a requirements PDF for an assessment. I did not trust it, so I asked them to paste the requirements in the chat instead. They sent screenshots of the PDF, and it looked like a real assessment. Clean structure, clear expectations, nothing immediately screaming scam.
Then they invited me to a GitHub repo called E-commerce-template-12d46f3e. My first thought was that the name looked autogenerated, like they were appending random numbers for each assessment. That is when I started treating it like a security review, not a coding exercise.
What I checked first
The first thing I looked at was package.json. I was expecting the usual red flags: weird postinstall hooks, obfuscated scripts, or packages I had never heard of. There was one outdated dependency, @zeit/next-css, but nothing in package.json looked obviously malicious.
That is what made the repo interesting. The dependency list looked boring; the problem was in the application flow.
The suspicious startup path
Next, I looked at the startup scripts.
The dev script ran server.js, and that file did something that immediately raised my guard: it called startLoggingErrors() during server startup.
At first glance, that looked like a harmless logging helper. But when I opened the related files, I found this chain:
server.js starts the server.
lib/serverStartup.js calls eval(...).
lib/startupLogs.js reconstructs a hidden payload from files in public/flags/.
That eval() was the key. A server startup path that reconstructs data from assets and then evaluates them is a hard stop.
The hidden payload in the SVGs
The weirdest part was the assets.
The repository had a bunch of country flag SVG files under public/flags/. Those looked normal until I checked the HTML comments inside them. Each SVG had a comment that looked like a fragment of base64-encoded text.
The loader in lib/startupLogs.js:
Walks through public/flags/
Reads each .svg
Extracts the text inside
Sorts and joins the fragments
Base64-decodes the result
Returns the decoded JavaScript
lib/serverStartup.js feeds that decoded string into eval()
The two lines that made the whole thing click were basically this:
const dir = path.join(process.cwd(), setLogUrl("sxeolf2iodjv"));
eval(log_manager());
That is the bridge between the SVG comments and the executed payload.
So yes, the SVG comments were not decorative. They were a distributed payload. The code was split across many innocent-looking image files so it would not stand out in a quick scan.
I also used Codex as a coding agent to help with the defensive part of the review. Instead of running the suspicious code, I asked it to inspect the repo, trace the startup flow, and deobfuscate the payload safely so I could understand what it did without accidentally executing it. That helped confirm the hidden flow and surfaced additional suspicious paths for a wider audit.
If you want the exact evidence trail, these are the key files:
server.js
lib/serverStartup.js
lib/startupLogs.js
public/flags/*.svg
What the decoded code actually does
Once I reconstructed the payload without executing it, with Codex helping me safely decode and audit the hidden code, the intent was obvious.
It is not just telemetry or error logging. It behaves like a stealer/dropper with persistence.
Part of the reconstructed payload after safely decoding the SVG fragments. I redacted active infrastructure details before publishing.
1. It fingerprints the machine
The payload gathers:
local IPv4 addresses
public IP via api.ipify.org
hostname
OS type and version
user info
a machine/user identifier
whether the machine looks virtualized
That means it profiles the environment before doing anything else.
2. It sends the profile to a remote server
It posts a JSON system profile to a remote endpoint over HTTP.
3. It drops and runs additional files on Windows
On Windows, it downloads executables into AppData and runs them.
It also writes a runjs.vbs file into the Windows Startup folder so the code can persist across reboots.
That is a classic persistence pattern.
4. It hunts for sensitive files
The script recursively scans user paths and drives for files matching patterns like:
.env
.pem
.key
.cer
.secret
.txt
.xlsx
readme.md
.ssh
.aws
.github
That is collection logic, not a developer convenience feature.
5. It targets browser data
It looks for browser profile directories for:
Chrome
Brave
Edge
LT Browser
Then it checks for files such as:
Login Data
Web Data
Local Extension Settings
That is the kind of place malware checks when it wants tokens, cookies, or saved credentials.
6. It targets Sticky Notes
It also checks the Microsoft Sticky Notes storage path on Windows. That is another common place where people accidentally leave sensitive information.
Indicators
I am intentionally redacting the live infrastructure in the public draft.
Redacted base URL: [redacted-host]:[redacted-port]
Observed endpoints:
/system-info
/file-manage
/download/track.js
/download/apps/language_server_x64_x32_windows.exe
/download/apps/assist_language_server_x64_x32_windows.exe
Data sent to /system-info:
OS type, platform, release
hostname
user info
local IP addresses
public IP
machine/user identifier
VM detection flag
Data uploaded to /file-manage:
file contents
filename
path
system identifier
File types and stores targeted locally:
.env, .pem, .key, .cer, .secret, .xlsx
browser profile databases
Microsoft Sticky Notes data
Why this was easy to miss
The repo looked like a regular Next.js storefront at a glance.
The package.json was mostly boring. The app structure looked normal. The assets looked like flags. The malicious code was buried in a runtime path that almost nobody checks unless they are being cautious on purpose.
That is the lesson here: malicious code does not have to live in node_modules, and it does not have to look obviously hostile. Sometimes it hides in the things you think are static content.
What I told myself while reviewing it
I kept repeating one rule: if a codebase wants to run something dynamically at startup, I need to know exactly why.
The moment I saw:
an obfuscated loader
base64 fragments hidden across image assets
eval() on decoded content
network calls to a hardcoded remote host
I stopped treating it like a normal assessment and started treating it like an incident.
What I would advise anyone else to do
If a Discord recruiter or random client sends you a repo:
Check package.json first, but do not stop there.
Inspect the runtime entrypoint, not just the UI code.
Search for eval, new Function, exec, spawn, and startup hooks.
Look inside static assets if the code mentions them.
If the repo uses comments, weird strings, or base64-looking fragments, assume it may be encoded payload data until proven otherwise.
Never run the project on your main machine before you understand the startup path.
Flow Diagram
server.js
↓
lib/serverStartup.js
↓
lib/startupLogs.js
↓
public/flags/*.svg
↓
HTML comment fragments
↓
base64 reconstruction
↓
eval(payload)
Closing thought
I went in expecting a take-home assessment.
What I found was a repo that used a clean-looking frontend as cover for a hidden payload loader. The lesson is simple: when something feels off, slow down and inspect the startup path. That is where malware likes to hide.
If you are job hunting right now, be careful. A polished assessment can still be malicious.
Also, currently open to Fullstack/Backend/AI roles.
Preferably the kind where the SVGs are not assembling malware payloads.
📰Originally published at dev.to
B
Blizine Admin
View Profile Staff Writer