many improvements :

- it is now possible not to save the passphrase for accounts
- close button in accounts window
- unset sensitivity of some widgets in preferences window when some checkboxes are not active
- autoconnect accounts is now available
- apply button in preferences window
This commit is contained in:
Yann Leboulanger 2004-11-01 13:41:00 +00:00
parent 329e35f932
commit 35d2ba75d2
5 changed files with 421 additions and 269 deletions

View File

@ -224,11 +224,13 @@ class GajimCore:
#connexions {con: name, ...} #connexions {con: name, ...}
self.connexions = {} self.connexions = {}
self.gpg = {} self.gpg = {}
self.passwords = {}
if USE_GPG: if USE_GPG:
self.gpg_common = MyGnuPG() self.gpg_common = MyGnuPG()
for a in self.accounts: for a in self.accounts:
self.connected[a] = 0 #0:offline, 1:online, 2:away, self.connected[a] = 0 #0:offline, 1:online, 2:away,
#3:xa, 4:dnd, 5:invisible #3:xa, 4:dnd, 5:invisible
self.passwords[a] = self.cfgParser.tab[a]["password"]
if USE_GPG: if USE_GPG:
self.gpg[a] = MyGnuPG() self.gpg[a] = MyGnuPG()
self.myVCardID = [] self.myVCardID = []
@ -271,7 +273,6 @@ class GajimCore:
'localhost', 'port': 8255, 'modules': 'gtkgui'}} 'localhost', 'port': 8255, 'modules': 'gtkgui'}}
fname = os.path.expanduser(CONFPATH) fname = os.path.expanduser(CONFPATH)
reps = string.split(fname, '/') reps = string.split(fname, '/')
# del reps[0]
path = '' path = ''
while len(reps) > 1: while len(reps) > 1:
path = path + reps[0] + '/' path = path + reps[0] + '/'
@ -482,7 +483,7 @@ class GajimCore:
"""Connect and authentificate to the Jabber server""" """Connect and authentificate to the Jabber server"""
hostname = self.cfgParser.tab[account]["hostname"] hostname = self.cfgParser.tab[account]["hostname"]
name = self.cfgParser.tab[account]["name"] name = self.cfgParser.tab[account]["name"]
password = self.cfgParser.tab[account]["password"] password = self.passwords[account]
ressource = self.cfgParser.tab[account]["ressource"] ressource = self.cfgParser.tab[account]["ressource"]
#create connexion if it doesn't already existe #create connexion if it doesn't already existe
@ -811,7 +812,9 @@ class GajimCore:
#('ACC_CHG', old_account, new_account) #('ACC_CHG', old_account, new_account)
elif ev[0] == 'ACC_CHG': elif ev[0] == 'ACC_CHG':
self.connected[ev[2]] = self.connected[ev[1]] self.connected[ev[2]] = self.connected[ev[1]]
self.passwords[ev[2]] = self.passwords[ev[1]]
del self.connected[ev[1]] del self.connected[ev[1]]
del self.passwords[ev[1]]
if USE_GPG: if USE_GPG:
self.gpg[ev[2]] = self.gpg[ev[1]] self.gpg[ev[2]] = self.gpg[ev[1]]
del self.gpg[ev[1]] del self.gpg[ev[1]]
@ -892,14 +895,16 @@ class GajimCore:
else: else:
con.send(common.jabber.Presence('%s/%s' % (ev[2][1], ev[2][0]), \ con.send(common.jabber.Presence('%s/%s' % (ev[2][1], ev[2][0]), \
'available', show=ev[2][2], status = ev[2][3])) 'available', show=ev[2][2], status = ev[2][3]))
#('PASSPHRASE', account, passphrase) #('GPGPASSPHRASE', account, passphrase)
elif ev[0] == 'PASSPHRASE': elif ev[0] == 'GPGPASSPHRASE':
if USE_GPG: if USE_GPG:
self.gpg[ev[1]].passphrase = ev[2] self.gpg[ev[1]].passphrase = ev[2]
elif ev[0] == 'GPG_SECRETE_KEYS': elif ev[0] == 'GPG_SECRETE_KEYS':
if USE_GPG: if USE_GPG:
keys = self.gpg_common.get_secret_keys() keys = self.gpg_common.get_secret_keys()
self.hub.sendPlugin('GPG_SECRETE_KEYS', ev[1], keys) self.hub.sendPlugin('GPG_SECRETE_KEYS', ev[1], keys)
elif ev[0] == 'PASSPHRASE':
self.passwords[ev[1]] = ev[2]
else: else:
log.debug(_("Unknown Command %s") % ev[0]) log.debug(_("Unknown Command %s") % ev[0])
if self.mode == 'server': if self.mode == 'server':

View File

@ -264,6 +264,10 @@ class preference_Window:
self.write_cfg() self.write_cfg()
self.xml.get_widget('Preferences').destroy() self.xml.get_widget('Preferences').destroy()
def on_apply(self, widget):
"""When Apply button is clicked"""
self.write_cfg()
def change_notebook_page(self, number): def change_notebook_page(self, number):
self.notebook.set_current_page(number) self.notebook.set_current_page(number)
@ -320,6 +324,11 @@ class preference_Window:
name = model.get_value(iter, 0) name = model.get_value(iter, 0)
model.set_value(iter, 1, buf.get_text(first_iter, end_iter)) model.set_value(iter, 1, buf.get_text(first_iter, end_iter))
def on_chk_toggled(self, widget, widgets):
"""set or unset sensitivity of widgets when widget is toggled"""
for w in widgets:
w.set_sensitive(widget.get_active())
def __init__(self, plugin): def __init__(self, plugin):
"""Initialize Preference window""" """Initialize Preference window"""
self.xml = gtk.glade.XML(GTKGUI_GLADE, 'Preferences', APP) self.xml = gtk.glade.XML(GTKGUI_GLADE, 'Preferences', APP)
@ -380,6 +389,7 @@ class preference_Window:
#Autopopupaway #Autopopupaway
st = self.plugin.config['autopopupaway'] st = self.plugin.config['autopopupaway']
self.chk_autoppaway.set_active(st) self.chk_autoppaway.set_active(st)
self.chk_autoppaway.set_sensitive(self.plugin.config['autopopup'])
#Autoaway #Autoaway
st = self.plugin.config['autoaway'] st = self.plugin.config['autoaway']
@ -388,6 +398,7 @@ class preference_Window:
#Autoawaytime #Autoawaytime
st = self.plugin.config['autoawaytime'] st = self.plugin.config['autoawaytime']
self.spin_autoawaytime.set_value(st) self.spin_autoawaytime.set_value(st)
self.spin_autoawaytime.set_sensitive(self.plugin.config['autoaway'])
#Autoxa #Autoxa
st = self.plugin.config['autoxa'] st = self.plugin.config['autoxa']
@ -396,6 +407,7 @@ class preference_Window:
#Autoxatime #Autoxatime
st = self.plugin.config['autoxatime'] st = self.plugin.config['autoxatime']
self.spin_autoxatime.set_value(st) self.spin_autoxatime.set_value(st)
self.spin_autoxatime.set_sensitive(self.plugin.config['autoxa'])
#Status messages #Status messages
self.msg_tree = self.xml.get_widget('msg_treeview') self.msg_tree = self.xml.get_widget('msg_treeview')
@ -461,6 +473,7 @@ class preference_Window:
self.xml.get_widget('fontbutton_user_text').set_font_name(fontStr) self.xml.get_widget('fontbutton_user_text').set_font_name(fontStr)
self.xml.signal_connect('gtk_widget_destroy', self.delete_event) self.xml.signal_connect('gtk_widget_destroy', self.delete_event)
self.xml.signal_connect('on_apply_clicked', self.on_apply)
self.xml.signal_connect('on_ok_clicked', self.on_ok) self.xml.signal_connect('on_ok_clicked', self.on_ok)
self.xml.signal_connect('on_cancel_clicked', self.on_cancel) self.xml.signal_connect('on_cancel_clicked', self.on_cancel)
self.xml.signal_connect('on_msg_treeview_cursor_changed', \ self.xml.signal_connect('on_msg_treeview_cursor_changed', \
@ -469,6 +482,12 @@ class preference_Window:
self.on_new_msg_button_clicked) self.on_new_msg_button_clicked)
self.xml.signal_connect('on_delete_msg_button_clicked', \ self.xml.signal_connect('on_delete_msg_button_clicked', \
self.on_delete_msg_button_clicked) self.on_delete_msg_button_clicked)
self.xml.signal_connect('on_chk_autopopup_toggled', \
self.on_chk_toggled, [self.chk_autoppaway])
self.xml.signal_connect('on_chk_autoaway_toggled', \
self.on_chk_toggled, [self.spin_autoawaytime])
self.xml.signal_connect('on_chk_autoxa_toggled', \
self.on_chk_toggled, [self.spin_autoxatime])
class accountPreference_Window: class accountPreference_Window:
"""Class for account informations""" """Class for account informations"""
@ -489,6 +508,11 @@ class accountPreference_Window:
self.xml.get_widget("entry_name").set_text(infos['accname']) self.xml.get_widget("entry_name").set_text(infos['accname'])
if infos.has_key('jid'): if infos.has_key('jid'):
self.xml.get_widget("entry_jid").set_text(infos['jid']) self.xml.get_widget("entry_jid").set_text(infos['jid'])
if infos.has_key('savepass'):
self.xml.get_widget('chk_password').set_active(\
infos['savepass'])
if infos['savepass']:
self.xml.get_widget('entry_password').set_sensitive(True)
if infos.has_key('password'): if infos.has_key('password'):
self.xml.get_widget("entry_password").set_text(infos['password']) self.xml.get_widget("entry_password").set_text(infos['password'])
if infos.has_key('ressource'): if infos.has_key('ressource'):
@ -519,9 +543,15 @@ class accountPreference_Window:
if infos.has_key('gpgpass'): if infos.has_key('gpgpass'):
self.xml.get_widget('gpg_pass_entry').set_text(\ self.xml.get_widget('gpg_pass_entry').set_text(\
infos['gpgpass']) infos['gpgpass'])
if infos.has_key('autoconnect'):
self.xml.get_widget('chk_autoconnect').set_active(\
infos['autoconnect'])
def on_save_clicked(self, widget): def on_save_clicked(self, widget):
"""When save button is clicked : Save informations in config file""" """When save button is clicked : Save informations in config file"""
savepass = 0
if self.xml.get_widget("chk_password").get_active():
savepass = 1
entryPass = self.xml.get_widget("entry_password") entryPass = self.xml.get_widget("entry_password")
entryRessource = self.xml.get_widget("entry_ressource") entryRessource = self.xml.get_widget("entry_ressource")
entryPriority = self.xml.get_widget("entry_priority") entryPriority = self.xml.get_widget("entry_priority")
@ -529,6 +559,9 @@ class accountPreference_Window:
check = self.xml.get_widget("checkbutton") check = self.xml.get_widget("checkbutton")
entryName = self.xml.get_widget("entry_name") entryName = self.xml.get_widget("entry_name")
entryJid = self.xml.get_widget("entry_jid") entryJid = self.xml.get_widget("entry_jid")
autoconnect = 0
if self.xml.get_widget("chk_autoconnect").get_active():
autoconnect = 1
checkProxy = self.xml.get_widget("checkbutton_proxy") checkProxy = self.xml.get_widget("checkbutton_proxy")
if checkProxy.get_active(): if checkProxy.get_active():
useProxy = 1 useProxy = 1
@ -598,11 +631,12 @@ class accountPreference_Window:
del self.plugin.accounts[self.account] del self.plugin.accounts[self.account]
self.plugin.send('ACC_CHG', self.account, name) self.plugin.send('ACC_CHG', self.account, name)
self.plugin.accounts[name] = {'name': login, 'hostname': hostname,\ self.plugin.accounts[name] = {'name': login, 'hostname': hostname,\
'password': entryPass.get_text(), 'ressource': \ 'savepass': savepass, 'password': entryPass.get_text(), \
entryRessource.get_text(), 'priority' : prio, 'use_proxy': \ 'ressource': entryRessource.get_text(), 'priority' : prio, \
useProxy, 'proxyhost': entryProxyhost.get_text(), 'proxyport': \ 'autoconnect': autoconnect, 'use_proxy': useProxy, 'proxyhost': \
proxyPort, 'keyid': keyID, 'keyname': keyName, 'savegpgpass': \ entryProxyhost.get_text(), 'proxyport': proxyPort, 'keyid': keyID, \
save_gpg_pass, 'gpgpass': gpg_pass} 'keyname': keyName, 'savegpgpass': save_gpg_pass, \
'gpgpass': gpg_pass}
self.plugin.send('CONFIG', None, ('accounts', self.plugin.accounts)) self.plugin.send('CONFIG', None, ('accounts', self.plugin.accounts))
#refresh accounts window #refresh accounts window
if self.plugin.windows.has_key('accounts'): if self.plugin.windows.has_key('accounts'):
@ -623,11 +657,11 @@ class accountPreference_Window:
check.set_active(FALSE) check.set_active(FALSE)
return return
self.plugin.accounts[name] = {'name': login, 'hostname': hostname,\ self.plugin.accounts[name] = {'name': login, 'hostname': hostname,\
'password': entryPass.get_text(), 'ressource': \ 'savepass': savepass, 'password': entryPass.get_text(), 'ressource': \
entryRessource.get_text(), 'priority' : prio, 'use_proxy': useProxy, \ entryRessource.get_text(), 'priority' : prio, 'autoconnect': \
'proxyhost': entryProxyhost.get_text(), 'proxyport': proxyPort, \ autoconnect, 'use_proxy': useProxy, 'proxyhost': \
'keyid': keyID, 'keyname': keyName, 'savegpgpass': save_gpg_pass, \ entryProxyhost.get_text(), 'proxyport': proxyPort, 'keyid': keyID, \
'gpgpass': gpg_pass} 'keyname': keyName, 'savegpgpass': save_gpg_pass, 'gpgpass': gpg_pass}
self.plugin.send('CONFIG', None, ('accounts', self.plugin.accounts)) self.plugin.send('CONFIG', None, ('accounts', self.plugin.accounts))
#update variables #update variables
self.plugin.windows[name] = {'infos': {}, 'chats': {}, 'gc': {}} self.plugin.windows[name] = {'infos': {}, 'chats': {}, 'gc': {}}
@ -673,12 +707,16 @@ class accountPreference_Window:
self.xml.get_widget('gpg_pass_checkbutton').set_active(False) self.xml.get_widget('gpg_pass_checkbutton').set_active(False)
self.xml.get_widget('gpg_pass_entry').set_text('') self.xml.get_widget('gpg_pass_entry').set_text('')
def on_gpg_pass_checkbutton_toggled(self, widget, data=None): def on_chk_toggled(self, widget, widgets):
if self.xml.get_widget('gpg_pass_checkbutton').get_active(): """set or unset sensitivity of widgets when widget is toggled"""
self.xml.get_widget('gpg_pass_entry').set_sensitive(True) for w in widgets:
else: w.set_sensitive(widget.get_active())
self.xml.get_widget('gpg_pass_entry').set_sensitive(False)
self.xml.get_widget('gpg_pass_entry').set_text('') def on_chk_toggled_and_clear(self, widget, widgets):
self.on_chk_toggled(widget, widgets)
for w in widgets:
if not widget.get_active():
w.set_text('')
#info must be a dictionnary #info must be a dictionnary
def __init__(self, plugin, infos = {}): def __init__(self, plugin, infos = {}):
@ -691,6 +729,7 @@ class accountPreference_Window:
self.xml.get_widget('gpg_name_label').set_text('') self.xml.get_widget('gpg_name_label').set_text('')
self.xml.get_widget('gpg_pass_checkbutton').set_sensitive(False) self.xml.get_widget('gpg_pass_checkbutton').set_sensitive(False)
self.xml.get_widget('gpg_pass_entry').set_sensitive(False) self.xml.get_widget('gpg_pass_entry').set_sensitive(False)
self.xml.get_widget('entry_password').set_sensitive(False)
if infos: if infos:
self.modify = True self.modify = True
self.account = infos['accname'] self.account = infos['accname']
@ -703,7 +742,9 @@ class accountPreference_Window:
self.xml.signal_connect('on_close_clicked', self.on_close) self.xml.signal_connect('on_close_clicked', self.on_close)
self.xml.signal_connect('on_choose_gpg_clicked', self.on_choose_gpg) self.xml.signal_connect('on_choose_gpg_clicked', self.on_choose_gpg)
self.xml.signal_connect('on_gpg_pass_checkbutton_toggled', \ self.xml.signal_connect('on_gpg_pass_checkbutton_toggled', \
self.on_gpg_pass_checkbutton_toggled) self.on_chk_toggled_and_clear, [self.xml.get_widget('gpg_pass_entry')])
self.xml.signal_connect('on_pass_checkbutton_toggled', \
self.on_chk_toggled_and_clear, [self.xml.get_widget('entry_password')])
class accounts_Window: class accounts_Window:
"""Class for accounts window : lists of accounts""" """Class for accounts window : lists of accounts"""
@ -711,10 +752,9 @@ class accounts_Window:
"""close window""" """close window"""
del self.plugin.windows['accounts'] del self.plugin.windows['accounts']
#Not for the moment ... but maybe one day there will be a button def on_close(self, widget):
# def on_close(self, widget): """When Close button is clicked"""
# """When Close button is clicked""" widget.get_toplevel().destroy()
# widget.get_toplevel().destroy()
def init_accounts(self): def init_accounts(self):
"""initialize listStore with existing accounts""" """initialize listStore with existing accounts"""
@ -810,6 +850,7 @@ class accounts_Window:
self.xml.signal_connect('on_new_clicked', self.on_new_clicked) self.xml.signal_connect('on_new_clicked', self.on_new_clicked)
self.xml.signal_connect('on_delete_clicked', self.on_delete_clicked) self.xml.signal_connect('on_delete_clicked', self.on_delete_clicked)
self.xml.signal_connect('on_modify_clicked', self.on_modify_clicked) self.xml.signal_connect('on_modify_clicked', self.on_modify_clicked)
self.xml.signal_connect('on_close_clicked', self.on_close)
self.init_accounts() self.init_accounts()

View File

@ -200,9 +200,10 @@ class passphrase_Window:
if event.keyval == gtk.keysyms.Return: if event.keyval == gtk.keysyms.Return:
self.xml.get_widget("Passphrase").response(gtk.RESPONSE_OK) self.xml.get_widget("Passphrase").response(gtk.RESPONSE_OK)
def __init__(self): def __init__(self, txt):
self.xml = gtk.glade.XML(GTKGUI_GLADE, 'Passphrase', APP) self.xml = gtk.glade.XML(GTKGUI_GLADE, 'Passphrase', APP)
self.entry = self.xml.get_widget("entry") self.entry = self.xml.get_widget("entry")
self.xml.get_widget("label").set_text(txt)
self.xml.signal_connect('on_Passphrase_key_press_event', \ self.xml.signal_connect('on_Passphrase_key_press_event', \
self.on_key_pressed) self.on_key_pressed)

View File

@ -693,57 +693,49 @@
<property name="right_padding">0</property> <property name="right_padding">0</property>
<child> <child>
<widget class="GtkHBox" id="hbox2"> <widget class="GtkHButtonBox" id="hbuttonbox15">
<property name="border_width">5</property>
<property name="visible">True</property> <property name="visible">True</property>
<property name="homogeneous">False</property> <property name="layout_style">GTK_BUTTONBOX_END</property>
<property name="spacing">20</property> <property name="spacing">7</property>
<child> <child>
<widget class="GtkButton" id="new_button"> <widget class="GtkButton" id="new_button">
<property name="visible">True</property> <property name="visible">True</property>
<property name="can_default">True</property>
<property name="can_focus">True</property> <property name="can_focus">True</property>
<property name="label">gtk-new</property> <property name="label">gtk-new</property>
<property name="use_stock">True</property> <property name="use_stock">True</property>
<property name="relief">GTK_RELIEF_NORMAL</property> <property name="relief">GTK_RELIEF_NORMAL</property>
<property name="focus_on_click">True</property> <property name="focus_on_click">True</property>
<signal name="clicked" handler="on_new_clicked" last_modification_time="Thu, 11 Dec 2003 17:06:22 GMT"/> <signal name="clicked" handler="on_new_clicked" last_modification_time="Thu, 28 Oct 2004 11:35:22 GMT"/>
</widget> </widget>
<packing>
<property name="padding">0</property>
<property name="expand">False</property>
<property name="fill">False</property>
</packing>
</child> </child>
<child> <child>
<widget class="GtkButton" id="delete_button"> <widget class="GtkButton" id="delete_button">
<property name="visible">True</property> <property name="visible">True</property>
<property name="sensitive">False</property> <property name="can_default">True</property>
<property name="can_focus">True</property> <property name="can_focus">True</property>
<property name="label">gtk-delete</property> <property name="label">gtk-delete</property>
<property name="use_stock">True</property> <property name="use_stock">True</property>
<property name="relief">GTK_RELIEF_NORMAL</property> <property name="relief">GTK_RELIEF_NORMAL</property>
<property name="focus_on_click">True</property> <property name="focus_on_click">True</property>
<signal name="clicked" handler="on_delete_clicked" last_modification_time="Thu, 11 Dec 2003 17:06:43 GMT"/> <signal name="clicked" handler="on_delete_clicked" last_modification_time="Thu, 28 Oct 2004 13:36:37 GMT"/>
</widget> </widget>
<packing>
<property name="padding">0</property>
<property name="expand">False</property>
<property name="fill">False</property>
</packing>
</child> </child>
<child> <child>
<widget class="GtkButton" id="modify_button"> <widget class="GtkButton" id="modify_button">
<property name="visible">True</property> <property name="visible">True</property>
<property name="sensitive">False</property> <property name="can_default">True</property>
<property name="can_focus">True</property> <property name="can_focus">True</property>
<property name="relief">GTK_RELIEF_NORMAL</property> <property name="relief">GTK_RELIEF_NORMAL</property>
<property name="focus_on_click">True</property> <property name="focus_on_click">True</property>
<signal name="clicked" handler="on_modify_clicked" last_modification_time="Thu, 11 Dec 2003 17:07:02 GMT"/> <signal name="clicked" handler="on_modify_clicked" last_modification_time="Thu, 28 Oct 2004 13:36:59 GMT"/>
<child> <child>
<widget class="GtkAlignment" id="alignment1"> <widget class="GtkAlignment" id="alignment30">
<property name="visible">True</property> <property name="visible">True</property>
<property name="xalign">0.5</property> <property name="xalign">0.5</property>
<property name="yalign">0.5</property> <property name="yalign">0.5</property>
@ -755,13 +747,13 @@
<property name="right_padding">0</property> <property name="right_padding">0</property>
<child> <child>
<widget class="GtkHBox" id="hbox3"> <widget class="GtkHBox" id="hbox45">
<property name="visible">True</property> <property name="visible">True</property>
<property name="homogeneous">False</property> <property name="homogeneous">False</property>
<property name="spacing">2</property> <property name="spacing">2</property>
<child> <child>
<widget class="GtkImage" id="image1"> <widget class="GtkImage" id="image172">
<property name="visible">True</property> <property name="visible">True</property>
<property name="stock">gtk-refresh</property> <property name="stock">gtk-refresh</property>
<property name="icon_size">4</property> <property name="icon_size">4</property>
@ -778,7 +770,7 @@
</child> </child>
<child> <child>
<widget class="GtkLabel" id="label1"> <widget class="GtkLabel" id="label167">
<property name="visible">True</property> <property name="visible">True</property>
<property name="label" translatable="yes">_Modify</property> <property name="label" translatable="yes">_Modify</property>
<property name="use_underline">True</property> <property name="use_underline">True</property>
@ -802,11 +794,19 @@
</widget> </widget>
</child> </child>
</widget> </widget>
<packing> </child>
<property name="padding">0</property>
<property name="expand">False</property> <child>
<property name="fill">False</property> <widget class="GtkButton" id="close_button">
</packing> <property name="visible">True</property>
<property name="can_default">True</property>
<property name="can_focus">True</property>
<property name="label">gtk-close</property>
<property name="use_stock">True</property>
<property name="relief">GTK_RELIEF_NORMAL</property>
<property name="focus_on_click">True</property>
<signal name="clicked" handler="on_close_clicked" last_modification_time="Thu, 28 Oct 2004 11:36:49 GMT"/>
</widget>
</child> </child>
</widget> </widget>
</child> </child>
@ -867,7 +867,7 @@
<child> <child>
<widget class="GtkLabel" id="label2"> <widget class="GtkLabel" id="label2">
<property name="visible">True</property> <property name="visible">True</property>
<property name="label" translatable="yes">&lt;b&gt;Gajim&lt;/b&gt; <property name="label" translatable="yes">&lt;b&gt;Gajim&lt;/b&gt; (http://www.gajim.org)
Copyright © 2003-2004 Gajim Team Copyright © 2003-2004 Gajim Team
@ -1064,30 +1064,6 @@ Yann Le Boulanger (asterix@crans.org)</property>
</packing> </packing>
</child> </child>
<child>
<widget class="GtkLabel" id="label10">
<property name="visible">True</property>
<property name="label" translatable="yes">Password:</property>
<property name="use_underline">False</property>
<property name="use_markup">False</property>
<property name="justify">GTK_JUSTIFY_LEFT</property>
<property name="wrap">False</property>
<property name="selectable">False</property>
<property name="xalign">0</property>
<property name="yalign">0.5</property>
<property name="xpad">0</property>
<property name="ypad">0</property>
</widget>
<packing>
<property name="left_attach">0</property>
<property name="right_attach">1</property>
<property name="top_attach">2</property>
<property name="bottom_attach">3</property>
<property name="x_options">fill</property>
<property name="y_options"></property>
</packing>
</child>
<child> <child>
<widget class="GtkLabel" id="label9"> <widget class="GtkLabel" id="label9">
<property name="visible">True</property> <property name="visible">True</property>
@ -1242,6 +1218,29 @@ Yann Le Boulanger (asterix@crans.org)</property>
<property name="y_options"></property> <property name="y_options"></property>
</packing> </packing>
</child> </child>
<child>
<widget class="GtkCheckButton" id="chk_password">
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="label" translatable="yes">Save password</property>
<property name="use_underline">True</property>
<property name="relief">GTK_RELIEF_NORMAL</property>
<property name="focus_on_click">True</property>
<property name="active">False</property>
<property name="inconsistent">False</property>
<property name="draw_indicator">True</property>
<signal name="toggled" handler="on_pass_checkbutton_toggled" last_modification_time="Thu, 28 Oct 2004 13:45:57 GMT"/>
</widget>
<packing>
<property name="left_attach">0</property>
<property name="right_attach">1</property>
<property name="top_attach">2</property>
<property name="bottom_attach">3</property>
<property name="x_options">fill</property>
<property name="y_options"></property>
</packing>
</child>
</widget> </widget>
<packing> <packing>
<property name="tab_expand">False</property> <property name="tab_expand">False</property>
@ -1300,11 +1299,69 @@ Yann Le Boulanger (asterix@crans.org)</property>
</child> </child>
<child> <child>
<widget class="GtkLabel" id="label13"> <widget class="GtkVBox" id="vbox37">
<property name="visible">True</property> <property name="visible">True</property>
<property name="label" translatable="yes">Empty</property> <property name="homogeneous">False</property>
<property name="spacing">0</property>
<child>
<widget class="GtkFrame" id="frame19">
<property name="visible">True</property>
<property name="label_xalign">0</property>
<property name="label_yalign">0.5</property>
<property name="shadow_type">GTK_SHADOW_ETCHED_IN</property>
<child>
<widget class="GtkAlignment" id="alignment31">
<property name="visible">True</property>
<property name="xalign">0.5</property>
<property name="yalign">0.5</property>
<property name="xscale">1</property>
<property name="yscale">1</property>
<property name="top_padding">0</property>
<property name="bottom_padding">0</property>
<property name="left_padding">12</property>
<property name="right_padding">0</property>
<child>
<widget class="GtkVBox" id="vbox38">
<property name="visible">True</property>
<property name="homogeneous">False</property>
<property name="spacing">0</property>
<child>
<widget class="GtkCheckButton" id="chk_autoconnect">
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="label" translatable="yes">Connect at startup</property>
<property name="use_underline">True</property>
<property name="relief">GTK_RELIEF_NORMAL</property>
<property name="focus_on_click">True</property>
<property name="active">False</property>
<property name="inconsistent">False</property>
<property name="draw_indicator">True</property>
</widget>
<packing>
<property name="padding">0</property>
<property name="expand">False</property>
<property name="fill">False</property>
</packing>
</child>
<child>
<placeholder/>
</child>
</widget>
</child>
</widget>
</child>
<child>
<widget class="GtkLabel" id="label168">
<property name="visible">True</property>
<property name="label" translatable="yes">&lt;b&gt;Startup&lt;/b&gt;</property>
<property name="use_underline">False</property> <property name="use_underline">False</property>
<property name="use_markup">False</property> <property name="use_markup">True</property>
<property name="justify">GTK_JUSTIFY_LEFT</property> <property name="justify">GTK_JUSTIFY_LEFT</property>
<property name="wrap">False</property> <property name="wrap">False</property>
<property name="selectable">False</property> <property name="selectable">False</property>
@ -1313,6 +1370,22 @@ Yann Le Boulanger (asterix@crans.org)</property>
<property name="xpad">0</property> <property name="xpad">0</property>
<property name="ypad">0</property> <property name="ypad">0</property>
</widget> </widget>
<packing>
<property name="type">label_item</property>
</packing>
</child>
</widget>
<packing>
<property name="padding">0</property>
<property name="expand">True</property>
<property name="fill">True</property>
</packing>
</child>
<child>
<placeholder/>
</child>
</widget>
<packing> <packing>
<property name="tab_expand">False</property> <property name="tab_expand">False</property>
<property name="tab_fill">True</property> <property name="tab_fill">True</property>
@ -3938,180 +4011,6 @@ on the server.</property>
</packing> </packing>
</child> </child>
<child>
<widget class="GtkFrame" id="frame8">
<property name="width_request">180</property>
<property name="height_request">165</property>
<property name="visible">True</property>
<property name="label_xalign">0</property>
<property name="label_yalign">0.5</property>
<property name="shadow_type">GTK_SHADOW_ETCHED_IN</property>
<child>
<widget class="GtkTable" id="table5">
<property name="visible">True</property>
<property name="n_rows">3</property>
<property name="n_columns">2</property>
<property name="homogeneous">False</property>
<property name="row_spacing">10</property>
<property name="column_spacing">3</property>
<child>
<widget class="GtkLabel" id="label70">
<property name="width_request">100</property>
<property name="visible">True</property>
<property name="label" translatable="yes">Outgoing Messages</property>
<property name="use_underline">False</property>
<property name="use_markup">False</property>
<property name="justify">GTK_JUSTIFY_CENTER</property>
<property name="wrap">True</property>
<property name="selectable">False</property>
<property name="xalign">0</property>
<property name="yalign">0.5</property>
<property name="xpad">0</property>
<property name="ypad">0</property>
</widget>
<packing>
<property name="left_attach">0</property>
<property name="right_attach">1</property>
<property name="top_attach">1</property>
<property name="bottom_attach">2</property>
<property name="x_options">fill</property>
<property name="y_options"></property>
</packing>
</child>
<child>
<widget class="GtkLabel" id="label71">
<property name="width_request">100</property>
<property name="visible">True</property>
<property name="label" translatable="yes">Status Messages</property>
<property name="use_underline">False</property>
<property name="use_markup">False</property>
<property name="justify">GTK_JUSTIFY_CENTER</property>
<property name="wrap">True</property>
<property name="selectable">False</property>
<property name="xalign">0</property>
<property name="yalign">0.5</property>
<property name="xpad">0</property>
<property name="ypad">0</property>
</widget>
<packing>
<property name="left_attach">0</property>
<property name="right_attach">1</property>
<property name="top_attach">2</property>
<property name="bottom_attach">3</property>
<property name="x_options">fill</property>
<property name="y_options"></property>
</packing>
</child>
<child>
<widget class="GtkLabel" id="label72">
<property name="width_request">100</property>
<property name="visible">True</property>
<property name="label" translatable="yes">Incoming Messages</property>
<property name="use_underline">False</property>
<property name="use_markup">False</property>
<property name="justify">GTK_JUSTIFY_CENTER</property>
<property name="wrap">True</property>
<property name="selectable">False</property>
<property name="xalign">0</property>
<property name="yalign">0.5</property>
<property name="xpad">0</property>
<property name="ypad">0</property>
</widget>
<packing>
<property name="left_attach">0</property>
<property name="right_attach">1</property>
<property name="top_attach">0</property>
<property name="bottom_attach">1</property>
<property name="x_options">fill</property>
<property name="y_options"></property>
</packing>
</child>
<child>
<widget class="GtkColorButton" id="colorbutton_in">
<property name="visible">True</property>
<property name="can_default">True</property>
<property name="has_default">True</property>
<property name="can_focus">True</property>
<property name="has_focus">True</property>
<property name="use_alpha">False</property>
<property name="focus_on_click">True</property>
</widget>
<packing>
<property name="left_attach">1</property>
<property name="right_attach">2</property>
<property name="top_attach">0</property>
<property name="bottom_attach">1</property>
<property name="x_options">fill</property>
<property name="y_options"></property>
</packing>
</child>
<child>
<widget class="GtkColorButton" id="colorbutton_out">
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="use_alpha">False</property>
<property name="focus_on_click">True</property>
</widget>
<packing>
<property name="left_attach">1</property>
<property name="right_attach">2</property>
<property name="top_attach">1</property>
<property name="bottom_attach">2</property>
<property name="x_options">fill</property>
<property name="y_options"></property>
</packing>
</child>
<child>
<widget class="GtkColorButton" id="colorbutton_status">
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="use_alpha">False</property>
<property name="focus_on_click">True</property>
</widget>
<packing>
<property name="left_attach">1</property>
<property name="right_attach">2</property>
<property name="top_attach">2</property>
<property name="bottom_attach">3</property>
<property name="x_options">fill</property>
<property name="y_options"></property>
</packing>
</child>
</widget>
</child>
<child>
<widget class="GtkLabel" id="label73">
<property name="visible">True</property>
<property name="label" translatable="yes">&lt;b&gt;Color&lt;/b&gt;</property>
<property name="use_underline">False</property>
<property name="use_markup">True</property>
<property name="justify">GTK_JUSTIFY_LEFT</property>
<property name="wrap">False</property>
<property name="selectable">False</property>
<property name="xalign">0.5</property>
<property name="yalign">0.5</property>
<property name="xpad">0</property>
<property name="ypad">0</property>
</widget>
<packing>
<property name="type">label_item</property>
</packing>
</child>
</widget>
<packing>
<property name="x">0</property>
<property name="y">0</property>
</packing>
</child>
<child> <child>
<widget class="GtkFrame" id="frame7"> <widget class="GtkFrame" id="frame7">
<property name="width_request">145</property> <property name="width_request">145</property>
@ -4287,6 +4186,180 @@ position</property>
<property name="y">103</property> <property name="y">103</property>
</packing> </packing>
</child> </child>
<child>
<widget class="GtkFrame" id="frame8">
<property name="width_request">180</property>
<property name="height_request">165</property>
<property name="visible">True</property>
<property name="label_xalign">0</property>
<property name="label_yalign">0.5</property>
<property name="shadow_type">GTK_SHADOW_ETCHED_IN</property>
<child>
<widget class="GtkTable" id="table5">
<property name="visible">True</property>
<property name="n_rows">3</property>
<property name="n_columns">2</property>
<property name="homogeneous">False</property>
<property name="row_spacing">10</property>
<property name="column_spacing">3</property>
<child>
<widget class="GtkLabel" id="label70">
<property name="width_request">100</property>
<property name="visible">True</property>
<property name="label" translatable="yes">Outgoing Messages</property>
<property name="use_underline">False</property>
<property name="use_markup">False</property>
<property name="justify">GTK_JUSTIFY_CENTER</property>
<property name="wrap">True</property>
<property name="selectable">False</property>
<property name="xalign">0</property>
<property name="yalign">0.5</property>
<property name="xpad">0</property>
<property name="ypad">0</property>
</widget>
<packing>
<property name="left_attach">0</property>
<property name="right_attach">1</property>
<property name="top_attach">1</property>
<property name="bottom_attach">2</property>
<property name="x_options">fill</property>
<property name="y_options"></property>
</packing>
</child>
<child>
<widget class="GtkLabel" id="label71">
<property name="width_request">100</property>
<property name="visible">True</property>
<property name="label" translatable="yes">Status Messages</property>
<property name="use_underline">False</property>
<property name="use_markup">False</property>
<property name="justify">GTK_JUSTIFY_CENTER</property>
<property name="wrap">True</property>
<property name="selectable">False</property>
<property name="xalign">0</property>
<property name="yalign">0.5</property>
<property name="xpad">0</property>
<property name="ypad">0</property>
</widget>
<packing>
<property name="left_attach">0</property>
<property name="right_attach">1</property>
<property name="top_attach">2</property>
<property name="bottom_attach">3</property>
<property name="x_options">fill</property>
<property name="y_options"></property>
</packing>
</child>
<child>
<widget class="GtkLabel" id="label72">
<property name="width_request">100</property>
<property name="visible">True</property>
<property name="label" translatable="yes">Incoming Messages</property>
<property name="use_underline">False</property>
<property name="use_markup">False</property>
<property name="justify">GTK_JUSTIFY_CENTER</property>
<property name="wrap">True</property>
<property name="selectable">False</property>
<property name="xalign">0</property>
<property name="yalign">0.5</property>
<property name="xpad">0</property>
<property name="ypad">0</property>
</widget>
<packing>
<property name="left_attach">0</property>
<property name="right_attach">1</property>
<property name="top_attach">0</property>
<property name="bottom_attach">1</property>
<property name="x_options">fill</property>
<property name="y_options"></property>
</packing>
</child>
<child>
<widget class="GtkColorButton" id="colorbutton_in">
<property name="visible">True</property>
<property name="can_default">True</property>
<property name="has_default">True</property>
<property name="can_focus">True</property>
<property name="has_focus">True</property>
<property name="use_alpha">False</property>
<property name="focus_on_click">True</property>
</widget>
<packing>
<property name="left_attach">1</property>
<property name="right_attach">2</property>
<property name="top_attach">0</property>
<property name="bottom_attach">1</property>
<property name="x_options">fill</property>
<property name="y_options"></property>
</packing>
</child>
<child>
<widget class="GtkColorButton" id="colorbutton_out">
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="use_alpha">False</property>
<property name="focus_on_click">True</property>
</widget>
<packing>
<property name="left_attach">1</property>
<property name="right_attach">2</property>
<property name="top_attach">1</property>
<property name="bottom_attach">2</property>
<property name="x_options">fill</property>
<property name="y_options"></property>
</packing>
</child>
<child>
<widget class="GtkColorButton" id="colorbutton_status">
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="use_alpha">False</property>
<property name="focus_on_click">True</property>
</widget>
<packing>
<property name="left_attach">1</property>
<property name="right_attach">2</property>
<property name="top_attach">2</property>
<property name="bottom_attach">3</property>
<property name="x_options">fill</property>
<property name="y_options"></property>
</packing>
</child>
</widget>
</child>
<child>
<widget class="GtkLabel" id="label73">
<property name="visible">True</property>
<property name="label" translatable="yes">&lt;b&gt;Color&lt;/b&gt;</property>
<property name="use_underline">False</property>
<property name="use_markup">True</property>
<property name="justify">GTK_JUSTIFY_LEFT</property>
<property name="wrap">False</property>
<property name="selectable">False</property>
<property name="xalign">0.5</property>
<property name="yalign">0.5</property>
<property name="xpad">0</property>
<property name="ypad">0</property>
</widget>
<packing>
<property name="type">label_item</property>
</packing>
</child>
</widget>
<packing>
<property name="x">0</property>
<property name="y">0</property>
</packing>
</child>
</widget> </widget>
<packing> <packing>
<property name="tab_expand">False</property> <property name="tab_expand">False</property>
@ -4344,6 +4417,7 @@ messages</property>
<property name="active">False</property> <property name="active">False</property>
<property name="inconsistent">False</property> <property name="inconsistent">False</property>
<property name="draw_indicator">True</property> <property name="draw_indicator">True</property>
<signal name="toggled" handler="on_chk_autopopup_toggled" last_modification_time="Thu, 28 Oct 2004 11:01:25 GMT"/>
</widget> </widget>
<packing> <packing>
<property name="padding">0</property> <property name="padding">0</property>
@ -4457,6 +4531,7 @@ when NOT online</property>
<property name="active">False</property> <property name="active">False</property>
<property name="inconsistent">False</property> <property name="inconsistent">False</property>
<property name="draw_indicator">True</property> <property name="draw_indicator">True</property>
<signal name="toggled" handler="on_chk_autoaway_toggled" last_modification_time="Thu, 28 Oct 2004 11:17:52 GMT"/>
</widget> </widget>
<packing> <packing>
<property name="left_attach">0</property> <property name="left_attach">0</property>
@ -4525,6 +4600,7 @@ when NOT online</property>
<property name="active">False</property> <property name="active">False</property>
<property name="inconsistent">False</property> <property name="inconsistent">False</property>
<property name="draw_indicator">True</property> <property name="draw_indicator">True</property>
<signal name="toggled" handler="on_chk_autoxa_toggled" last_modification_time="Thu, 28 Oct 2004 11:20:22 GMT"/>
</widget> </widget>
<packing> <packing>
<property name="left_attach">0</property> <property name="left_attach">0</property>
@ -4864,6 +4940,19 @@ when NOT online</property>
<signal name="clicked" handler="on_ok_clicked" last_modification_time="Mon, 29 Dec 2003 13:48:07 GMT"/> <signal name="clicked" handler="on_ok_clicked" last_modification_time="Mon, 29 Dec 2003 13:48:07 GMT"/>
</widget> </widget>
</child> </child>
<child>
<widget class="GtkButton" id="button_apply">
<property name="visible">True</property>
<property name="can_default">True</property>
<property name="can_focus">True</property>
<property name="label">gtk-apply</property>
<property name="use_stock">True</property>
<property name="relief">GTK_RELIEF_NORMAL</property>
<property name="focus_on_click">True</property>
<signal name="clicked" handler="on_apply_clicked" last_modification_time="Thu, 28 Oct 2004 11:23:17 GMT"/>
</widget>
</child>
</widget> </widget>
<packing> <packing>
<property name="padding">0</property> <property name="padding">0</property>
@ -8468,7 +8557,7 @@ when NOT online</property>
<property name="spacing">0</property> <property name="spacing">0</property>
<child> <child>
<widget class="GtkLabel" id="label148"> <widget class="GtkLabel" id="label">
<property name="visible">True</property> <property name="visible">True</property>
<property name="label" translatable="yes">Enter your passphrase</property> <property name="label" translatable="yes">Enter your passphrase</property>
<property name="use_underline">False</property> <property name="use_underline">False</property>

View File

@ -1346,6 +1346,17 @@ class roster_Window:
def send_status(self, account, status, txt): def send_status(self, account, status, txt):
if status != 'offline': if status != 'offline':
save_pass = 0
if self.plugin.accounts[account].has_key("savepass"):
save_pass = self.plugin.accounts[account]["savepass"]
if not save_pass and not self.plugin.connected[account]:
passphrase = ''
w = passphrase_Window('Enter your passphrase for your account %s' % account)
passphrase = w.run()
if passphrase == -1:
return
self.plugin.send('PASSPHRASE', account, passphrase)
keyid = None keyid = None
save_gpg_pass = 0 save_gpg_pass = 0
if self.plugin.accounts[account].has_key("savegpgpass"): if self.plugin.accounts[account].has_key("savegpgpass"):
@ -1358,11 +1369,11 @@ class roster_Window:
passphrase = self.plugin.accounts[account]['gpgpass'] passphrase = self.plugin.accounts[account]['gpgpass']
else: else:
passphrase = '' passphrase = ''
w = passphrase_Window() w = passphrase_Window('Enter your passphrase for your the GPG key of your account %s' % account)
passphrase = w.run() passphrase = w.run()
if passphrase == -1: if passphrase == -1:
passphrase = '' passphrase = ''
self.plugin.send('PASSPHRASE', account, passphrase) self.plugin.send('GPGPASSPHRASE', account, passphrase)
self.plugin.send('STATUS', account, (status, txt)) self.plugin.send('STATUS', account, (status, txt))
if status == 'online' and self.plugin.sleeper.getState() != \ if status == 'online' and self.plugin.sleeper.getState() != \
common.sleepy.STATE_UNKNOWN: common.sleepy.STATE_UNKNOWN:
@ -2396,7 +2407,7 @@ class plugin:
'msg0_name':'Brb',\ 'msg0_name':'Brb',\
'msg0':'Back in some minutes.',\ 'msg0':'Back in some minutes.',\
'msg1_name':'Eating',\ 'msg1_name':'Eating',\
'msg1':'I\'m eating, so let a message.',\ 'msg1':'I\'m eating, so leave me a message.',\
'msg2_name':'Film',\ 'msg2_name':'Film',\
'msg2':'I\'m watching a film.',\ 'msg2':'I\'m watching a film.',\
'trayicon':1,\ 'trayicon':1,\
@ -2453,6 +2464,11 @@ class plugin:
self.roster = roster_Window(self) self.roster = roster_Window(self)
gtk.timeout_add(100, self.read_queue) gtk.timeout_add(100, self.read_queue)
gtk.timeout_add(1000, self.read_sleepy) gtk.timeout_add(1000, self.read_sleepy)
#auto connect at startup
for a in self.accounts.keys():
if self.accounts[a].has_key('autoconnect'):
if self.accounts[a]['autoconnect']:
self.roster.send_status(a, 'online', 'Online')
self.sleeper = common.sleepy.Sleepy( \ self.sleeper = common.sleepy.Sleepy( \
self.config['autoawaytime']*60, \ self.config['autoawaytime']*60, \
self.config['autoxatime']*60) self.config['autoxatime']*60)