Correctly register gajim-remote with xmpp: URIs
This commit is contained in:
parent
d69fcc9e1e
commit
c9eb479fe3
|
@ -0,0 +1,11 @@
|
||||||
|
[Desktop Entry]
|
||||||
|
Categories=Network;InstantMessaging;RemoteAccess;ConsoleOnly;
|
||||||
|
_Name=Gajim Remote
|
||||||
|
_Keywords=chat;messaging;im;jabber;xmpp;bonjour;voip
|
||||||
|
Version=1.0
|
||||||
|
Exec=gajim-remote handle_uri %u
|
||||||
|
TryExec=gajim-remote
|
||||||
|
StartupNotify=false
|
||||||
|
Terminal=false
|
||||||
|
Type=Application
|
||||||
|
MimeType=x-scheme-handler/xmpp
|
|
@ -3049,23 +3049,6 @@ to discover one from server.</property>
|
||||||
<property name="position">0</property>
|
<property name="position">0</property>
|
||||||
</packing>
|
</packing>
|
||||||
</child>
|
</child>
|
||||||
<child>
|
|
||||||
<object class="GtkCheckButton" id="check_default_client_checkbutton">
|
|
||||||
<property name="label" translatable="yes">Check on startup if Gajim is the _default Jabber client</property>
|
|
||||||
<property name="visible">True</property>
|
|
||||||
<property name="can_focus">True</property>
|
|
||||||
<property name="receives_default">False</property>
|
|
||||||
<property name="use_underline">True</property>
|
|
||||||
<property name="xalign">0</property>
|
|
||||||
<property name="draw_indicator">True</property>
|
|
||||||
<signal name="toggled" handler="on_check_default_client_checkbutton_toggled" swapped="no"/>
|
|
||||||
</object>
|
|
||||||
<packing>
|
|
||||||
<property name="expand">False</property>
|
|
||||||
<property name="fill">True</property>
|
|
||||||
<property name="position">1</property>
|
|
||||||
</packing>
|
|
||||||
</child>
|
|
||||||
</object>
|
</object>
|
||||||
</child>
|
</child>
|
||||||
</object>
|
</object>
|
||||||
|
|
2
po/el.po
2
po/el.po
|
@ -8859,7 +8859,7 @@ msgstr ""
|
||||||
|
|
||||||
#: ../src/gajim-remote-plugin.py:252 ../src/gajim-remote.py:277
|
#: ../src/gajim-remote-plugin.py:252 ../src/gajim-remote.py:277
|
||||||
#, fuzzy
|
#, fuzzy
|
||||||
msgid "Handle a xmpp:/ uri"
|
msgid "Handle a xmpp: uri"
|
||||||
msgstr "Το URI \"%s\" δεν είναι έγκυρο."
|
msgstr "Το URI \"%s\" δεν είναι έγκυρο."
|
||||||
|
|
||||||
#: ../src/gajim-remote-plugin.py:254 ../src/gajim-remote.py:279
|
#: ../src/gajim-remote-plugin.py:254 ../src/gajim-remote.py:279
|
||||||
|
|
2
po/he.po
2
po/he.po
|
@ -9628,7 +9628,7 @@ msgstr "cli"
|
||||||
|
|
||||||
#: ../src/gajim-remote.py:277
|
#: ../src/gajim-remote.py:277
|
||||||
#, fuzzy
|
#, fuzzy
|
||||||
msgid "Handle a xmpp:/ uri"
|
msgid "Handle a xmpp: uri"
|
||||||
msgstr "cli"
|
msgstr "cli"
|
||||||
|
|
||||||
#: ../src/gajim-remote.py:279
|
#: ../src/gajim-remote.py:279
|
||||||
|
|
2
po/pl.po
2
po/pl.po
|
@ -8979,7 +8979,7 @@ msgid "Account in which the avatar will be set; if not specified, the avatar wil
|
||||||
msgstr "Konto, dla którego ma być ustawiony awatar; jeżeli nie jest określone, awatar zostanie ustawiony dla wszystkich kont"
|
msgstr "Konto, dla którego ma być ustawiony awatar; jeżeli nie jest określone, awatar zostanie ustawiony dla wszystkich kont"
|
||||||
|
|
||||||
#: ../src/gajim-remote.py:278
|
#: ../src/gajim-remote.py:278
|
||||||
msgid "Handle a xmpp:/ uri"
|
msgid "Handle a xmpp: uri"
|
||||||
msgstr "Obsługuj URI xmpp:/"
|
msgstr "Obsługuj URI xmpp:/"
|
||||||
|
|
||||||
#: ../src/gajim-remote.py:280
|
#: ../src/gajim-remote.py:280
|
||||||
|
|
2
po/tr.po
2
po/tr.po
|
@ -7786,7 +7786,7 @@ msgstr ""
|
||||||
|
|
||||||
#: ../src/gajim-remote.py:277
|
#: ../src/gajim-remote.py:277
|
||||||
#, fuzzy
|
#, fuzzy
|
||||||
msgid "Handle a xmpp:/ uri"
|
msgid "Handle a xmpp: uri"
|
||||||
msgstr "Adres verilmedi"
|
msgstr "Adres verilmedi"
|
||||||
|
|
||||||
#: ../src/gajim-remote.py:279
|
#: ../src/gajim-remote.py:279
|
||||||
|
|
|
@ -245,7 +245,6 @@ class Config:
|
||||||
'notification_avatar_height': [opt_int, 48],
|
'notification_avatar_height': [opt_int, 48],
|
||||||
'muc_highlight_words': [opt_str, '', _('A semicolon-separated list of words that will be highlighted in group chats.')],
|
'muc_highlight_words': [opt_str, '', _('A semicolon-separated list of words that will be highlighted in group chats.')],
|
||||||
'quit_on_roster_x_button': [opt_bool, False, _('If True, quits Gajim when X button of Window Manager is clicked. This setting is taken into account only if notification icon is used.')],
|
'quit_on_roster_x_button': [opt_bool, False, _('If True, quits Gajim when X button of Window Manager is clicked. This setting is taken into account only if notification icon is used.')],
|
||||||
'check_if_gajim_is_default': [opt_bool, True, _('If True, Gajim will check if it\'s the default jabber client on each startup.')],
|
|
||||||
'show_unread_tab_icon': [opt_bool, False, _('If True, Gajim will display an icon on each tab containing unread messages. Depending on the theme, this icon may be animated.')],
|
'show_unread_tab_icon': [opt_bool, False, _('If True, Gajim will display an icon on each tab containing unread messages. Depending on the theme, this icon may be animated.')],
|
||||||
'show_status_msgs_in_roster': [opt_bool, True, _('If True, Gajim will display the status message, if not empty, for every contact under the contact name in roster window.'), True],
|
'show_status_msgs_in_roster': [opt_bool, True, _('If True, Gajim will display the status message, if not empty, for every contact under the contact name in roster window.'), True],
|
||||||
'show_avatars_in_roster': [opt_bool, True, '', True],
|
'show_avatars_in_roster': [opt_bool, True, '', True],
|
||||||
|
|
|
@ -608,6 +608,7 @@ class Sign(TextHandler):
|
||||||
__bool__ = __nonzero__
|
__bool__ = __nonzero__
|
||||||
|
|
||||||
def handle_status(self, key, value):
|
def handle_status(self, key, value):
|
||||||
|
self.status = ''
|
||||||
if key in ("USERID_HINT", "NEED_PASSPHRASE", "BAD_PASSPHRASE",
|
if key in ("USERID_HINT", "NEED_PASSPHRASE", "BAD_PASSPHRASE",
|
||||||
"GOOD_PASSPHRASE", "BEGIN_SIGNING", "CARDCTRL", "INV_SGNR",
|
"GOOD_PASSPHRASE", "BEGIN_SIGNING", "CARDCTRL", "INV_SGNR",
|
||||||
"NO_SGNR", "MISSING_PASSPHRASE", "NEED_PASSPHRASE_PIN",
|
"NO_SGNR", "MISSING_PASSPHRASE", "NEED_PASSPHRASE_PIN",
|
||||||
|
|
|
@ -557,10 +557,6 @@ class PreferencesWindow:
|
||||||
|
|
||||||
self.update_proxy_list()
|
self.update_proxy_list()
|
||||||
|
|
||||||
# check if gajm is default
|
|
||||||
st = gajim.config.get('check_if_gajim_is_default')
|
|
||||||
self.xml.get_object('check_default_client_checkbutton').set_active(st)
|
|
||||||
|
|
||||||
# Ignore messages from unknown contacts
|
# Ignore messages from unknown contacts
|
||||||
w = self.xml.get_object('ignore_events_from_unknown_contacts_checkbutton')
|
w = self.xml.get_object('ignore_events_from_unknown_contacts_checkbutton')
|
||||||
st = self.get_per_account_option('ignore_unknown_contacts')
|
st = self.get_per_account_option('ignore_unknown_contacts')
|
||||||
|
@ -1179,9 +1175,6 @@ class PreferencesWindow:
|
||||||
widget.set_inconsistent(False)
|
widget.set_inconsistent(False)
|
||||||
self.on_per_account_checkbutton_toggled(widget, 'send_idle_time')
|
self.on_per_account_checkbutton_toggled(widget, 'send_idle_time')
|
||||||
|
|
||||||
def on_check_default_client_checkbutton_toggled(self, widget):
|
|
||||||
self.on_checkbutton_toggled(widget, 'check_if_gajim_is_default')
|
|
||||||
|
|
||||||
def on_notify_gmail_checkbutton_toggled(self, widget):
|
def on_notify_gmail_checkbutton_toggled(self, widget):
|
||||||
self.on_checkbutton_toggled(widget, 'notify_on_new_gmail_email')
|
self.on_checkbutton_toggled(widget, 'notify_on_new_gmail_email')
|
||||||
|
|
||||||
|
|
|
@ -677,94 +677,6 @@ def decode_filechooser_file_paths(file_paths):
|
||||||
|
|
||||||
return file_paths_list
|
return file_paths_list
|
||||||
|
|
||||||
def possibly_set_gajim_as_xmpp_handler():
|
|
||||||
"""
|
|
||||||
Register (by default only the first time) 'xmmp:' to Gajim
|
|
||||||
"""
|
|
||||||
path_to_dot_kde = os.path.expanduser('~/.kde')
|
|
||||||
if os.path.exists(path_to_dot_kde):
|
|
||||||
path_to_kde_file = os.path.join(path_to_dot_kde,
|
|
||||||
'share/services/xmpp.protocol')
|
|
||||||
else:
|
|
||||||
path_to_kde_file = None
|
|
||||||
|
|
||||||
def set_gajim_as_xmpp_handler(is_checked=None):
|
|
||||||
if is_checked is not None:
|
|
||||||
# come from confirmation dialog
|
|
||||||
gajim.config.set('check_if_gajim_is_default', is_checked)
|
|
||||||
path_to_gajim_script, typ = get_abspath_for_script('gajim-remote', True)
|
|
||||||
if path_to_gajim_script:
|
|
||||||
if typ == 'svn':
|
|
||||||
command = path_to_gajim_script + ' handle_uri %s'
|
|
||||||
else: # 'installed'
|
|
||||||
command = 'gajim-remote handle_uri %s'
|
|
||||||
|
|
||||||
# setting for GNOME/Gconf
|
|
||||||
client.set_bool('/desktop/gnome/url-handlers/xmpp/enabled', True)
|
|
||||||
client.set_string('/desktop/gnome/url-handlers/xmpp/command',
|
|
||||||
command)
|
|
||||||
client.set_bool('/desktop/gnome/url-handlers/xmpp/needs_terminal',
|
|
||||||
False)
|
|
||||||
|
|
||||||
# setting for KDE
|
|
||||||
if path_to_kde_file is not None: # user has run kde at least once
|
|
||||||
try:
|
|
||||||
f = open(path_to_kde_file, 'a')
|
|
||||||
f.write('''\
|
|
||||||
[Protocol]
|
|
||||||
exec=%s "%%u"
|
|
||||||
protocol=xmpp
|
|
||||||
input=none
|
|
||||||
output=none
|
|
||||||
helper=true
|
|
||||||
listing=false
|
|
||||||
reading=false
|
|
||||||
writing=false
|
|
||||||
makedir=false
|
|
||||||
deleting=false
|
|
||||||
icon=gajim
|
|
||||||
Description=xmpp
|
|
||||||
''' % command)
|
|
||||||
f.close()
|
|
||||||
except IOError:
|
|
||||||
log.debug("I/O Error writing settings to %s",
|
|
||||||
repr(path_to_kde_file), exc_info=True)
|
|
||||||
else: # no gajim remote, stop ask user everytime
|
|
||||||
gajim.config.set('check_if_gajim_is_default', False)
|
|
||||||
|
|
||||||
try:
|
|
||||||
gi.require_version('GConf', '2.0')
|
|
||||||
GConf = importlib.import_module('gi.repository.GConf')
|
|
||||||
# in try because daemon may not be there
|
|
||||||
client = GConf.Client.get_default()
|
|
||||||
except Exception:
|
|
||||||
return
|
|
||||||
|
|
||||||
old_command = client.get_string('/desktop/gnome/url-handlers/xmpp/command')
|
|
||||||
if not old_command or old_command.endswith(' open_chat %s'):
|
|
||||||
# first time (GNOME/GCONF) or old Gajim version
|
|
||||||
we_set = True
|
|
||||||
elif path_to_kde_file is not None and not os.path.exists(path_to_kde_file):
|
|
||||||
# only the first time (KDE)
|
|
||||||
we_set = True
|
|
||||||
else:
|
|
||||||
we_set = False
|
|
||||||
|
|
||||||
if we_set:
|
|
||||||
set_gajim_as_xmpp_handler()
|
|
||||||
elif old_command and not old_command.endswith(' handle_uri %s'):
|
|
||||||
# xmpp: is currently handled by another program, so ask the user
|
|
||||||
pritext = _('Gajim is not the default Jabber client')
|
|
||||||
sectext = _('Would you like to make Gajim the default Jabber client?')
|
|
||||||
checktext = _('Always check to see if Gajim is the default Jabber '
|
|
||||||
'client on startup')
|
|
||||||
def on_cancel(checked):
|
|
||||||
gajim.config.set('check_if_gajim_is_default', checked)
|
|
||||||
dlg = dialogs.ConfirmationDialogCheck(pritext, sectext, checktext,
|
|
||||||
set_gajim_as_xmpp_handler, on_cancel)
|
|
||||||
if gajim.config.get('check_if_gajim_is_default'):
|
|
||||||
dlg.checkbutton.set_active(True)
|
|
||||||
|
|
||||||
def escape_underscore(s):
|
def escape_underscore(s):
|
||||||
"""
|
"""
|
||||||
Escape underlines to prevent them from being interpreted as keyboard
|
Escape underlines to prevent them from being interpreted as keyboard
|
||||||
|
|
|
@ -1213,6 +1213,8 @@ class Interface:
|
||||||
file_props = None
|
file_props = None
|
||||||
# get the file_props of our session
|
# get the file_props of our session
|
||||||
file_props = FilesProp.getFileProp(obj.conn.name, obj.sid)
|
file_props = FilesProp.getFileProp(obj.conn.name, obj.sid)
|
||||||
|
if not file_props:
|
||||||
|
return
|
||||||
ft.set_status(file_props, 'stop')
|
ft.set_status(file_props, 'stop')
|
||||||
file_props.error = -4 # is it the right error code?
|
file_props.error = -4 # is it the right error code?
|
||||||
ft.show_stopped(obj.jid, file_props, 'Peer cancelled ' +
|
ft.show_stopped(obj.jid, file_props, 'Peer cancelled ' +
|
||||||
|
@ -2772,10 +2774,6 @@ class Interface:
|
||||||
if gajim.config.get('verbose'):
|
if gajim.config.get('verbose'):
|
||||||
logging_helpers.set_verbose()
|
logging_helpers.set_verbose()
|
||||||
|
|
||||||
# Is Gajim default app?
|
|
||||||
if os.name != 'nt' and gajim.config.get('check_if_gajim_is_default'):
|
|
||||||
gtkgui_helpers.possibly_set_gajim_as_xmpp_handler()
|
|
||||||
|
|
||||||
for account in gajim.config.get_per('accounts'):
|
for account in gajim.config.get_per('accounts'):
|
||||||
if gajim.config.get_per('accounts', account, 'is_zeroconf'):
|
if gajim.config.get_per('accounts', account, 'is_zeroconf'):
|
||||||
gajim.ZEROCONF_ACC_NAME = account
|
gajim.ZEROCONF_ACC_NAME = account
|
||||||
|
|
Loading…
Reference in New Issue