Ability to register new incoming network events (based on exisiting one) added. Modify-only network events are possible (eg. add some text each message, but don't create any new global event). Events creation can be chained. Examples of new network events classes are in New Events Example plugin. Events from src/gajim.py now all go through Global Events Dispatcher and only through it (easy to modify, in chain, data passed with them).
127 lines
No EOL
4.1 KiB
Python
127 lines
No EOL
4.1 KiB
Python
# -*- coding: utf-8 -*-
|
|
##
|
|
## This file is part of Gajim.
|
|
##
|
|
## Gajim is free software; you can redistribute it and/or modify
|
|
## it under the terms of the GNU General Public License as published
|
|
## by the Free Software Foundation; version 3 only.
|
|
##
|
|
## Gajim is distributed in the hope that it will be useful,
|
|
## but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
## GNU General Public License for more details.
|
|
##
|
|
## You should have received a copy of the GNU General Public License
|
|
## along with Gajim. If not, see <http://www.gnu.org/licenses/>.
|
|
##
|
|
'''
|
|
Events Dump plugin.
|
|
|
|
Dumps info about selected events to console.
|
|
|
|
:author: Mateusz Biliński <mateusz@bilinski.it>
|
|
:since: 10th August 2008
|
|
:copyright: Copyright (2008) Mateusz Biliński <mateusz@bilinski.it>
|
|
:license: GPL
|
|
'''
|
|
|
|
import new
|
|
from pprint import pformat
|
|
|
|
from plugins import GajimPlugin
|
|
from plugins.helpers import log_calls, log
|
|
from common import ged
|
|
|
|
class EventsDumpPlugin(GajimPlugin):
|
|
name = u'Events Dump'
|
|
short_name = u'events_dump'
|
|
version = u'0.1'
|
|
description = u'''Dumps info about selected events to console.'''
|
|
authors = [u'Mateusz Biliński <mateusz@bilinski.it>']
|
|
homepage = u'http://blog.bilinski.it'
|
|
|
|
@log_calls('EventsDumpPlugin')
|
|
def init(self):
|
|
self.config_dialog = None
|
|
#self.gui_extension_points = {}
|
|
#self.config_default_values = {}
|
|
events_from_old_dbus_support = [
|
|
'Roster', 'AccountPresence', 'ContactPresence',
|
|
'ContactAbsence', 'ContactStatus', 'NewMessage',
|
|
'Subscribe', 'Subscribed', 'Unsubscribed',
|
|
'NewAccount', 'VcardInfo', 'LastStatusTime',
|
|
'OsInfo', 'GCPresence', 'GCMessage', 'RosterInfo',
|
|
'NewGmail']
|
|
|
|
events_from_src_gajim = [
|
|
'ROSTER', 'WARNING', 'ERROR',
|
|
'INFORMATION', 'ERROR_ANSWER', 'STATUS',
|
|
'NOTIFY', 'MSGERROR', 'MSGSENT', 'MSGNOTSENT',
|
|
'SUBSCRIBED', 'UNSUBSCRIBED', 'SUBSCRIBE',
|
|
'AGENT_ERROR_INFO', 'AGENT_ERROR_ITEMS',
|
|
'AGENT_REMOVED', 'REGISTER_AGENT_INFO',
|
|
'AGENT_INFO_ITEMS', 'AGENT_INFO_INFO',
|
|
'QUIT', 'NEW_ACC_CONNECTED',
|
|
'NEW_ACC_NOT_CONNECTED', 'ACC_OK', 'ACC_NOT_OK',
|
|
'MYVCARD', 'VCARD', 'LAST_STATUS_TIME', 'OS_INFO',
|
|
'GC_NOTIFY', 'GC_MSG', 'GC_SUBJECT', 'GC_CONFIG',
|
|
'GC_CONFIG_CHANGE', 'GC_INVITATION',
|
|
'GC_AFFILIATION', 'GC_PASSWORD_REQUIRED',
|
|
'BAD_PASSPHRASE', 'ROSTER_INFO', 'BOOKMARKS',
|
|
'CON_TYPE', 'CONNECTION_LOST', 'FILE_REQUEST',
|
|
'GMAIL_NOTIFY', 'FILE_REQUEST_ERROR',
|
|
'FILE_SEND_ERROR', 'STANZA_ARRIVED', 'STANZA_SENT',
|
|
'HTTP_AUTH', 'VCARD_PUBLISHED',
|
|
'VCARD_NOT_PUBLISHED', 'ASK_NEW_NICK', 'SIGNED_IN',
|
|
'METACONTACTS', 'ATOM_ENTRY', 'FAILED_DECRYPT',
|
|
'PRIVACY_LISTS_RECEIVED', 'PRIVACY_LIST_RECEIVED',
|
|
'PRIVACY_LISTS_ACTIVE_DEFAULT',
|
|
'PRIVACY_LIST_REMOVED', 'ZC_NAME_CONFLICT',
|
|
'PING_SENT', 'PING_REPLY', 'PING_ERROR',
|
|
'SEARCH_FORM', 'SEARCH_RESULT',
|
|
'RESOURCE_CONFLICT', 'PEP_CONFIG',
|
|
'UNIQUE_ROOM_ID_UNSUPPORTED',
|
|
'UNIQUE_ROOM_ID_SUPPORTED', 'SESSION_NEG',
|
|
'GPG_PASSWORD_REQUIRED', 'SSL_ERROR',
|
|
'FINGERPRINT_ERROR', 'PLAIN_CONNECTION',
|
|
'PUBSUB_NODE_REMOVED', 'PUBSUB_NODE_NOT_REMOVED']
|
|
|
|
network_events_from_core = ['raw-message-received',
|
|
'raw-iq-received',
|
|
'raw-pres-received']
|
|
|
|
network_events_generated_in_nec = [
|
|
'customized-message-received',
|
|
'more-customized-message-received',
|
|
'modify-only-message-received',
|
|
'enriched-chat-message-received']
|
|
|
|
self.events_names = []
|
|
self.events_names += network_events_from_core
|
|
self.events_names += network_events_generated_in_nec
|
|
|
|
self.events_handlers = {}
|
|
self._set_handling_methods()
|
|
|
|
|
|
def activate(self):
|
|
pass
|
|
|
|
def deactivate(self):
|
|
pass
|
|
|
|
def _set_handling_methods(self):
|
|
for event_name in self.events_names:
|
|
setattr(self, event_name,
|
|
new.instancemethod(
|
|
self._generate_handling_method(event_name),
|
|
self,
|
|
EventsDumpPlugin))
|
|
self.events_handlers[event_name] = (ged.POSTCORE,
|
|
getattr(self, event_name))
|
|
|
|
def _generate_handling_method(self, event_name):
|
|
def handler(self, *args):
|
|
print "Event '%s' occured. Arguments: %s\n\n===\n"%(event_name, pformat(args))
|
|
|
|
return handler |