Standardizing message format and implementing stderr for errors
[electrum-nvc.git] / upgrade.py
1 import electrum, base64, ast, sys, os
2 from version import SEED_VERSION
3
4 try:
5     from lib import prompt_password
6 except ImportError:
7     from electrum import prompt_password
8
9
10
11
12
13 if __name__ == "__main__":
14     try:
15         path = sys.argv[1]
16     except:
17         # backward compatibility: look for wallet file in the default data directory
18         if "HOME" in os.environ:
19             wallet_dir = os.path.join( os.environ["HOME"], '.electrum')
20         elif "LOCALAPPDATA" in os.environ:
21             wallet_dir = os.path.join( os.environ["LOCALAPPDATA"], 'Electrum' )
22         elif "APPDATA" in os.environ:
23             wallet_dir = os.path.join( os.environ["APPDATA"],  'Electrum' )
24         else:
25             raise BaseException("No home directory found in environment variables.")
26         path = os.path.join( wallet_dir, 'electrum.dat')
27
28     try:
29         f = open(path,"r")
30         data = f.read()
31         f.close()
32     except:
33         sys.stderr.write("Error: File not found: " + path + "\n")
34         sys.stderr.flush()
35         exit(1)
36
37     try:
38         x = ast.literal_eval(data)
39     except:
40         sys.stderr.write("Error: Could not parse wallet\n")
41         sys.stderr.flush()
42         exit(1)
43
44     # version <= 0.33 uses a tuple
45     if type(x) == tuple:
46         seed_version, use_encryption, fee, host, port, blocks, seed, all_addresses, private_keys, change_indexes, status, history, labels, addressbook = x
47
48         print "walet path =",path
49         print "seed version =", seed_version
50
51         if seed_version == 1 and use_encryption:
52             # version 1 used pycrypto for wallet encryption
53             import Crypto
54             from Crypto.Cipher import AES
55             BLOCK_SIZE = 32
56             PADDING = '{'
57             pad = lambda s: s + (BLOCK_SIZE - len(s) % BLOCK_SIZE) * PADDING
58             EncodeAES = lambda secret, s: base64.b64encode(AES.new(secret).encrypt(pad(s)))
59             DecodeAES = lambda secret, e: AES.new(secret).decrypt(base64.b64decode(e)).rstrip(PADDING)
60
61             print "Please enter your password"
62             password = prompt_password("Password:")
63             secret = electrum.Hash(password)
64             try:
65                 seed = DecodeAES( secret, wallet.seed )
66                 private_keys = ast.literal_eval( DecodeAES( secret, wallet.private_keys ) )
67             except:
68                 sys.stderr.write("Error: Password does not decrypt this wallet.\n")
69                 sys.stderr.flush()
70                 exit(1)
71             seed_version = 2
72             s = repr( (seed_version, use_encryption, fee, host, port, blocks, seed, all_addresses, private_keys, change_indexes, status, history, labels, addressbook ))
73             f = open(path,"w")
74             data = f.read()
75             f.close()
76             print "Wallet is now unencrypted."
77
78         print """This wallet is deprecated.
79 Please create a new wallet, open the old wallet with Electrum 0.33, and send your coins to your new wallet.
80 We apologize for the inconvenience. We try to keep this kind of upgrades as rare as possible."""
81
82     
83         
84