DALGLI0/main.py

74 lines
1.7 KiB
Python
Raw Normal View History

2018-06-15 16:17:36 +02:00
def encode(m):
message = format(int.from_bytes(m.encode("latin-1"), "big"), "b")
2018-06-10 22:34:22 +02:00
generator = "10001000000100001"
gen_deg = len(generator)
message += "0" * (gen_deg - 1)
2018-06-15 16:17:36 +02:00
while len(message) % 8 != 0:
2018-06-10 22:34:22 +02:00
message = "0" + message
2018-06-10 22:55:12 +02:00
swapped = list(message)
for i in range(gen_deg - 1):
if swapped[i] == "0":
swapped[i] = "1"
else:
swapped[i] = "0"
message = "".join(swapped)
2018-06-10 22:34:22 +02:00
while True:
if message[0] == "0":
message = message[1:]
else:
chunk = message[:gen_deg]
2018-06-10 22:34:22 +02:00
if len(chunk) < gen_deg:
2018-06-15 16:17:36 +02:00
while len(chunk) % 8 != 0:
chunk = "0" + chunk
return m + chr(int(chunk[:8], 2)) + chr(int(chunk[8:], 2))
2018-06-10 22:34:22 +02:00
remainder = format(int(chunk, 2) ^ int(generator, 2), "b")
message = remainder + message[gen_deg:]
2018-06-15 16:17:36 +02:00
def decode(n):
message = format(int.from_bytes(n.encode("latin-1"), "big"), "b")
generator = "10001000000100001"
gen_deg = len(generator)
while len(message) % 8 != 0:
message = "0" + message
2018-06-15 16:17:36 +02:00
swapped = list(message)
for i in range(gen_deg - 1):
if swapped[i] == "0":
swapped[i] = "1"
else:
swapped[i] = "0"
message = "".join(swapped)
while True:
if '1' not in message:
return True
if message[0] == "0":
message = message[1:]
else:
chunk = message[:gen_deg]
if len(chunk) < gen_deg:
return False
remainder = format(int(chunk, 2) ^ int(generator, 2), "b")
message = remainder + message[gen_deg:]
if __name__ == "__main__":
2018-06-15 16:17:36 +02:00
print()