forked from hexway/apple_bleee
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhashmap_gen.py
57 lines (42 loc) · 1.39 KB
/
hashmap_gen.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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
#!/usr/bin/env python2
# web: https://hexway.io
# Twitter: https://twitter.com/_hexway
#yeah, this is just PoC
from __future__ import print_function
import sys
import hashlib
import psycopg2
if len(sys.argv)!=2:
print("\nUsage:\t",sys.argv[0],"<4-digit phone prefix>")
print("\nEx.:Calculate hashmap for range +12130000000 -- +12139999999:")
print(sys.argv[0],"1213")
print("\n\n");
sys.exit()
prefix = sys.argv[1]
num=int(prefix+"0000000")
stop_num=num+10000000
connection = psycopg2.connect(user="lookup",
password="h3xwayp4ssw0rd", #you can change it if you want
host="127.0.0.1",
port="5432",
database="phones")
cursor = connection.cursor()
postgres_insert_query = """ INSERT INTO map (hash, phone) VALUES (%s, %s)"""
while num < stop_num :
if num % 100000 == 0:
print(100-(stop_num-num)/100000,"% complete")
connection.commit()
strnum = str(num).encode('utf-8')
m = hashlib.sha256()
m.update(strnum)
bhash = m.digest()
strhash = str(bhash).encode()
#print(strhash) #These are optional if you want to see it work
#print(strnum)
record_to_insert = (strhash, num)
#print(record_to_insert)
cursor.execute(postgres_insert_query, record_to_insert)
num +=1
connection.commit()
print("last num:\t", strnum)
print("done!")