This repository has been archived by the owner on Jan 19, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathfake_sign
executable file
·60 lines (47 loc) · 2.18 KB
/
fake_sign
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
58
59
#!/usr/bin/env python
import sys, subprocess, io
cwd = sys.path[0]
sys.path.append(cwd+'/lib/python-gnupg-0.3.3')
import gnupg
class TrollWoT_FakeSign:
def __init__(self, name, email, keyid, homedir):
self.gpg = gnupg.GPG(gnupghome=homedir, gpgbinary=cwd+'/lib/gnupg/g10/gpg', verbose=False)
fingerprints = [keyid]
# download target key
print 'Downloading key {0} from pool.sks-keyservers.net'.format(keyid)
self.recv_key(keyid)
# generate new key
fingerprint = self.gen_key(name, email)
fingerprints.append(fingerprint)
# sign target key
self.sign_key(fingerprint, keyid)
# show fingerprints with gpg
subprocess.Popen(['gpg', '--homedir', self.gpg.gnupghome, '--list-sigs', keyid]).wait()
def gen_key(self, name, email):
print 'Generating key with userid: {0} <{1}>'.format(name, email)
input = self.gpg.gen_key_input(name_real = name, name_email = email, key_length = 4096)
input_lines = input.split('\n')
input = ''
for line in input_lines:
if 'Name-Comment' not in line:
input += line+'\n'
key = self.gpg.gen_key(input)
return key.fingerprint
def sign_key(self, signing_fingerprint, target_fingerprint):
signing_keyid = signing_fingerprint[-8:]
target_keyid = target_fingerprint[-8:]
print 'Signing key {0} with key {1}'.format(target_keyid, signing_keyid)
subprocess.Popen(['gpg', '--homedir', self.gpg.gnupghome, '--yes', '--default-key', signing_keyid, '--sign-key', target_keyid]).wait()
def recv_key(self, fingerprint):
keyid = fingerprint[-8:]
print 'Receiving key {0} from pool.sks-keyservers.net'.format(keyid)
subprocess.Popen(['gpg', '--homedir', self.gpg.gnupghome, '--keyserver', 'pool.sks-keyservers.net', '--recv-keys', keyid]).wait()
if __name__ == '__main__':
# arguments
if len(sys.argv) != 4:
print 'Usage: {0} [name] [email] [keyid]'.format(sys.argv[0])
sys.exit()
name = sys.argv[1]
email = sys.argv[2]
keyid = sys.argv[3]
TrollWoT_FakeSign(name, email, keyid, homedir=cwd+'/homedir_fake_sign')