|
@ -61,7 +61,7 @@ def init_wallet(wallet): |
|
|
r = dialog.run() |
|
|
r = dialog.run() |
|
|
passphrase = p_entry.get_text() |
|
|
passphrase = p_entry.get_text() |
|
|
dialog.destroy() |
|
|
dialog.destroy() |
|
|
if r==-6: exit(1) |
|
|
if r==gtk.RESPONSE_CANCEL: exit(1) |
|
|
if len(passphrase) < 20: |
|
|
if len(passphrase) < 20: |
|
|
print len(passphrase) |
|
|
print len(passphrase) |
|
|
passphrase = None |
|
|
passphrase = None |
|
@ -88,7 +88,7 @@ def init_wallet(wallet): |
|
|
thread.start_new_thread( recover_thread, ( wallet, dialog, None ) ) # no password |
|
|
thread.start_new_thread( recover_thread, ( wallet, dialog, None ) ) # no password |
|
|
r = dialog.run() |
|
|
r = dialog.run() |
|
|
dialog.destroy() |
|
|
dialog.destroy() |
|
|
if r==-6: exit(1) |
|
|
if r==gtk.RESPONSE_CANCEL: exit(1) |
|
|
|
|
|
|
|
|
def settings_dialog(wallet, is_recover): |
|
|
def settings_dialog(wallet, is_recover): |
|
|
|
|
|
|
|
@ -96,23 +96,9 @@ def settings_dialog(wallet, is_recover): |
|
|
parent = None, |
|
|
parent = None, |
|
|
flags = gtk.DIALOG_MODAL, |
|
|
flags = gtk.DIALOG_MODAL, |
|
|
buttons = gtk.BUTTONS_OK_CANCEL, |
|
|
buttons = gtk.BUTTONS_OK_CANCEL, |
|
|
message_format = "Please indicate the server, and the gap limit if you are recovering a lost wallet." if is_recover else '' ) |
|
|
message_format = "Please indicate the server, and the gap limit if you are recovering a lost wallet." if is_recover else 'Settings') |
|
|
|
|
|
|
|
|
if not is_recover: |
|
|
dialog.set_default_response(gtk.RESPONSE_OK) |
|
|
dialog.get_image().hide() |
|
|
|
|
|
dialog.set_title("settings") |
|
|
|
|
|
|
|
|
|
|
|
pw = gtk.HBox() |
|
|
|
|
|
if not is_recover: |
|
|
|
|
|
pw_label = gtk.Label('Encryption: ') |
|
|
|
|
|
pw_label.set_size_request(100,10) |
|
|
|
|
|
pw_label.show() |
|
|
|
|
|
pw.pack_start(pw_label,False, False, 10) |
|
|
|
|
|
pw_button = gtk.Button( ('Yes' if wallet.use_encryption else 'No')) |
|
|
|
|
|
pw_button.connect("clicked", change_password_dialog, wallet) |
|
|
|
|
|
pw_button.show() |
|
|
|
|
|
pw.pack_start(pw_button,False, False, 10) |
|
|
|
|
|
pw.show() |
|
|
|
|
|
|
|
|
|
|
|
gap = gtk.HBox() |
|
|
gap = gtk.HBox() |
|
|
gap_label = gtk.Label('Max. gap:') |
|
|
gap_label = gtk.Label('Max. gap:') |
|
@ -154,7 +140,6 @@ def settings_dialog(wallet, is_recover): |
|
|
fee.show() |
|
|
fee.show() |
|
|
|
|
|
|
|
|
vbox = dialog.vbox |
|
|
vbox = dialog.vbox |
|
|
vbox.pack_start(pw, False, False, 5) |
|
|
|
|
|
vbox.pack_start(host, False,False, 5) |
|
|
vbox.pack_start(host, False,False, 5) |
|
|
vbox.pack_start(gap, False,False, 5) |
|
|
vbox.pack_start(gap, False,False, 5) |
|
|
vbox.pack_start(fee, False, False, 5) |
|
|
vbox.pack_start(fee, False, False, 5) |
|
@ -220,11 +205,11 @@ def password_dialog(): |
|
|
dialog.destroy() |
|
|
dialog.destroy() |
|
|
if result: return pw |
|
|
if result: return pw |
|
|
|
|
|
|
|
|
def change_password_dialog(button, wallet): |
|
|
def change_password_dialog(button, wallet, icon): |
|
|
dialog = gtk.MessageDialog( None, gtk.DIALOG_MODAL | gtk.DIALOG_DESTROY_WITH_PARENT, |
|
|
dialog = gtk.MessageDialog( None, gtk.DIALOG_MODAL | gtk.DIALOG_DESTROY_WITH_PARENT, gtk.MESSAGE_QUESTION, gtk.BUTTONS_OK_CANCEL, |
|
|
gtk.MESSAGE_QUESTION, gtk.BUTTONS_OK_CANCEL, 'Change password') |
|
|
'Your wallet is encrypted' if wallet.use_encryption else 'Your wallet is not encrypted') |
|
|
if wallet.use_encryption: |
|
|
if wallet.use_encryption: |
|
|
current_pw, current_pw_entry = password_line('Old password:') |
|
|
current_pw, current_pw_entry = password_line('Current password:') |
|
|
dialog.vbox.pack_start(current_pw, False, True, 0) |
|
|
dialog.vbox.pack_start(current_pw, False, True, 0) |
|
|
|
|
|
|
|
|
password, password_entry = password_line('New password:') |
|
|
password, password_entry = password_line('New password:') |
|
@ -238,14 +223,14 @@ def change_password_dialog(button, wallet): |
|
|
new_password = password_entry.get_text() |
|
|
new_password = password_entry.get_text() |
|
|
new_password2 = password2_entry.get_text() |
|
|
new_password2 = password2_entry.get_text() |
|
|
dialog.destroy() |
|
|
dialog.destroy() |
|
|
if result == 0: |
|
|
if result == gtk.RESPONSE_CANCEL: |
|
|
return |
|
|
return |
|
|
|
|
|
|
|
|
try: |
|
|
try: |
|
|
passphrase = wallet.pw_decode( wallet.passphrase, password) |
|
|
passphrase = wallet.pw_decode( wallet.passphrase, password) |
|
|
private_keys = ast.literal_eval( wallet.pw_decode( wallet.private_keys, password) ) |
|
|
private_keys = ast.literal_eval( wallet.pw_decode( wallet.private_keys, password) ) |
|
|
except: |
|
|
except: |
|
|
show_message("sorry") |
|
|
show_message("Incorrect password") |
|
|
return |
|
|
return |
|
|
|
|
|
|
|
|
if new_password != new_password2: |
|
|
if new_password != new_password2: |
|
@ -256,8 +241,12 @@ def change_password_dialog(button, wallet): |
|
|
wallet.passphrase = wallet.pw_encode( passphrase, new_password) |
|
|
wallet.passphrase = wallet.pw_encode( passphrase, new_password) |
|
|
wallet.private_keys = wallet.pw_encode( repr( private_keys ), new_password) |
|
|
wallet.private_keys = wallet.pw_encode( repr( private_keys ), new_password) |
|
|
wallet.save() |
|
|
wallet.save() |
|
|
if button: |
|
|
|
|
|
button.set_label('Yes' if wallet.use_encryption else 'No') |
|
|
if icon: |
|
|
|
|
|
if wallet.use_encryption: |
|
|
|
|
|
icon.set_tooltip_text('wallet is encrypted') |
|
|
|
|
|
else: |
|
|
|
|
|
icon.set_tooltip_text('wallet is unencrypted') |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def add_help_button(hbox, message): |
|
|
def add_help_button(hbox, message): |
|
@ -310,21 +299,35 @@ class BitcoinGUI: |
|
|
self.status_image.set_from_stock(gtk.STOCK_YES, gtk.ICON_SIZE_MENU) |
|
|
self.status_image.set_from_stock(gtk.STOCK_YES, gtk.ICON_SIZE_MENU) |
|
|
self.status_image.set_alignment(True, 0.5 ) |
|
|
self.status_image.set_alignment(True, 0.5 ) |
|
|
self.status_image.show() |
|
|
self.status_image.show() |
|
|
self.status_bar.pack_end(self.status_image,False,False) |
|
|
self.status_bar.pack_end(self.status_image, False, False) |
|
|
|
|
|
|
|
|
settings_icon = gtk.Image() |
|
|
settings_icon = gtk.Image() |
|
|
settings_icon.set_from_stock(gtk.STOCK_PREFERENCES, gtk.ICON_SIZE_MENU) |
|
|
settings_icon.set_from_stock(gtk.STOCK_PREFERENCES, gtk.ICON_SIZE_MENU) |
|
|
settings_icon.set_alignment(True, False) |
|
|
settings_icon.set_alignment(0.5, 0.5) |
|
|
settings_icon.set_size_request(30,9 ) |
|
|
settings_icon.set_size_request(16,16 ) |
|
|
settings_icon.show() |
|
|
settings_icon.show() |
|
|
|
|
|
|
|
|
prefs_button = gtk.Button() |
|
|
prefs_button = gtk.Button() |
|
|
prefs_button.connect("clicked", run_settings_dialog, self.wallet, False) |
|
|
prefs_button.connect("clicked", run_settings_dialog, self.wallet, False) |
|
|
prefs_button.add(settings_icon) |
|
|
prefs_button.add(settings_icon) |
|
|
prefs_button.set_tooltip_text("Settings") |
|
|
prefs_button.set_tooltip_text("Settings") |
|
|
|
|
|
prefs_button.set_relief(gtk.RELIEF_NONE) |
|
|
prefs_button.show() |
|
|
prefs_button.show() |
|
|
self.status_bar.pack_end(prefs_button,False,False) |
|
|
self.status_bar.pack_end(prefs_button,False,False) |
|
|
|
|
|
|
|
|
|
|
|
pw_icon = gtk.Image() |
|
|
|
|
|
pw_icon.set_from_stock(gtk.STOCK_DIALOG_AUTHENTICATION, gtk.ICON_SIZE_MENU) |
|
|
|
|
|
pw_icon.set_alignment(0.5, 0.5) |
|
|
|
|
|
pw_icon.set_size_request(16,16 ) |
|
|
|
|
|
pw_icon.show() |
|
|
|
|
|
|
|
|
|
|
|
password_button = gtk.Button() |
|
|
|
|
|
password_button.connect("clicked", change_password_dialog, self.wallet, pw_icon) |
|
|
|
|
|
password_button.add(pw_icon) |
|
|
|
|
|
password_button.set_relief(gtk.RELIEF_NONE) |
|
|
|
|
|
password_button.show() |
|
|
|
|
|
self.status_bar.pack_end(password_button,False,False) |
|
|
|
|
|
|
|
|
self.window.add(vbox) |
|
|
self.window.add(vbox) |
|
|
self.window.show_all() |
|
|
self.window.show_all() |
|
|
|
|
|
|
|
|