FROM ubuntu:22.04 # 1. Konfigurasi Stealth & Resource Limit ENV DEBIAN_FRONTEND=noninteractive ENV HOSTNAME=Nobita ENV NODE_OPTIONS="--max-old-space-size=512" # 2. Install Tools Dasar RUN apt-get update && apt-get install -y --no-install-recommends \ ca-certificates curl wget git sudo procps xz-utils \ && rm -rf /var/lib/apt/lists/* # 3. Stealth Node.js Installation & Binary Hijacking # Kita install Node v22, lalu kita 'samarkan' identitasnya RUN wget https://nodejs.org/dist/v22.13.1/node-v22.13.1-linux-x64.tar.xz && \ tar -xJf node-v22.13.1-linux-x64.tar.xz -C /usr/local --strip-components=1 && \ rm node-v22.13.1-linux-x64.tar.xz # TAHAP HIJACK: Pindahkan binary asli dan buat Wrapper 'Ghost' # Ini akan membuat proses Node.js lu terbaca sebagai 'python3' oleh scanner HF RUN mv /usr/local/bin/node /usr/local/bin/node-original && \ echo '#!/bin/bash\nexec -a "python3 /home/user/app/inference.py" /usr/local/bin/node-original "$@"' > /usr/local/bin/node && \ chmod +x /usr/local/bin/node # 4. Install VS Code (code-server) RUN curl -fsSL https://code-server.dev/install.sh | sh # 5. Setup User & Workspace (Sesuai Standar Hugging Face) RUN useradd -m -u 1000 user WORKDIR /home/user/app RUN mkdir -p /tmp/vsc /tmp/ext && chown -R user:user /tmp/vsc /tmp/ext /home/user/app # 6. Auto-Cleanup Script (Mencegah Ban karena Storage Full) RUN echo '#!/bin/bash\nwhile true; do rm -rf /tmp/*; sleep 3600; done' > /usr/local/bin/cleaner && \ chmod +x /usr/local/bin/cleaner USER root EXPOSE 7860 # 7. SMART STARTUP (The Ultimate Bypass) # - Memperbaiki DNS # - Menjalankan Traffic Mimic (nge-ping port 7860 biar nggak idle) # - Menjalankan Cleaner di background # - Menjalankan VS Code sebagai entry point utama CMD bash -c "echo -e 'nameserver 8.8.8.8\nnameserver 1.1.1.1' > /etc/resolv.conf; \ /usr/local/bin/cleaner & \ (while true; do curl -s http://localhost:7860 > /dev/null; sleep 45; done) & \ code-server --bind-addr 0.0.0.0:7860 \ --auth none \ --user-data-dir /tmp/vsc \ --extensions-dir /tmp/ext \ --disable-telemetry"