Learn how to interact with a process and solve the quiz.
Solution
from pwn import*from time import timefrom ctypes import CDLL# Allows you to switch between local/GDB/remote from terminaldefstart(argv=[],*a,**kw):if args.GDB:# Set GDBscript belowreturn gdb.debug([exe] + argv, gdbscript=gdbscript, *a, **kw)elif args.REMOTE:# ('server', 'port')returnremote(sys.argv[1], sys.argv[2], *a, **kw)else:# Run locallyreturnprocess([exe] + argv, *a, **kw)# Specify GDB script here (breakpoints etc)gdbscript ='''init-pwndbgcontinue'''.format(**locals())# Binary filenameexe ='./badseed'# This will automatically get context arch, bits, os etcelf = context.binary =ELF(exe, checksec=False)# Change logging level to help with debugging (warning/info/debug)context.log_level ='debug'# ===========================================================# EXPLOIT GOES HERE# ===========================================================# Start programio =start()# Question 1 - let's do the sumcorrect_answer =int(4000/6.035077)io.sendlineafter('how heavy is an asian elephant on the moon?', str(correct_answer).encode())# Question 2 - first we need to recreate timelibc =CDLL('/lib/x86_64-linux-gnu/libc.so.6')current_time =int(time())libc.srand(current_time)libc.rand()correct_answer = libc.rand()io.sendlineafter('give me the rand() value', str(correct_answer).encode())# Question 3 - need to recreate the equation againcurrent_time =int(time())libc.srand(current_time)rand_a = libc.rand()libc.srand(rand_a)rand_b = libc.rand()correct_answer =int(rand_a / rand_b)%1000io.sendlineafter('no hint this time... you can do it?!', str(correct_answer).encode())# Got Shell?io.interactive()