blob: bfb941b88c90a9ca8c601b704bdf913ee34ce01a (
plain)
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
|
#!/usr/bin/env python
import re
import rsa
def _logon( username, password ):
# Retrive the public key
# network stuff # req = urllib2.Request(AAA_GET_KEY, headers={'User-Agent': CLIENT_ID})
# network stuff # response = urllib2.urlopen(req)
# network stuff # html = response.read()
# network stuff # print response.info() # DEBUG
# network stuff # print html # DEBUG
# replacement for network stuff #
html="<x509PublicKey>30820122300d06092a864886f70d01010105000382010f003082010a0282010100dad8e3c084137bab285e869ae99a5de9752a095753680e9128adbe981e8141225704e558b8ee437836ec8c5460514efae61550bfdd883549981458bae388c9490b5ab43475068b169b32da446b0aae2dfbb3a5f425c74b284ced3f57ed33b30ec7b4b95a8216f8b063e34af2c84fef58bab381f3b79b80d06b687e0b5fc7aaeb311a88389ab7aa1422ae0b58956bb9e91c5cbf2b98422b05e1eacb82e29938566f6f05274294a8c596677c950ce97dcd003709d008f1ae6418ce5bf55ad2bf921318c6e31b324bdda4b4f12ff1fd86b5b71e647d1fc175aea137ba0ff869d5fbcf9ed0289fe7da3619c1204fc42d616462ac1b6a4e6ca2655d44bce039db519d0203010001</x509PublicKey>"
# end replacement for network stuff #
# This shall pick the key
hexstring = re.compile('<x509PublicKey[^>]*>([0-9a-fA-F]+)</x509PublicKey>')
# pick the key and convert it to der format
hex_pub_der = hexstring.search(html).group(1)
pub_der = hex_pub_der.decode('hex')
# Convert it to a public key
pub_key = rsa.PublicKey.load_pkcs1_openssl_der(pub_der)
# encode the password
enc_pass = rsa.encrypt(password, pub_key)
# and hex-encode it
hex_pass = enc_pass.encode('hex')
# _logon('me', 'MyPass')
import timeit
timeit.timeit('_logon( "me", "MyPass" )',
setup='from __main__ import _logon',
number=1000)
|