#!/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)