Light refactring of bookmark code

- Convert xs:boolean values in bookmark module
- Use python booleans for minimize and autojoin in other parts of Gajim
- Use add_bookmark() instead of manipulating the bookmarks dict
This commit is contained in:
Philipp Hörist 2018-09-05 00:06:59 +02:00
parent b62335eaf5
commit 27f7580688
7 changed files with 72 additions and 62 deletions

View File

@ -499,16 +499,6 @@ def get_file_path_from_dnd_dropped_uri(uri):
path = path[5:] # 5 is len('file:') path = path[5:] # 5 is len('file:')
return path return path
def from_xs_boolean_to_python_boolean(value):
# this is xs:boolean so 'true', 'false', '1', '0'
# convert those to True/False (python booleans)
if value in ('1', 'true'):
val = True
else: # '0', 'false' or anything else
val = False
return val
def get_xmpp_show(show): def get_xmpp_show(show):
if show in ('online', 'offline'): if show in ('online', 'offline'):
return None return None

View File

@ -24,6 +24,8 @@ from gajim.common import app
from gajim.common import helpers from gajim.common import helpers
from gajim.common.const import BookmarkStorageType from gajim.common.const import BookmarkStorageType
from gajim.common.nec import NetworkIncomingEvent from gajim.common.nec import NetworkIncomingEvent
from gajim.common.modules.util import from_xs_boolean
from gajim.common.modules.util import to_xs_boolean
log = logging.getLogger('gajim.c.m.bookmarks') log = logging.getLogger('gajim.c.m.bookmarks')
@ -193,8 +195,8 @@ class Bookmarks:
log.debug('Found Bookmark: %s', jid) log.debug('Found Bookmark: %s', jid)
self.bookmarks[jid] = { self.bookmarks[jid] = {
'name': conf.getAttr('name'), 'name': conf.getAttr('name'),
'autojoin': autojoin_val, 'autojoin': from_xs_boolean(autojoin_val),
'minimize': minimize_val, 'minimize': from_xs_boolean(minimize_val),
'password': conf.getTagData('password'), 'password': conf.getTagData('password'),
'nick': conf.getTagData('nick'), 'nick': conf.getTagData('nick'),
'print_status': print_status} 'print_status': print_status}
@ -208,10 +210,10 @@ class Bookmarks:
for jid, bm in self.bookmarks.items(): for jid, bm in self.bookmarks.items():
conf_node = storage_node.addChild(name="conference") conf_node = storage_node.addChild(name="conference")
conf_node.setAttr('jid', jid) conf_node.setAttr('jid', jid)
conf_node.setAttr('autojoin', bm['autojoin']) conf_node.setAttr('autojoin', to_xs_boolean(bm['autojoin']))
conf_node.setAttr('name', bm['name']) conf_node.setAttr('name', bm['name'])
conf_node.setTag( conf_node.setTag('minimize', namespace=NS_GAJIM_BM).setData(
'minimize', namespace=NS_GAJIM_BM).setData(bm['minimize']) to_xs_boolean(bm['minimize']))
# Only add optional elements if not empty # Only add optional elements if not empty
# Note: need to handle both None and '' as empty # Note: need to handle both None and '' as empty
# thus shouldn't use "is not None" # thus shouldn't use "is not None"
@ -279,15 +281,14 @@ class Bookmarks:
if app.is_invisible(self._account): if app.is_invisible(self._account):
return return
for jid, bm in self.bookmarks.items(): for jid, bm in self.bookmarks.items():
if bm['autojoin'] in ('1', 'true'): if bm['autojoin']:
# Only join non-opened groupchats. Opened one are already # Only join non-opened groupchats. Opened one are already
# auto-joined on re-connection # auto-joined on re-connection
if jid not in app.gc_connected[self._account]: if jid not in app.gc_connected[self._account]:
# we are not already connected # we are not already connected
minimize = bm['minimize'] in ('1', 'true')
app.interface.join_gc_room( app.interface.join_gc_room(
self._account, jid, bm['nick'], self._account, jid, bm['nick'],
bm['password'], minimize=minimize) bm['password'], minimize=bm['minimize'])
def add_bookmark(self, name, jid, autojoin, def add_bookmark(self, name, jid, autojoin,
minimize, password, nick): minimize, password, nick):

View File

@ -39,3 +39,36 @@ def is_muc_pm(message, jid, groupchat=False):
if app.logger.jid_is_room_jid(jid.getStripped()): if app.logger.jid_is_room_jid(jid.getStripped()):
return True return True
return False return False
def from_xs_boolean(value):
# Convert a xs:boolean ('true', 'false', '1', '0', '')
# to a python boolean (True, False)
if value in (True, False):
return value
if value in ('1', 'true'):
return True
# '0', 'false' or empty
if value in ('0', 'false', ''):
return False
raise ValueError(
'Cant convert %s to python boolean' % value)
def to_xs_boolean(value):
# Convert to xs:boolean ('true', 'false')
# from a python boolean (True, False) or None
if value in ('true', 'false'):
return value
if value is True:
return 'true'
if value in (False, None):
return 'false'
raise ValueError(
'Cant convert %s to xs:boolean' % value)

View File

@ -1708,19 +1708,11 @@ class MucBrowser(AgentBrowser):
def on_bookmark_button_clicked(self, *args): def on_bookmark_button_clicked(self, *args):
con = app.connections[self.account] con = app.connections[self.account]
model, iter = self.window.services_treeview.get_selection().get_selected() model, iter_ = self.window.services_treeview.get_selection().get_selected()
if not iter: if not iter_:
return return
name = app.config.get_per('accounts', self.account, 'name')
room_jid = model[iter][0]
bm = {
'name': room_jid.split('@')[0],
'autojoin': '0',
'minimize': '0',
'password': '',
'nick': name
}
room_jid = model[iter_][0]
if room_jid in con.get_module('Bookmarks').bookmarks: if room_jid in con.get_module('Bookmarks').bookmarks:
ErrorDialog( ErrorDialog(
_('Bookmark already set'), _('Bookmark already set'),
@ -1728,10 +1720,12 @@ class MucBrowser(AgentBrowser):
transient_for=self.window.window) transient_for=self.window.window)
return return
con.get_module('Bookmarks').bookmarks[room_jid] = bm con.get_module('Bookmarks').add_bookmark(room_jid.split('@')[0],
con.get_module('Bookmarks').store_bookmarks() room_jid,
False,
gui_menu_builder.build_bookmark_menu(self.account) False,
''
'')
InformationDialog( InformationDialog(
_('Bookmark has been added successfully'), _('Bookmark has been added successfully'),

View File

@ -715,9 +715,12 @@ class GroupchatControl(ChatControlBase):
""" """
password = app.gc_passwords.get(self.room_jid, '') password = app.gc_passwords.get(self.room_jid, '')
con = app.connections[self.account] con = app.connections[self.account]
con.get_module('Bookmarks').add_bookmark( con.get_module('Bookmarks').add_bookmark(self.name,
self.name, self.room_jid, self.room_jid,
'1', '1', password, self.nick) True,
True,
password,
self.nick)
self.update_actions() self.update_actions()
def _on_request_voice(self, action, param): def _on_request_voice(self, action, param):

View File

@ -48,22 +48,14 @@ class ManageBookmarksWindow:
bookmarks = con.get_module('Bookmarks').get_sorted_bookmarks() bookmarks = con.get_module('Bookmarks').get_sorted_bookmarks()
for jid, bookmark in bookmarks.items(): for jid, bookmark in bookmarks.items():
# make '1', '0', 'true', 'false' (or other) to True/False
autojoin = helpers.from_xs_boolean_to_python_boolean(
bookmark['autojoin'])
minimize = helpers.from_xs_boolean_to_python_boolean(
bookmark['minimize'])
print_status = bookmark.get('print_status', '') print_status = bookmark.get('print_status', '')
if print_status not in ('', 'all', 'in_and_out', 'none'): if print_status not in ('', 'all', 'in_and_out', 'none'):
print_status = '' print_status = ''
self.treestore.append(iter_, [account, self.treestore.append(iter_, [account,
bookmark['name'], bookmark['name'],
jid, jid,
autojoin, bookmark['autojoin'],
minimize, bookmark['minimize'],
bookmark['password'], bookmark['password'],
bookmark['nick'], bookmark['nick'],
print_status, print_status,
@ -211,23 +203,16 @@ class ManageBookmarksWindow:
con.get_module('Bookmarks').bookmarks = {} con.get_module('Bookmarks').bookmarks = {}
for bm in account.iterchildren(): for bm in account.iterchildren():
# Convert True/False/None to '1' or '0'
autojoin = str(int(bm[3]))
minimize = str(int(bm[4]))
name = bm[1]
jid = bm[2]
pw = bm[5]
nick = bm[6]
# create the bookmark-dict # create the bookmark-dict
bmdict = { bmdict = {
'name': name, 'name': bm[1],
'autojoin': autojoin, 'autojoin': bm[3],
'minimize': minimize, 'minimize': bm[4],
'password': pw, 'password': bm[5],
'nick': nick, 'nick': bm[6],
'print_status': bm[7]} 'print_status': bm[7]}
jid = bm[2]
con.get_module('Bookmarks').bookmarks[jid] = bmdict con.get_module('Bookmarks').bookmarks[jid] = bmdict
con.get_module('Bookmarks').store_bookmarks() con.get_module('Bookmarks').store_bookmarks()

View File

@ -261,12 +261,16 @@ class JoinGroupchatWindow(Gtk.ApplicationWindow):
if not add_bookmark: if not add_bookmark:
return return
autojoin = int(self.autojoin_switch.get_active()) autojoin = self.autojoin_switch.get_active()
# Add as bookmark, with autojoin and not minimized # Add as bookmark, with autojoin and not minimized
name = app.get_nick_from_jid(self.room_jid) name = app.get_nick_from_jid(self.room_jid)
con.get_module('Bookmarks').add_bookmark( con.get_module('Bookmarks').add_bookmark(name,
name, self.room_jid, autojoin, 1, password, nickname) self.room_jid,
autojoin,
True,
password,
nickname)
def _on_search_clicked(self, widget): def _on_search_clicked(self, widget):
server = self.server_combo.get_active_text().strip() server = self.server_combo.get_active_text().strip()