Rating:
See here : [https://berryberry.hatenablog.jp/](https://berryberry.hatenablog.jp/entry/2022/03/27/034315)
Opened with Ghidra for the first step.
data:image/s3,"s3://crabby-images/2eac5/2eac5f20a2b5260e7512a83fcce1ccf6427d3a0e" alt=""
This program is similar to the Pascal. You can see that the ivar3 variable is compared with the input number in line 37.
data:image/s3,"s3://crabby-images/13edc/13edc04b8a153754fa06a1be0b03b4f853185951" alt=""
In the function1, it calculates the greatest common divisor of local_20 variable and local_28 variable.
data:image/s3,"s3://crabby-images/ae6fb/ae6fb4a0d3cf3ca807e4a61292182f23fff7da18" alt=""
In the function2, it calculates the factorial of the ivar3 variable plus 3.
The solution is below.
```
import math
from pwn import *
elf = ELF("./decompile", checksec=False)
host = '143.198.224.219'
port = 21530
def func1(num1, num2):
return math.gcd(num1, num2)
def func2(num):
if (num == 0):
return 1
else:
return func2(num-1) * num
r = remote(host, port)
while (True):
# receive two numbers
now = r.recvline()
if (b"fun() took" in now):
break
a, b = map(str, now.decode('utf-8').split())
# send number which does func1 and func2
num = func2(func1(int(a), int(b))+3)
r.sendline(str(num).encode())
print(now.decode('utf-8'))
r.interactive()
```
You can get the FLAG.
data:image/s3,"s3://crabby-images/c853d/c853d4d261f2920ded76098fb6923d9f023b88f4" alt=""