* second draft of message archiving preferences window

This commit is contained in:
Anaël Verrier 2009-07-31 19:16:03 +02:00
parent 7922426464
commit 690c5e82ed
6 changed files with 683 additions and 320 deletions

View File

@ -10,43 +10,104 @@
<property name="visible">True</property> <property name="visible">True</property>
<property name="orientation">vertical</property> <property name="orientation">vertical</property>
<child> <child>
<widget class="GtkHBox" id="hbox2"> <widget class="GtkTable" id="table1">
<property name="visible">True</property> <property name="visible">True</property>
<property name="n_rows">4</property>
<property name="n_columns">2</property>
<child> <child>
<widget class="GtkLabel" id="label1"> <widget class="GtkLabel" id="label4">
<property name="visible">True</property> <property name="visible">True</property>
<property name="label" translatable="yes">&lt;i&gt;Auto Save&lt;/i&gt;</property> <property name="label" translatable="yes">&lt;i&gt;Method Manual&lt;/i&gt;</property>
<property name="use_markup">True</property> <property name="use_markup">True</property>
</widget> </widget>
<packing> <packing>
<property name="position">0</property> <property name="top_attach">3</property>
<property name="bottom_attach">4</property>
</packing> </packing>
</child> </child>
<child> <child>
<widget class="GtkRadioButton" id="auto_save_yes_radiobutton"> <widget class="GtkLabel" id="label3">
<property name="label" translatable="yes">Yes</property>
<property name="visible">True</property> <property name="visible">True</property>
<property name="can_focus">True</property> <property name="label" translatable="yes">&lt;i&gt;Method Local&lt;/i&gt;</property>
<property name="receives_default">False</property> <property name="use_markup">True</property>
<property name="active">True</property>
<property name="draw_indicator">True</property>
</widget> </widget>
<packing> <packing>
<property name="position">1</property> <property name="top_attach">2</property>
<property name="bottom_attach">3</property>
</packing> </packing>
</child> </child>
<child> <child>
<widget class="GtkRadioButton" id="auto_save_no_radiobutton"> <widget class="GtkLabel" id="label2">
<property name="label" translatable="yes">No</property>
<property name="visible">True</property> <property name="visible">True</property>
<property name="can_focus">True</property> <property name="label" translatable="yes">&lt;i&gt;Method Auto&lt;/i&gt;</property>
<property name="receives_default">False</property> <property name="use_markup">True</property>
<property name="active">True</property>
<property name="draw_indicator">True</property>
<property name="group">auto_save_yes_radiobutton</property>
</widget> </widget>
<packing> <packing>
<property name="position">2</property> <property name="top_attach">1</property>
<property name="bottom_attach">2</property>
</packing>
</child>
<child>
<widget class="GtkComboBox" id="method_manual_combobox">
<property name="visible">True</property>
<property name="items" translatable="yes">Prefer
Concede
Forbid</property>
<signal name="changed" handler="on_method_foo_combobox_changed"/>
</widget>
<packing>
<property name="left_attach">1</property>
<property name="right_attach">2</property>
<property name="top_attach">3</property>
<property name="bottom_attach">4</property>
</packing>
</child>
<child>
<widget class="GtkComboBox" id="method_local_combobox">
<property name="visible">True</property>
<property name="items" translatable="yes">Prefer
Concede
Forbid</property>
<signal name="changed" handler="on_method_foo_combobox_changed"/>
</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>
</packing>
</child>
<child>
<widget class="GtkComboBox" id="method_auto_combobox">
<property name="visible">True</property>
<property name="items" translatable="yes">Prefer
Concede
Forbid</property>
<signal name="changed" handler="on_method_foo_combobox_changed"/>
</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>
</packing>
</child>
<child>
<widget class="GtkLabel" id="label5">
<property name="visible">True</property>
<property name="label" translatable="yes">label</property>
</widget>
</child>
<child>
<widget class="GtkComboBox" id="auto_combobox">
<property name="visible">True</property>
<property name="items" translatable="yes">No
Yes</property>
<signal name="changed" handler="on_auto_combobox_changed"/>
</widget>
<packing>
<property name="left_attach">1</property>
<property name="right_attach">2</property>
</packing> </packing>
</child> </child>
</widget> </widget>
@ -56,150 +117,21 @@
</packing> </packing>
</child> </child>
<child> <child>
<widget class="GtkTable" id="table1"> <widget class="GtkVBox" id="vbox2">
<property name="visible">True</property> <property name="visible">True</property>
<property name="n_rows">3</property> <property name="orientation">vertical</property>
<property name="n_columns">2</property>
<child> <child>
<widget class="GtkLabel" id="label2"> <widget class="GtkScrolledWindow" id="scrolledwindow1">
<property name="visible">True</property> <property name="visible">True</property>
<property name="label" translatable="yes">&lt;i&gt;Method Auto&lt;/i&gt;</property> <property name="can_focus">True</property>
<property name="use_markup">True</property> <property name="hscrollbar_policy">automatic</property>
</widget> <property name="vscrollbar_policy">automatic</property>
</child>
<child>
<widget class="GtkLabel" id="label3">
<property name="visible">True</property>
<property name="label" translatable="yes">&lt;i&gt;Method Local&lt;/i&gt;</property>
<property name="use_markup">True</property>
</widget>
<packing>
<property name="top_attach">1</property>
<property name="bottom_attach">2</property>
</packing>
</child>
<child>
<widget class="GtkLabel" id="label4">
<property name="visible">True</property>
<property name="label" translatable="yes">&lt;i&gt;Method Manual&lt;/i&gt;</property>
<property name="use_markup">True</property>
</widget>
<packing>
<property name="top_attach">2</property>
<property name="bottom_attach">3</property>
</packing>
</child>
<child>
<widget class="GtkComboBox" id="method_manual_combobox">
<property name="visible">True</property>
<property name="items" translatable="yes">Prefer
Concede
Forbid</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>
</packing>
</child>
<child>
<widget class="GtkComboBox" id="method_local_combobox">
<property name="visible">True</property>
<property name="items" translatable="yes">Prefer
Concede
Forbid</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>
</packing>
</child>
<child>
<widget class="GtkComboBox" id="method_auto_combobox">
<property name="visible">True</property>
<property name="items" translatable="yes">Prefer
Concede
Forbid</property>
</widget>
<packing>
<property name="left_attach">1</property>
<property name="right_attach">2</property>
</packing>
</child>
</widget>
<packing>
<property name="expand">False</property>
<property name="position">1</property>
</packing>
</child>
<child>
<widget class="GtkHBox" id="hbox1">
<property name="visible">True</property>
<child>
<widget class="GtkVBox" id="vbox2">
<property name="visible">True</property>
<property name="orientation">vertical</property>
<child> <child>
<widget class="GtkScrolledWindow" id="scrolledwindow1"> <widget class="GtkTreeView" id="item_treeview">
<property name="visible">True</property> <property name="visible">True</property>
<property name="can_focus">True</property> <property name="can_focus">True</property>
<property name="hscrollbar_policy">automatic</property> <signal name="cursor_changed" handler="on_item_treeview_cursor_changed"/>
<property name="vscrollbar_policy">automatic</property>
<child>
<widget class="GtkTreeView" id="item_treeview">
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="headers_visible">False</property>
<signal name="cursor_changed" handler="on_item_treeview_cursor_changed"/>
</widget>
</child>
</widget> </widget>
<packing>
<property name="position">0</property>
</packing>
</child>
<child>
<widget class="GtkHButtonBox" id="hbuttonbox2">
<property name="visible">True</property>
<property name="layout_style">spread</property>
<child>
<widget class="GtkButton" id="add_item_button">
<property name="label" translatable="yes">gtk-add</property>
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="receives_default">True</property>
<property name="use_stock">True</property>
<signal name="clicked" handler="on_add_item_button_clicked"/>
</widget>
<packing>
<property name="expand">False</property>
<property name="fill">False</property>
<property name="position">0</property>
</packing>
</child>
<child>
<widget class="GtkButton" id="remove_item_button">
<property name="label" translatable="yes">gtk-remove</property>
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="receives_default">True</property>
<property name="use_stock">True</property>
<signal name="clicked" handler="on_remove_item_button_clicked"/>
</widget>
<packing>
<property name="expand">False</property>
<property name="fill">False</property>
<property name="position">1</property>
</packing>
</child>
</widget>
<packing>
<property name="expand">False</property>
<property name="position">1</property>
</packing>
</child> </child>
</widget> </widget>
<packing> <packing>
@ -207,124 +139,63 @@ Forbid</property>
</packing> </packing>
</child> </child>
<child> <child>
<widget class="GtkNotebook" id="item_notebook"> <widget class="GtkHButtonBox" id="hbuttonbox2">
<property name="visible">True</property> <property name="visible">True</property>
<property name="can_focus">True</property> <property name="layout_style">spread</property>
<property name="show_tabs">False</property>
<property name="show_border">False</property>
<child> <child>
<widget class="GtkLabel" id="label11"> <widget class="GtkButton" id="add_button">
<property name="label" translatable="yes">gtk-add</property>
<property name="visible">True</property> <property name="visible">True</property>
</widget> <property name="can_focus">True</property>
</child> <property name="receives_default">True</property>
<child> <property name="use_stock">True</property>
<widget class="GtkLabel" id="label5"> <signal name="clicked" handler="on_add_item_button_clicked"/>
<property name="visible">True</property>
<property name="label" translatable="yes">page 1</property>
</widget> </widget>
<packing> <packing>
<property name="tab_fill">False</property> <property name="expand">False</property>
<property name="type">tab</property> <property name="fill">False</property>
<property name="position">0</property>
</packing> </packing>
</child> </child>
<child> <child>
<widget class="GtkTable" id="table3"> <widget class="GtkButton" id="remove_button">
<property name="label" translatable="yes">gtk-remove</property>
<property name="visible">True</property> <property name="visible">True</property>
<property name="n_rows">3</property> <property name="can_focus">True</property>
<property name="n_columns">2</property> <property name="receives_default">True</property>
<child> <property name="use_stock">True</property>
<widget class="GtkLabel" id="label8"> <signal name="clicked" handler="on_remove_item_button_clicked"/>
<property name="visible">True</property>
<property name="label" translatable="yes">expire</property>
</widget>
</child>
<child>
<widget class="GtkLabel" id="label9">
<property name="visible">True</property>
<property name="label" translatable="yes">otr</property>
</widget>
<packing>
<property name="top_attach">1</property>
<property name="bottom_attach">2</property>
</packing>
</child>
<child>
<widget class="GtkLabel" id="label10">
<property name="visible">True</property>
<property name="label" translatable="yes">save</property>
</widget>
<packing>
<property name="top_attach">2</property>
<property name="bottom_attach">3</property>
</packing>
</child>
<child>
<widget class="GtkEntry" id="expire_entry">
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="invisible_char">&#x2022;</property>
</widget>
<packing>
<property name="left_attach">1</property>
<property name="right_attach">2</property>
</packing>
</child>
<child>
<widget class="GtkComboBox" id="otr_combobox">
<property name="visible">True</property>
<property name="items" translatable="yes">approve
concede
forbid
oppose
prefer
require</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>
</packing>
</child>
<child>
<widget class="GtkComboBox" id="save_combobox">
<property name="visible">True</property>
<property name="items" translatable="yes">body
false
message
stream</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>
</packing>
</child>
</widget> </widget>
<packing> <packing>
<property name="expand">False</property>
<property name="fill">False</property>
<property name="position">1</property> <property name="position">1</property>
</packing> </packing>
</child> </child>
<child> <child>
<widget class="GtkLabel" id="label6"> <widget class="GtkButton" id="edit_button">
<property name="label" translatable="yes">gtk-edit</property>
<property name="visible">True</property> <property name="visible">True</property>
<property name="label" translatable="yes">page 2</property> <property name="can_focus">True</property>
<property name="receives_default">True</property>
<property name="use_stock">True</property>
<signal name="clicked" handler="on_edit_item_button_clicked"/>
</widget> </widget>
<packing> <packing>
<property name="position">1</property> <property name="expand">False</property>
<property name="tab_fill">False</property> <property name="fill">False</property>
<property name="type">tab</property> <property name="position">2</property>
</packing> </packing>
</child> </child>
</widget> </widget>
<packing> <packing>
<property name="expand">False</property>
<property name="position">1</property> <property name="position">1</property>
</packing> </packing>
</child> </child>
</widget> </widget>
<packing> <packing>
<property name="position">2</property> <property name="position">1</property>
</packing> </packing>
</child> </child>
<child> <child>
@ -350,7 +221,7 @@ stream</property>
</widget> </widget>
<packing> <packing>
<property name="expand">False</property> <property name="expand">False</property>
<property name="position">3</property> <property name="position">2</property>
</packing> </packing>
</child> </child>
</widget> </widget>

View File

@ -0,0 +1,176 @@
<?xml version="1.0"?>
<glade-interface>
<!-- interface-requires gtk+ 2.16 -->
<!-- interface-naming-policy project-wide -->
<widget class="GtkWindow" id="item_archiving_preferences_window">
<property name="border_width">12</property>
<signal name="destroy" handler="on_item_archiving_preferences_window_destroy"/>
<child>
<widget class="GtkVBox" id="vbox1">
<property name="visible">True</property>
<property name="orientation">vertical</property>
<property name="spacing">12</property>
<child>
<widget class="GtkTable" id="table3">
<property name="visible">True</property>
<property name="n_rows">4</property>
<property name="n_columns">2</property>
<child>
<widget class="GtkLabel" id="label8">
<property name="visible">True</property>
<property name="label" translatable="yes">expire</property>
</widget>
<packing>
<property name="top_attach">1</property>
<property name="bottom_attach">2</property>
</packing>
</child>
<child>
<widget class="GtkEntry" id="expire_entry">
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="invisible_char">&#x2022;</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>
</packing>
</child>
<child>
<widget class="GtkComboBox" id="otr_combobox">
<property name="visible">True</property>
<property name="items" translatable="yes">approve
concede
forbid
oppose
prefer
require</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>
</packing>
</child>
<child>
<widget class="GtkComboBox" id="save_combobox">
<property name="visible">True</property>
<property name="items" translatable="yes">body
false
message
stream</property>
</widget>
<packing>
<property name="left_attach">1</property>
<property name="right_attach">2</property>
<property name="top_attach">3</property>
<property name="bottom_attach">4</property>
</packing>
</child>
<child>
<widget class="GtkLabel" id="label10">
<property name="visible">True</property>
<property name="label" translatable="yes">save</property>
</widget>
<packing>
<property name="top_attach">3</property>
<property name="bottom_attach">4</property>
</packing>
</child>
<child>
<widget class="GtkLabel" id="label9">
<property name="visible">True</property>
<property name="label" translatable="yes">otr</property>
</widget>
<packing>
<property name="top_attach">2</property>
<property name="bottom_attach">3</property>
</packing>
</child>
<child>
<widget class="GtkLabel" id="label1">
<property name="visible">True</property>
<property name="label" translatable="yes">jid</property>
</widget>
</child>
<child>
<widget class="GtkEntry" id="jid_entry">
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="invisible_char">&#x2022;</property>
</widget>
<packing>
<property name="left_attach">1</property>
<property name="right_attach">2</property>
</packing>
</child>
</widget>
<packing>
<property name="expand">False</property>
<property name="fill">False</property>
<property name="position">0</property>
</packing>
</child>
<child>
<widget class="GtkHBox" id="hbox1">
<property name="visible">True</property>
<child>
<widget class="GtkProgressBar" id="progressbar"/>
<packing>
<property name="expand">False</property>
<property name="fill">False</property>
<property name="position">0</property>
</packing>
</child>
<child>
<widget class="GtkHButtonBox" id="hbuttonbox1">
<property name="visible">True</property>
<property name="layout_style">end</property>
<child>
<widget class="GtkButton" id="cancel_button">
<property name="label" translatable="yes">gtk-cancel</property>
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="receives_default">True</property>
<property name="use_stock">True</property>
<signal name="clicked" handler="on_cancel_button_clicked"/>
</widget>
<packing>
<property name="expand">False</property>
<property name="fill">False</property>
<property name="position">0</property>
</packing>
</child>
<child>
<widget class="GtkButton" id="ok_button">
<property name="label" translatable="yes">gtk-ok</property>
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="receives_default">True</property>
<property name="use_stock">True</property>
<signal name="clicked" handler="on_ok_button_clicked"/>
</widget>
<packing>
<property name="expand">False</property>
<property name="fill">False</property>
<property name="position">1</property>
</packing>
</child>
</widget>
<packing>
<property name="position">1</property>
</packing>
</child>
</widget>
<packing>
<property name="expand">False</property>
<property name="position">1</property>
</packing>
</child>
</widget>
</child>
</widget>
</glade-interface>

View File

@ -1033,10 +1033,7 @@ class Connection(ConnectionHandlers):
self.connection.set_send_timeout2(self.pingalives, self.sendPing) self.connection.set_send_timeout2(self.pingalives, self.sendPing)
self.connection.onreceive(None) self.connection.onreceive(None)
# Request message archiving preferences self.request_message_archiving_preferences()
iq = common.xmpp.Iq('get')
iq.setTag('pref', namespace=common.xmpp.NS_ARCHIVE)
self.connection.send(iq)
# Request privacy list # Request privacy list
iq = common.xmpp.Iq('get', common.xmpp.NS_PRIVACY, xmlns = '') iq = common.xmpp.Iq('get', common.xmpp.NS_PRIVACY, xmlns = '')

View File

@ -18,6 +18,8 @@
## along with Gajim. If not, see <http://www.gnu.org/licenses/>. ## along with Gajim. If not, see <http://www.gnu.org/licenses/>.
## ##
import common.xmpp
class ConnectionArchive: class ConnectionArchive:
def __init__(self): def __init__(self):
@ -25,60 +27,110 @@ class ConnectionArchive:
self.archive_manage_supported = False self.archive_manage_supported = False
self.archive_manual_supported = False self.archive_manual_supported = False
self.archive_pref_supported = False self.archive_pref_supported = False
self.auto_save = None self.auto = None
self.method_auto = None self.method_auto = None
self.method_local = None self.method_local = None
self.method_manual = None self.method_manual = None
self.default = None self.default = None
self.items = {} self.items = {}
def set_default(self, otr, save, expire=None, unset=False): def request_message_archiving_preferences(self):
self.default = {'expire': expire, 'otr': otr, 'save': save, iq_ = common.xmpp.Iq('get')
'unset': unset} iq_.setTag('pref', namespace=common.xmpp.NS_ARCHIVE)
print iq_
self.connection.send(iq_)
def set_pref(self, name, **data):
'''
data contains names and values of pref name attributes.
'''
iq_ = common.xmpp.Iq('set')
pref = iq_.setTag('pref', namespace=common.xmpp.NS_ARCHIVE)
tag = pref.setTag(name)
for key, value in data.items():
if value is not None:
tag.setAttr(key, value)
print iq_
self.connection.send(iq_)
def set_auto(self, save):
self.set_pref('auto', save=save)
def set_method(self, type, use):
self.set_pref('method', type=type, use=use)
def set_default(self, otr, save, expire=None):
self.set_pref('default', otr=otr, save=save, expire=expire)
def append_or_update_item(self, jid, otr, save, expire): def append_or_update_item(self, jid, otr, save, expire):
self.items[jid] = {'expire': expire, 'otr': otr, 'save': save} self.set_pref('item', jid=jid, otr=otr, save=save)
def remove_item(self, jid): def remove_item(self, jid):
del self.items[jid] iq_ = common.xmpp.Iq('set')
itemremove = iq_.setTag('itemremove', namespace=common.xmpp.NS_ARCHIVE)
item = itemremove.setTag('item')
item.setAttr('jid', jid)
print iq_
self.connection.send(iq_)
def _ArchiveCB(self, con, iq_obj): def _ArchiveCB(self, con, iq_obj):
print '_ArchiveCB', iq_obj.getType() print '_ArchiveCB', iq_obj.getType()
if iq_obj.getType() not in ('result', 'set'): if iq_obj.getType() == 'error':
self.dispatch('ARCHIVING_ERROR', iq_obj.getErrorMsg())
return return
elif iq_obj.getType() not in ('result', 'set'):
print iq_obj
return
if iq_obj.getTag('pref'): if iq_obj.getTag('pref'):
pref = iq_obj.getTag('pref') pref = iq_obj.getTag('pref')
if pref.getTag('auto'): if pref.getTag('auto'):
self.auto_save = pref.getTagAttr('auto', 'save') self.auto = pref.getTagAttr('auto', 'save')
print 'auto_save:', self.auto_save print 'auto:', self.auto
self.dispatch('ARCHIVING_CHANGED', ('auto',
self.auto))
method_auto = pref.getTag('method', attrs={'type': 'auto'}) method_auto = pref.getTag('method', attrs={'type': 'auto'})
if method_auto: if method_auto:
self.method_auto = method_auto.getAttr('use') self.method_auto = method_auto.getAttr('use')
self.dispatch('ARCHIVING_CHANGED', ('method_auto',
self.method_auto))
method_local = pref.getTag('method', attrs={'type': 'local'}) method_local = pref.getTag('method', attrs={'type': 'local'})
if method_local: if method_local:
self.method_local = method_local.getAttr('use') self.method_local = method_local.getAttr('use')
self.dispatch('ARCHIVING_CHANGED', ('method_local',
self.method_local))
method_manual = pref.getTag('method', attrs={'type': 'manual'}) method_manual = pref.getTag('method', attrs={'type': 'manual'})
if method_manual: if method_manual:
self.method_manual = method_manual.getAttr('use') self.method_manual = method_manual.getAttr('use')
self.dispatch('ARCHIVING_CHANGED', ('method_manual',
self.method_manual))
print 'method alm:', self.method_auto, self.method_local, self.method_manual print 'method alm:', self.method_auto, self.method_local, self.method_manual
if pref.getTag('default'): if pref.getTag('default'):
default = pref.getTag('default') default = pref.getTag('default')
print 'default oseu:', default.getAttr('otr'), default.getAttr('save'), default.getAttr('expire'), default.getAttr('unset') print 'default oseu:', default.getAttr('otr'), default.getAttr('save'), default.getAttr('expire'), default.getAttr('unset')
self.set_default(default.getAttr('otr'), self.default = {
default.getAttr('save'), default.getAttr('expire'), 'expire': default.getAttr('expire'),
default.getAttr('unset')) 'otr': default.getAttr('otr'),
'save': default.getAttr('save'),
'unset': default.getAttr('unset')}
self.dispatch('ARCHIVING_CHANGED', ('default',
self.default))
for item in pref.getTags('item'): for item in pref.getTags('item'):
print item.getAttr('jid'), item.getAttr('otr'), item.getAttr('save'), item.getAttr('expire') print item.getAttr('jid'), item.getAttr('otr'), item.getAttr('save'), item.getAttr('expire')
self.append_or_update_item(item.getAttr('jid'), self.items[item.getAttr('jid')] = {
item.getAttr('otr'), item.getAttr('save'), 'expire': item.getAttr('expire'),
item.getAttr('expire')) 'otr': item.getAttr('otr'), 'save': item.getAttr('save')}
self.dispatch('ARCHIVING_CHANGED', ('item',
item.getAttr('jid'), self.items[item.getAttr('jid')]))
elif iq_obj.getTag('itemremove'): elif iq_obj.getTag('itemremove'):
for item in pref.getTags('item'): for item in pref.getTags('item'):
print 'del', item.getAttr('jid') print 'del', item.getAttr('jid')
self.remove_item(item.getAttr('jid')) del self.items[item.getAttr('jid')]
self.dispatch('ARCHIVING_CHANGED', ('itemremove',
item.getAttr('jid')))

View File

@ -2848,66 +2848,247 @@ class RosterItemExchangeWindow:
self.window.destroy() self.window.destroy()
class ItemArchivingPreferencesWindow:
otr_name = ('approve', 'concede', 'forbid', 'oppose', 'prefer', 'require')
otr_index = dict([(j, i) for i, j in enumerate(otr_name)])
save_name = ('body', 'false', 'message', 'stream')
save_index = dict([(j, i) for i, j in enumerate(save_name)])
def __init__(self, account, item):
self.account = account
self.item = item
if self.item and self.item != 'Default':
self.item_config = gajim.connections[self.account].items[self.item]
else:
self.item_config = gajim.connections[self.account].default
print self.item, self.item_config
self.waiting = None
# Connect to glade
self.xml = gtkgui_helpers.get_glade(
'item_archiving_preferences_window.glade')
self.window = self.xml.get_widget('item_archiving_preferences_window')
# Add Widgets
for widget_to_add in ('jid_entry', 'expire_entry', 'otr_combobox',
'save_combobox', 'cancel_button', 'ok_button', 'progressbar'):
self.__dict__[widget_to_add] = self.xml.get_widget(widget_to_add)
if self.item:
self.jid_entry.set_text(self.item)
expire_value = self.item_config['expire'] or ''
self.otr_combobox.set_active(self.otr_index[self.item_config['otr']])
self.save_combobox.set_active(
self.save_index[self.item_config['save']])
self.expire_entry.set_text(expire_value)
self.window.set_title(_('Archiving Preferences for %s') % self.account)
self.window.show_all()
self.progressbar.hide()
self.xml.signal_autoconnect(self)
def update_progressbar(self):
if self.waiting:
self.progressbar.pulse()
return True
return False
def on_ok_button_clicked(self, widget):
# Return directly if operation in progress
if self.waiting:
return
item = self.jid_entry.get_text()
otr = self.otr_name[self.otr_combobox.get_active()]
save = self.save_name[self.save_combobox.get_active()]
expire = self.expire_entry.get_text()
if self.item != 'Default':
try:
item = helpers.parse_jid(item)
except helpers.InvalidFormat, s:
pritext = _('Invalid User ID')
ErrorDialog(pritext, str(s))
return
if expire:
try:
if int(expire) < 0 or str(int(expire)) != expire:
raise ValueError
except ValueError:
pritext = _('Invalid expire value')
sectext = _('Expire must be a valid positive integer.')
ErrorDialog(pritext, sectext)
return
if not (item == self.item and expire == self.item_config['expire'] and
otr == self.item_config['otr'] and save == self.item_config['save']):
if not self.item or self.item == item:
if self.item == 'Default':
self.waiting = 'default'
gajim.connections[self.account].set_default(
otr, save, expire)
else:
self.waiting = 'item'
gajim.connections[self.account].append_or_update_item(
item, otr, save, expire)
else:
self.waiting = 'item'
gajim.connections[self.account].append_or_update_item(
item, otr, save, expire)
gajim.connections[self.account].remove_item(self.item)
self.launch_progressbar()
#self.window.destroy()
def on_cancel_button_clicked(self, widget):
self.window.destroy()
def on_item_archiving_preferences_window_destroy(self, widget):
if self.item:
key_name = 'edit_item_archiving_preferences_%s' % self.item
else:
key_name = 'new_item_archiving_preferences'
if key_name in gajim.interface.instances[self.account]:
del gajim.interface.instances[self.account][key_name]
def launch_progressbar(self):
self.progressbar.show()
self.update_progressbar_timeout_id = gobject.timeout_add(
100, self.update_progressbar)
def response_arrived(self, data):
if self.waiting:
self.window.destroy()
def error_arrived(self, error):
if self.waiting:
self.waiting = None
self.progressbar.hide()
pritext = _('There is an error with the form')
sectext = error
ErrorDialog(pritext, sectext)
class ArchivingPreferencesWindow: class ArchivingPreferencesWindow:
auto_name = ('false', 'true')
auto_index = dict([(j, i) for i, j in enumerate(auto_name)])
method_foo_name = ('prefer', 'concede', 'forbid')
method_foo_index = dict([(j, i) for i, j in enumerate(method_foo_name)])
def __init__(self, account): def __init__(self, account):
self.account = account self.account = account
self.waiting = []
# Connect to glade # Connect to glade
self.xml = gtkgui_helpers.get_glade('archiving_preferences_window.glade') self.xml = gtkgui_helpers.get_glade('archiving_preferences_window.glade')
self.window = self.xml.get_widget('archiving_preferences_window') self.window = self.xml.get_widget('archiving_preferences_window')
# Add Widgets # Add Widgets
for widget_to_add in ('auto_save_yes_radiobutton', for widget_to_add in ('auto_combobox', 'method_auto_combobox',
'auto_save_no_radiobutton', 'method_auto_combobox',
'method_local_combobox', 'method_manual_combobox', 'close_button', 'method_local_combobox', 'method_manual_combobox', 'close_button',
'item_treeview', 'item_notebook', 'otr_combobox', 'save_combobox', 'item_treeview', 'item_notebook', 'otr_combobox', 'save_combobox',
'expire_entry'): 'expire_entry', 'remove_button', 'edit_button'):
self.__dict__[widget_to_add] = self.xml.get_widget(widget_to_add) self.__dict__[widget_to_add] = self.xml.get_widget(widget_to_add)
self.auto_combobox.set_active(
self.auto_index[gajim.connections[self.account].auto])
self.method_auto_combobox.set_active(
self.method_foo_index[gajim.connections[self.account].method_auto])
self.method_local_combobox.set_active(
self.method_foo_index[gajim.connections[self.account].method_local])
self.method_manual_combobox.set_active(
self.method_foo_index[gajim.connections[self.account].method_manual])
auto_save = gajim.connections[account].auto_save == 'true' model = gtk.ListStore(str, str, str, str)
self.auto_save_yes_radiobutton.set_active(auto_save)
self.auto_save_no_radiobutton.set_active(not auto_save)
method_index = {'prefer': 0, 'concede': 1, 'forbid': 2}
self.method_auto_combobox.set_active(method_index[gajim.connections[
self.account].method_auto])
self.method_local_combobox.set_active(method_index[gajim.connections[
self.account].method_local])
self.method_manual_combobox.set_active(method_index[gajim.connections[
self.account].method_manual])
model = gtk.ListStore(str)
self.item_treeview.set_model(model) self.item_treeview.set_model(model)
col = gtk.TreeViewColumn('name') col = gtk.TreeViewColumn('jid')
self.item_treeview.append_column(col) self.item_treeview.append_column(col)
renderer = gtk.CellRendererText() renderer = gtk.CellRendererText()
col.pack_start(renderer, True) col.pack_start(renderer, True)
col.set_attributes(renderer, text=0) col.set_attributes(renderer, text=0)
#renderer.connect('edited', self.on_msg_cell_edited)
renderer.set_property('editable', False) col = gtk.TreeViewColumn('expire')
#self.fill_item_treeview() col.pack_start(renderer, True)
iter_ = model.append() col.set_attributes(renderer, text=1)
model.set(iter_, 0, 'Default') self.item_treeview.append_column(col)
for item in gajim.connections[account].items:
iter_ = model.append() col = gtk.TreeViewColumn('otr')
model.set(iter_, 0, item) col.pack_start(renderer, True)
col.set_attributes(renderer, text=2)
self.item_treeview.append_column(col)
col = gtk.TreeViewColumn('save')
col.pack_start(renderer, True)
col.set_attributes(renderer, text=3)
self.item_treeview.append_column(col)
self.fill_items()
self.current_item = None self.current_item = None
def sort_items(model, iter1, iter2):
item1 = model.get_value(iter1, 0)
item2 = model.get_value(iter2, 0)
if item1 == 'Default':
return -1
if item2 == 'Default':
return 1
if '@' in item1:
if '@' not in item2:
return 1
elif '@' in item2:
return -1
if item1 < item2:
return -1
if item1 > item2:
return 1
# item1 == item2 ? WTF?
return 0
model.set_sort_column_id(0, gtk.SORT_ASCENDING)
model.set_sort_func(0, sort_items)
self.remove_button.set_sensitive(False)
self.edit_button.set_sensitive(False)
self.window.set_title(_('Archiving Preferences for %s') % self.account) self.window.set_title(_('Archiving Preferences for %s') % self.account)
self.window.show_all() self.window.show_all()
self.xml.signal_autoconnect(self) self.xml.signal_autoconnect(self)
def on_archiving_preferences_window_destroy(self, widget):
if 'archiving_preferences' in gajim.interface.instances[self.account]:
del gajim.interface.instances[self.account]['archiving_preferences']
def on_add_item_button_clicked(self, widget): def on_add_item_button_clicked(self, widget):
model = self.item_treeview.get_model() key_name = 'new_item_archiving_preferences'
iter_ = model.append() if key_name in gajim.interface.instances[self.account]:
model.set(iter_, 0, 'jid@example.net') gajim.interface.instances[self.account][key_name].window.present()
else:
gajim.interface.instances[self.account][key_name] = \
ItemArchivingPreferencesWindow(self.account, '')
def on_remove_item_button_clicked(self, widget):
if not self.current_item:
return
self.waiting.append('itemremove')
sel = self.item_treeview.get_selection()
(model, iter_) = sel.get_selected()
gajim.connections[self.account].remove_item(model[iter_][0])
model.remove(iter_)
self.remove_button.set_sensitive(False)
self.edit_button.set_sensitive(False)
def on_edit_item_button_clicked(self, widget):
if not self.current_item:
print 'there is no current item'
return
key_name = 'edit_item_archiving_preferences_%s' % self.current_item
if key_name in gajim.interface.instances[self.account]:
gajim.interface.instances[self.account][key_name].window.present()
else:
gajim.interface.instances[self.account][key_name] = \
ItemArchivingPreferencesWindow(self.account, self.current_item)
def on_item_treeview_cursor_changed(self, widget): def on_item_treeview_cursor_changed(self, widget):
sel = self.item_treeview.get_selection() sel = self.item_treeview.get_selection()
@ -2918,27 +3099,101 @@ class ArchivingPreferencesWindow:
if self.current_item and self.current_item == item: if self.current_item and self.current_item == item:
return return
if iter: self.current_item = item
otr_index = {'approve': 0, 'concede': 1, 'forbid': 2, 'oppose': 3, if self.current_item == 'Default':
'prefer': 4, 'require': 5} self.remove_button.set_sensitive(False)
save_index = {'body': 0, 'false': 1, 'message': 2, 'stream': 3} self.edit_button.set_sensitive(True)
item_config = None elif self.current_item:
if item == 'Default': self.remove_button.set_sensitive(True)
item_config = gajim.connections[self.account].default self.edit_button.set_sensitive(True)
else:
item_config = gajim.connections[self.account].items[item]
self.otr_combobox.set_active(otr_index[item_config['otr']])
self.save_combobox.set_active(save_index[item_config['save']])
expire_value = item_config['expire'] or ''
self.expire_entry.set_text(expire_value)
self.current_item = item
if self.current_item:
self.item_notebook.set_current_page(1)
else: else:
self.item_notebook.set_current_page(0) self.remove_button.set_sensitive(False)
self.edit_button.set_sensitive(False)
def on_auto_combobox_changed(self, widget):
save = self.auto_name[widget.get_active()]
gajim.connections[self.account].set_auto(save)
def on_method_foo_combobox_changed(self, widget):
# We retrieve method type from widget name
# ('foo' in 'method_foo_combobox')
method_type = widget.name.split('_')[1]
use = self.method_foo_name[widget.get_active()]
self.waiting.append('method_%s' % method_type)
gajim.connections[self.account].set_method(method_type, use)
def get_child_window(self):
edit_key_name = 'edit_item_archiving_preferences_%s' % \
self.current_item
new_key_name = 'new_item_archiving_preferences'
if edit_key_name in gajim.interface.instances[self.account]:
return gajim.interface.instances[self.account][edit_key_name]
if new_key_name in gajim.interface.instances[self.account]:
return gajim.interface.instances[self.account][new_key_name]
def archiving_changed(self, data):
if data[0] in ('auto', 'method_auto', 'method_local', 'method_manual'):
if data[0] in self.waiting:
self.waiting.remove(data[0])
elif data[0] == 'default':
key_name = 'edit_item_archiving_preferences_%s' % \
self.current_item
if key_name in gajim.interface.instances[self.account]:
gajim.interface.instances[self.account][key_name].\
response_arrived(data[1:])
self.fill_items(True)
elif data[0] == 'item':
child = self.get_child_window()
if child:
is_new = not child.item
child.response_arrived(data[1:])
if is_new:
model = self.item_treeview.get_model()
model.append((data[1], data[2]['expire'], data[2]['otr'],
data[2]['save']))
return
self.fill_items(True)
elif data[0] == 'itemremove' == self.waiting:
if data[0] in self.waiting:
self.waiting.remove(data[0])
self.fill_items(True)
def fill_items(self, clear=False):
model = self.item_treeview.get_model()
if clear:
model.clear()
default_config = gajim.connections[self.account].default
expire_value = default_config['expire'] or ''
model.append(('Default', expire_value,
default_config['otr'], default_config['save']))
for item, item_config in \
gajim.connections[self.account].items.items():
expire_value = item_config['expire'] or ''
model.append((item, expire_value, item_config['otr'],
item_config['save']))
def archiving_error(self, error):
if self.waiting:
pritext = _('There is an error')
sectext = error
ErrorDialog(pritext, sectext)
self.waiting.pop()
else:
child = self.get_child_window()
if child:
child.error_arrived(error)
print error
def on_close_button_clicked(self, widget): def on_close_button_clicked(self, widget):
self.window.destroy() if not self.waiting:
self.window.destroy()
def on_archiving_preferences_window_destroy(self, widget):
if 'archiving_preferences' in gajim.interface.instances[self.account]:
del gajim.interface.instances[self.account]['archiving_preferences']
class PrivacyListWindow: class PrivacyListWindow:

View File

@ -2236,6 +2236,16 @@ class Interface:
_('PEP node %(node)s was not removed: %(message)s') % { _('PEP node %(node)s was not removed: %(message)s') % {
'node': data[1], 'message': data[2]}) 'node': data[1], 'message': data[2]})
def handle_event_archiving_changed(self, account, data):
if 'archiving_preferences' in self.instances[account]:
self.instances[account]['archiving_preferences'].archiving_changed(
data)
def handle_event_archiving_error(self, account, data):
if 'archiving_preferences' in self.instances[account]:
self.instances[account]['archiving_preferences'].archiving_error(
data)
def register_handlers(self): def register_handlers(self):
self.handlers = { self.handlers = {
'ROSTER': self.handle_event_roster, 'ROSTER': self.handle_event_roster,
@ -2320,6 +2330,8 @@ class Interface:
'INSECURE_SSL_CONNECTION': self.handle_event_insecure_ssl_connection, 'INSECURE_SSL_CONNECTION': self.handle_event_insecure_ssl_connection,
'PUBSUB_NODE_REMOVED': self.handle_event_pubsub_node_removed, 'PUBSUB_NODE_REMOVED': self.handle_event_pubsub_node_removed,
'PUBSUB_NODE_NOT_REMOVED': self.handle_event_pubsub_node_not_removed, 'PUBSUB_NODE_NOT_REMOVED': self.handle_event_pubsub_node_not_removed,
'ARCHIVING_CHANGED': self.handle_event_archiving_changed,
'ARCHIVING_ERROR': self.handle_event_archiving_error,
} }
gajim.handlers = self.handlers gajim.handlers = self.handlers