<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom">
  <channel>
    <title>node on </title>
    <link>/tags/node/</link>
    <description>Recent content in node on </description>
    <generator>Hugo -- gohugo.io</generator>
    <language>en-us</language>
    <lastBuildDate>Sat, 11 Apr 2026 12:00:00 +0000</lastBuildDate><atom:link href="/tags/node/index.xml" rel="self" type="application/rss+xml" />
    <item>
      <title>FCSC Aquarium [EN]| FCSC 2026</title>
      <link>/writeups/fcsc-aquarium/</link>
      <pubDate>Sat, 11 Apr 2026 12:00:00 +0000</pubDate>
      
      <guid>/writeups/fcsc-aquarium/</guid>
      <description>FCSC Aquarium | FCSC 2026 Challenge The challenge gives us the full source of a Dockerized Node.js web app that serves an animated aquarium page. There is a SUID binary /getflag that reads the flag from /root/flag.txt. Goal is obvious.
Looking at the source Two services run inside the container via supervisord.
The web app (server.mjs) is started with the Node.js permission model:
node --permission --allow-fs-read=/ /usr/app/server.mjs The second one is a messages service (messages.</description>
    </item>
    
  </channel>
</rss>
